Skip to content

Tiny util for CLI testing: fetch stdout, stderr streams and match data to snapshot

License

Notifications You must be signed in to change notification settings

qiwi/stdstream-snapshot

Repository files navigation

@qiwi/stdstream-snapshot

CI Maintainability Test Coverage npm (scoped)

Util for CLI testing: fetch stdout, stderr streams and match its data to snapshot

Install

yarn add @qiwi/stdstream-snapshot -D
npm add @qiwi/stdstream-snapshot -D

Snapshot

{
  "stderr": "",
  "stdout": "/rules/some-rules.ts\n    2:7   error  'name'...",
  "err": {
    "signal": null,
    "code": 1,
    "killed": false
  }
}

Usage

With Jest:

import {generateSnapshot} from 'stdstream-snapshot'

it('cmd output matches to snapshot', async () => {
  const cmd = 'somecmd --flag=foo -b'
  const result = await generateSnapshot({
    cmd,
  })

  expect(result).toMatchSnapshot()
})

With Jasmine or another test framework with no built-it snapshot API:

import {matchSnapshot} from 'stdstream-snapshot'

it('cmd output matches to snapshot', async () => {
  const cmd = 'somecmd --flag=foo -b'
  const target = './test/snapshots/some-cmd-output.json'
  const result = await matchSnapshot({
    cmd,
    target,
    update: !!process.env.UPDATE_SNAPSHOT
  })

  expect(result).toBe(true)
})

Options

There are several normalization steps supported out of box.

Option Description Default
trim Removes redundant spaces from both ends of strings true
normalizePaths Replaces process.cwd() prefix from any found paths in the output strings true
normalizeSpaces Converts tabs to double spaces true
normalizeEncoding Replaces output rubbish like [8m [10m true

License

MIT

About

Tiny util for CLI testing: fetch stdout, stderr streams and match data to snapshot

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published