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
|
/*---
includes: [compareArray.js, compatFs.js]
flags: [async]
---*/
var dname = `${test_dir}/fs_promises_αβγ_08/`;
var path = 'one/two/three/αβγ';
var wipePath = (root, path, nofail) => {
path
.split('/')
.map((x, i, a) => {
return root + a.slice(0, i + 1).join('/');
})
.reverse()
.map((dir) => {
try {
fs.rmdirSync(dir);
} catch (e) {
if (!nofail) {
throw e;
}
}
});
};
let stages = [];
var testSync = () => new Promise((resolve, reject) => {
try {
wipePath(dname, path + '/' + path, true);
fs.rmdirSync(dname);
} catch (e) {
}
try {
fs.mkdirSync(dname);
fs.mkdirSync(dname, { recursive: true });
fs.mkdirSync(dname + '/', { recursive: true });
fs.mkdirSync(dname + '////', { recursive: true });
fs.mkdirSync(dname + path, { recursive: true });
wipePath(dname, path);
fs.mkdirSync(dname + '////' + path + '////' + path + '////', { recursive: true });
wipePath(dname, path + '/' + path);
try {
fs.mkdirSync(dname + path, { recursive: true, mode: 0 });
} catch (e) {
if (e.code != 'EACCES') {
reject(e);
}
}
wipePath(dname, path, true);
try {
fs.mkdirSync(dname + path, { recursive: true });
fs.writeFileSync(dname + path + '/one', 'not dir');
fs.mkdirSync(dname + path + '/' + path, { recursive: true });
} catch (e) {
if (e.code != 'ENOTDIR') {
reject(e);
}
}
fs.unlinkSync(dname + path + '/one');
wipePath(dname, path);
fs.rmdirSync(dname);
stages.push("mkdirSync")
resolve();
} catch (e) {
reject(e);
}
});
let p = Promise.resolve()
.then(testSync)
.then(() => assert.compareArray(stages, ["mkdirSync"]))
p.then($DONE, $DONE);
|