Skip to content
This repository has been archived by the owner on Feb 9, 2023. It is now read-only.

Latest commit

 

History

History
169 lines (124 loc) · 3.22 KB

README.md

File metadata and controls

169 lines (124 loc) · 3.22 KB

Examples

Running Examples Locally

Local configuration

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

{
  "koaApi": "http://localhost",
  "logLevel": "info",
  "logFilter": null,
  "logOutputMode": "short"
}

Override any option with the corresponding environment variable:

  • KOA_API (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 health

Pass arguments to examples with

$ yarn run example health koa

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

$ yarn run example:watch health

Debugging examples

Debug examples with, e.g.,

$ yarn run example:inspect health

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 health

Writing New Examples

Modify the serverOptions function in example/index.js` to use server configuration values in your 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.