forked from smooth80/webpack
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathContextModuleFactory.unittest.js
123 lines (121 loc) · 3.12 KB
/
ContextModuleFactory.unittest.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
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
117
118
119
120
121
122
123
"use strict";
const { createFsFromVolume, Volume } = require("memfs");
const ContextModuleFactory = require("../lib/ContextModuleFactory");
describe("ContextModuleFactory", () => {
describe("resolveDependencies", () => {
let factory, memfs;
beforeEach(() => {
factory = new ContextModuleFactory([]);
memfs = createFsFromVolume(new Volume());
});
it("should not report an error when ENOENT errors happen", done => {
memfs.readdir = (dir, callback) => {
setTimeout(() => callback(null, ["/file"]));
};
memfs.stat = (file, callback) => {
let err = new Error("fake ENOENT error");
err.code = "ENOENT";
setTimeout(() => callback(err, null));
};
factory.resolveDependencies(
memfs,
{
resource: "/",
recursive: true,
regExp: /.*/
},
(err, res) => {
expect(err).toBeFalsy();
expect(Array.isArray(res)).toBe(true);
expect(res.length).toBe(0);
done();
}
);
});
it("should report an error when non-ENOENT errors happen", done => {
memfs.readdir = (dir, callback) => {
setTimeout(() => callback(null, ["/file"]));
};
memfs.stat = (file, callback) => {
let err = new Error("fake EACCES error");
err.code = "EACCES";
setTimeout(() => callback(err, null));
};
factory.resolveDependencies(
memfs,
{
resource: "/",
recursive: true,
regExp: /.*/
},
(err, res) => {
expect(err).toBeInstanceOf(Error);
expect(res).toBeFalsy();
done();
}
);
});
it("should return callback with [] if circular symlinks exist", done => {
let statDirStatus = 0;
memfs.readdir = (dir, callback) => {
statDirStatus++;
setTimeout(() => callback(null, ["/A"]));
};
memfs.stat = (file, callback) => {
const resolvedValue = {
isDirectory: () => statDirStatus === 1,
isFile: () => statDirStatus !== 1
};
setTimeout(() => callback(null, resolvedValue));
};
memfs.realpath = (dir, callback) => {
const realPath = dir.split("/");
setTimeout(() => callback(null, realPath[realPath.length - 1]));
};
factory.resolveDependencies(
memfs,
{
resource: "/A",
recursive: true,
regExp: /.*/
},
(err, res) => {
expect(res).toStrictEqual([]);
done();
}
);
});
it("should not return callback with [] if there are no circular symlinks", done => {
let statDirStatus = 0;
memfs.readdir = (dir, callback) => {
statDirStatus++;
setTimeout(() => callback(null, ["/B"]));
};
memfs.stat = (file, callback) => {
const resolvedValue = {
isDirectory: () => statDirStatus === 1,
isFile: () => statDirStatus !== 1
};
setTimeout(() => callback(null, resolvedValue));
};
memfs.realpath = (dir, callback) => {
const realPath = dir.split("/");
setTimeout(() => callback(null, realPath[realPath.length - 1]));
};
factory.resolveDependencies(
memfs,
{
resource: "/A",
recursive: true,
regExp: /.*/
},
(err, res) => {
expect(res).not.toStrictEqual([]);
expect(Array.isArray(res)).toBe(true);
expect(res.length).toBe(1);
done();
}
);
});
});
});