webpack/test/ContextModuleFactory.unitte...

168 lines
4.3 KiB
JavaScript
Raw Normal View History

"use strict";
2018-01-24 20:17:21 +08:00
2025-07-03 17:06:45 +08:00
const { Volume, createFsFromVolume } = require("memfs");
const ContextModuleFactory = require("../lib/ContextModuleFactory");
2018-01-24 20:17:21 +08:00
describe("ContextModuleFactory", () => {
describe("resolveDependencies", () => {
2024-07-31 09:56:53 +08:00
let factory;
let memfs;
2018-01-24 20:17:21 +08:00
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) => {
2024-07-31 04:09:42 +08:00
const err = new Error("fake ENOENT error");
err.code = "ENOENT";
setTimeout(() => callback(err, null));
};
2018-02-25 18:46:17 +08:00
factory.resolveDependencies(
memfs,
{
resource: "/",
recursive: true,
regExp: /.*/
},
(err, res) => {
expect(err).toBeFalsy();
expect(Array.isArray(res)).toBe(true);
expect(res).toHaveLength(0);
2018-02-25 18:46:17 +08:00
done();
}
);
});
it("should report an error when non-ENOENT errors happen", (done) => {
memfs.readdir = (dir, callback) => {
setTimeout(() => callback(null, ["/file"]));
};
memfs.stat = (file, callback) => {
2024-07-31 04:09:42 +08:00
const err = new Error("fake EACCES error");
err.code = "EACCES";
setTimeout(() => callback(err, null));
};
2018-02-25 18:46:17 +08:00
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).toHaveLength(1);
done();
}
);
});
it("should resolve correctly several resources", (done) => {
memfs.readdir = (dir, callback) => {
if (dir === "/a") setTimeout(() => callback(null, ["/B"]));
if (dir === "/b") setTimeout(() => callback(null, ["/A"]));
if (dir === "/a/B") setTimeout(() => callback(null, ["a"]));
if (dir === "/b/A") setTimeout(() => callback(null, ["b"]));
};
memfs.stat = (file, callback) => {
const resolvedValue = {
isDirectory: () => file !== "/a/B/a" && file !== "/b/A/b",
isFile: () => file === "/a/B/a" || file === "/b/A/b"
};
setTimeout(() => callback(null, resolvedValue));
};
memfs.realpath = undefined;
factory.resolveDependencies(
memfs,
{
resource: ["/a", "/b"],
resourceFragment: "#hash",
resourceQuery: "?query",
recursive: true,
regExp: /.*/
},
(err, res) => {
expect(res).not.toStrictEqual([]);
expect(Array.isArray(res)).toBe(true);
expect(res.map((r) => r.request)).toEqual([
2022-03-25 21:28:18 +08:00
"./B/a?query#hash",
"./A/b?query#hash"
]);
expect(res.map((r) => r.getContext())).toEqual(["/a", "/b"]);
expect(res.map((r) => r.userRequest)).toEqual(["./B/a", "./A/b"]);
done();
}
);
});
});
});