forked from sourcegraph/sourcegraph-public-snapshot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjest.snapshot-resolver.js
39 lines (33 loc) · 1.66 KB
/
jest.snapshot-resolver.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
// @ts-check
const path = require('path')
// TODO(bazel): drop when non-bazel removed.
const IS_BAZEL = !!(process.env.JS_BINARY__TARGET || process.env.BAZEL_BINDIR || process.env.BAZEL_TEST)
// TODO(bazel): bazel runs tests on the pre-compiled .js files, non-bazel runs on .tsx files.
// This snapshot resolver edits the pre-compiled .js to snapshots assuming a .tsx extension.
// This can be removed and snapshot files renamed to .js when non-bazel is removed.
// NOTE: this assumes all snapshot tests are in .tsx files, not .ts or .jsx and will not work for non-.tsx files.
const SNAPSHOT_EXTENSION = '.tsx.snap'
const TEST_EXTENSION = IS_BAZEL ? '.js' : '.tsx'
/**
* Bazel runs the tests on pre-compiled .js files so we have no way of knowing
* if the original test was .ts or .tsx. Jest requires mapping from the test file
* name (.js in bazel, .ts[x] in non-bazel) to the snapshot file name (.ts[x].snap)
* without any additional information - if we only know the .js name we don't know
* if the snapshot is .ts or .tsx.
*
* While we need to support non-bazel we can't update the existing snapshots to .js.snap.
* For now, we require all snapshot tests use .tsx extensions.
*/
module.exports = {
resolveSnapshotPath: testPath =>
path.join(
path.join(path.dirname(testPath), '__snapshots__'),
path.basename(testPath).replace(TEST_EXTENSION, SNAPSHOT_EXTENSION)
),
resolveTestPath: snapshotPath =>
path.join(
path.dirname(path.dirname(snapshotPath)),
path.basename(snapshotPath).replace(SNAPSHOT_EXTENSION, TEST_EXTENSION)
),
testPathForConsistencyCheck: path.posix.join(__dirname, 'consistency_check', '__tests__', 'example.test.tsx'),
}