-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathgenerate-random-tree.unit.test.ts
More file actions
79 lines (67 loc) · 2.14 KB
/
generate-random-tree.unit.test.ts
File metadata and controls
79 lines (67 loc) · 2.14 KB
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
import { generateRandomFilesAndFolders } from "examples/utils/generate-random-file-tree";
import VirtualDrive from "@/virtual-drive";
class MockVirtualDrive implements Partial<VirtualDrive> {
private files: Record<string, any> = {};
private folders: Record<string, any> = {};
createFileByPath({
relativePath,
itemId,
size = 0,
creationTime = Date.now(),
lastWriteTime = Date.now(),
}: {
relativePath: string;
itemId: string;
size?: number;
creationTime?: number;
lastWriteTime?: number;
}): void {
this.files[relativePath] = { itemId, size, creationTime, lastWriteTime };
}
createFolderByPath({
relativePath,
itemId,
size = 0,
creationTime = Date.now(),
lastWriteTime = Date.now(),
}: {
relativePath: string;
itemId: string;
size?: number;
creationTime?: number;
lastWriteTime?: number;
}): void {
this.folders[relativePath] = { itemId, size, creationTime, lastWriteTime };
}
getFiles(): Record<string, any> {
return this.files;
}
}
describe("When call generateRandomFilesAndFolders", () => {
it("Then it generates the correct structure of files and folders with sizes following a normal distribution", async () => {
// Arrange
const mockDrive = new MockVirtualDrive();
const meanSizeMB = 1;
const stdDevMB = 0.5;
const options = {
rootPath: "/root",
depth: 2,
filesPerFolder: 100,
foldersPerLevel: 2,
meanSize: meanSizeMB,
stdDev: stdDevMB,
timeOffset: 1000,
};
// Act
await generateRandomFilesAndFolders(mockDrive as unknown as VirtualDrive, options);
// Assert
const files = mockDrive.getFiles();
expect(Object.keys(files).length).toBeGreaterThan(0);
const sizes = Object.values(files).map((file) => file.size / (1024 * 1024));
const lowerBound = meanSizeMB - 3 * stdDevMB;
const upperBound = meanSizeMB + 3 * stdDevMB;
const withinRange = sizes.filter((size) => size >= lowerBound && size <= upperBound);
const percentageWithinRange = (withinRange.length / sizes.length) * 100;
expect(percentageWithinRange).toBeGreaterThanOrEqual(99);
});
});