From 6327019d5f9cdb17810acf587793b9d151ed86ea Mon Sep 17 00:00:00 2001 From: Art Date: Tue, 11 Apr 2023 00:59:32 +0700 Subject: [PATCH] Apply suggestions from code review Co-authored-by: Tom Mrazauskas --- docs/ExpectAPI.md | 10 +++++----- docs/SnapshotTesting.md | 6 +++++- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/docs/ExpectAPI.md b/docs/ExpectAPI.md index dbb8aa699e96..7a7722efe2df 100644 --- a/docs/ExpectAPI.md +++ b/docs/ExpectAPI.md @@ -744,13 +744,13 @@ You can provide an optional `propertyMatchers` object argument, which has asymme You can provide an optional `hint` string argument that is appended to the test name. Although Jest always appends a number at the end of a snapshot name, short descriptive hints might be more useful than numbers to differentiate **multiple** snapshots in a **single** `it` or `test` block. Jest sorts snapshots by name in the corresponding `.snap` file. -### `.toMatchNamedSnapshot(propertyMatchers?, snapshotName?)` +### `.toMatchNamedSnapshot(snapshotName, propertyMatchers?)` This ensures that a value matches the most recent snapshot. Check out [the Snapshot Testing guide](SnapshotTesting.md) for more information. You can provide an optional `propertyMatchers` object argument, which has asymmetric matchers as values of a subset of expected properties, **if** the received value will be an **object** instance. It is like `toMatchObject` with flexible criteria for a subset of properties, followed by a snapshot test as exact criteria for the rest of the properties. -You can provide an optional `snapshotName` string argument that functions as the test name. By providing a snapshot name (as opposed to letting Jest infer the name from context) snapshot names can be guaranteed to be consistent across test runs, whatever the context at the time of evaluation. Jest always appends a number at the end of a snapshot name. +By setting the `snapshotName` explicitly (as opposed to letting Jest infer the name from context) it can be guaranteed to be consistent across test runs, whatever the context at the time of evaluation. Jest always appends a number at the end of a snapshot name. Jest sorts snapshots by name in the corresponding `.snap` file. @@ -886,11 +886,11 @@ exports[`drinking flavors throws on octopus 1`] = `"yuck, octopus flavor"`; Check out [React Tree Snapshot Testing](/blog/2016/07/27/jest-14) for more information on snapshot testing. -### `.toThrowErrorMatchingNamedSnapshot(snapshotName?)` +### `.toThrowErrorMatchingNamedSnapshot(snapshotName)` -Use `.toThrowErrorMatchingNamedSnapshot` to test that a functino throws an error matching the most recent snapshot when it is called. +Use `.toThrowErrorMatchingNamedSnapshot` to test that a function throws an error matching the most recent snapshot when it is called. -You can provide an optional `snapshotName` string argument that functions as the test name. By providing a snapshot name (as opposed to letting Jest infer the name from context) snapshot names can be guaranteed to be consistent across test runs, whatever the context at the time of evaluation. Jest always appends a number at the end of a snapshot name. +By setting the `snapshotName` explicitly (as opposed to letting Jest infer the name from context) it can be guaranteed to be consistent across test runs, whatever the context at the time of evaluation. Jest always appends a number at the end of a snapshot name. ### `.toThrowErrorMatchingInlineSnapshot(inlineSnapshot)` diff --git a/docs/SnapshotTesting.md b/docs/SnapshotTesting.md index 23ae76570326..69594f37c050 100644 --- a/docs/SnapshotTesting.md +++ b/docs/SnapshotTesting.md @@ -264,7 +264,11 @@ Now, every time the snapshot test case runs, `Date.now()` will return `148236336 Always strive to use descriptive test and/or snapshot names for snapshots. The best names describe the expected snapshot content. This makes it easier for reviewers to verify the snapshots during review, and for anyone to know whether or not an outdated snapshot is the correct behavior before updating. -The default matcher, `toMatchSnapshot`, infers the name based on the test function context when the snapshot is evaluated. This can cause snapshots in tests that are run concurrently to have different names on each test run. If you want to guarantee consistent names, you can use `toMatchNamedSnapshot` as an alternative matcher. +:::tip + +The `toMatchSnapshot` matcher infers the name based on the test function context when the snapshot is evaluated. This can cause snapshots in tests that are run concurrently to have different names on each test run. If you want to guarantee consistent names, you can use the `toMatchNamedSnapshot` matcher. + +::: For example, compare: