1.6.0 • Published 6 days ago

@vitest/snapshot v1.6.0

Weekly downloads
-
License
MIT
Repository
github
Last release
6 days ago

@vitest/snapshot

Lightweight implementation of Jest's snapshots.

Usage

import { SnapshotClient } from '@vitest/snapshot'
import { NodeSnapshotEnvironment } from '@vitest/snapshot/environment'
import { SnapshotManager } from '@vitest/snapshot/manager'

const client = new SnapshotClient({
  // you need to provide your own equality check implementation if you use it
  // this function is called when `.toMatchSnapshot({ property: 1 })` is called
  isEqual: (received, expected) => equals(received, expected, [iterableEquality, subsetEquality]),
})

// class that implements snapshot saving and reading
// by default uses fs module, but you can provide your own implementation depending on the environment
const environment = new NodeSnapshotEnvironment()

// you need to implement this yourselves,
// this depends on your runner
function getCurrentFilepath() {
  return '/file.spec.js'
}
function getCurrentTestName() {
  return 'test1'
}

// example for inline snapshots, nothing is required to support regular snapshots,
// just call `assert` with `isInline: false`
function wrapper(received) {
  function __INLINE_SNAPSHOT__(inlineSnapshot, message) {
    client.assert({
      received,
      message,
      isInline: true,
      inlineSnapshot,
      filepath: getCurrentFilepath(),
      name: getCurrentTestName(),
    })
  }
  return {
    // the name is hard-coded, it should be inside another function, so Vitest can find the actual test file where it was called (parses call stack trace + 2)
    // you can override this behaviour in SnapshotState's `_inferInlineSnapshotStack` method by providing your own SnapshotState to SnapshotClient constructor
    toMatchInlineSnapshot: (...args) => __INLINE_SNAPSHOT__(...args),
  }
}

const options = {
  updateSnapshot: 'new',
  snapshotEnvironment: environment,
}

await client.startCurrentRun(getCurrentFilepath(), getCurrentTestName(), options)

// this will save snapshot to a file which is returned by "snapshotEnvironment.resolvePath"
client.assert({
  received: 'some text',
  isInline: false,
})

// uses "pretty-format", so it requires quotes
// also naming is hard-coded when parsing test files
wrapper('text 1').toMatchInlineSnapshot()
wrapper('text 2').toMatchInlineSnapshot('"text 2"')

const result = await client.finishCurrentRun() // this saves files and returns SnapshotResult

// you can use manager to manage several clients
const manager = new SnapshotManager(options)
manager.add(result)

// do something
// and then read the summary

console.log(manager.summary)
1.6.0

6 days ago

1.5.3

9 days ago

1.5.2

14 days ago

1.5.1

15 days ago

1.5.0

27 days ago

1.4.0

2 months ago

1.3.1

3 months ago

1.3.0

3 months ago

1.2.2

3 months ago

1.2.1

4 months ago

1.2.0

4 months ago

1.1.3

4 months ago

1.1.2

4 months ago

1.1.1

4 months ago

1.1.0

5 months ago

1.0.4

5 months ago

1.0.3

5 months ago

1.0.2

5 months ago

1.0.1

5 months ago

1.0.0

5 months ago

0.34.6

7 months ago

0.34.5

8 months ago

0.34.4

8 months ago

0.34.3

9 months ago

0.34.2

9 months ago

0.32.4

10 months ago

0.34.1

9 months ago

0.32.3

10 months ago

0.34.0

9 months ago

0.33.0

10 months ago

0.34.7

7 months ago

1.0.0-beta.2

7 months ago

1.0.0-beta.3

6 months ago

1.0.0-beta.4

6 months ago

1.0.0-beta.5

6 months ago

1.0.0-beta.0

7 months ago

1.0.0-beta.1

7 months ago

1.0.0-beta.6

5 months ago

0.31.4

11 months ago

0.32.2

11 months ago

0.31.3

11 months ago

0.32.1

11 months ago

0.31.2

11 months ago

0.32.0

11 months ago

0.31.1

12 months ago

0.31.0

1 year ago

0.30.1

1 year ago

0.30.0

1 year ago