-
Notifications
You must be signed in to change notification settings - Fork 774
/
test.mjs
116 lines (112 loc) · 2.29 KB
/
test.mjs
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
import assert from 'assert'
import fsLegacy from './lib/index.js'
// NOTE: eslint comments needed because we're importing the same file multiple times
import fsDefault from './lib/esm.mjs' // eslint-disable-line
import * as fsStar from './lib/esm.mjs'
import {
copy,
copySync,
emptyDirSync,
emptydirSync,
emptyDir,
emptydir,
createFile,
createFileSync,
ensureFile,
ensureFileSync,
createLink,
createLinkSync,
ensureLink,
ensureLinkSync,
createSymlink,
createSymlinkSync,
ensureSymlink,
ensureSymlinkSync,
readJson,
readJsonSync,
writeJson,
writeJsonSync,
outputJson,
outputJsonSync,
outputJSON,
outputJSONSync,
writeJSON,
writeJSONSync,
readJSON,
readJSONSync,
mkdirs,
mkdirsSync,
mkdirp,
mkdirpSync,
ensureDir,
ensureDirSync,
move,
moveSync,
outputFile,
outputFileSync,
pathExists,
pathExistsSync,
remove,
removeSync
} from './lib/esm.mjs' // eslint-disable-line
const fsNamed = [
copy,
copySync,
emptyDirSync,
emptydirSync,
emptyDir,
emptydir,
createFile,
createFileSync,
ensureFile,
ensureFileSync,
createLink,
createLinkSync,
ensureLink,
ensureLinkSync,
createSymlink,
createSymlinkSync,
ensureSymlink,
ensureSymlinkSync,
readJson,
readJsonSync,
writeJson,
writeJsonSync,
outputJson,
outputJsonSync,
outputJSON,
outputJSONSync,
writeJSON,
writeJSONSync,
readJSON,
readJSONSync,
mkdirs,
mkdirsSync,
mkdirp,
mkdirpSync,
ensureDir,
ensureDirSync,
move,
moveSync,
outputFile,
outputFileSync,
pathExists,
pathExistsSync,
remove,
removeSync
]
const keys = Object.keys(fsDefault)
assert.deepStrictEqual(Object.values(fsDefault), fsNamed, 'named and default exports should match')
assert.deepStrictEqual(
Object.entries(fsStar)
.filter(([name]) => name !== 'default') // remove "default" property here
.sort(([nameA], [nameB]) => keys.indexOf(nameA) - keys.indexOf(nameB)) // sort for exact match
.map(([name, fn]) => fn),
Object.values(fsDefault),
'star and default exports should match'
)
// default exports a subset of the legacy implementation, but functions are the same
Object.entries(fsDefault).forEach(([name, fn]) => {
assert.strictEqual(fn, fsLegacy[name], `${name}() should match legacy implementation`)
})
console.warn('ESM tests pass!')