Skip to content

Latest commit

 

History

History
166 lines (122 loc) · 3.11 KB

README.md

File metadata and controls

166 lines (122 loc) · 3.11 KB

Examples

Running Examples Locally

Local configuration

Set required and optional configuration options in examples/local.json, e.g.,

{
  "minLevel": 2,
  "logLevel": "info",
  "logFilter": null,
  "logOutputMode": "short"
}

Override any option with the corresponding environment variable:

  • MIN_LEVEL (optional)
  • LOG_LEVEL (optional)
  • LOG_FILTER (optional)
  • LOG_OUTPUT_MODE (optional)

Running examples with arguments

List all runnable examples with

$ yarn run example

Run provided examples with, e.g.,

$ yarn run example adventure

Pass arguments to examples with

$ yarn run example adventure Finn

Automatically watch and rerun an example on changes with, e.g.,

$ yarn run example:watch adventure

Debugging examples

Debug examples with, e.g.,

$ yarn run example:inspect adventure

For examples which run a single process and then exit, create a breakpoint by adding the statement debugger to the top of the example function, e.g.,

export default ({log}) => async () => {
  debugger
  // ...
}

Automatically watch and rerun a debuggable example on changes with, e.g.,

$ yarn run example:inspect:watch adventure

Writing New Examples

  1. Create a new file in examples or add an example to an existing file. Any new dependencies which are only used in examples should be installed as devDependencies. The return value of the function will be logged as data. All exported functions can take options and arguments with defaults, e.g.,

    /* examples/query-api.js */
    import request from 'request-promise'
    
    export default ({
      log,
      fooApi = 'https://example.com'
    }) => async (query = 'foo', page = 1) => {
      const qs = {page: parseInt(page)}
      log.debug({query, qs})
      return request(`${fooApi}/search/${query}`, {qs})
    }
  2. Import and add the example to examples/index.js, e.g.,

    /* examples/index.js */
    import queryApi from './query-api'
    
    export const examples = {
      queryApi,
      // ...
    }
  3. Add any new options to this README and in examples/index.js, e.g.,

    /* examples/index.js */
    const envVars = [
      'FOO_API',
      // ...
    ]
    /* examples/README.md */
    ### Local configuration
    
    Set required and optional configuration options in `examples/local.json`, e.g.,
    
    ```json
    {
      "queryApi": "https://example.com",
      ...
    }
    ```
    
    Override any option with the corresponding environment variable:
    
    - QUERY_API
    - ...
    

Adding Log Filters

  1. Create a new file in examples which exports filters, e.g.,

    /* examples/filters.js */
    // Only print logs with a foo property equal to bar.
    const onlyFooBar = log => log.foo === 'bar'
    
    export default {
      onlyFooBar
    }
  2. Import and add filters to examples/index.js, e.g.,

    /* examples/index.js */
    import filters from './filters'
    
    const { runExample } = createExamples({
      filters,
      ...
    })
  3. Apply the filter by setting LOG_FILTER or logFilter, e.g., LOG_FILTER=onlyFooBar.