one
Version:
One is a new React Framework that makes Vite serve both native and web.
232 lines (230 loc) • 8.13 kB
JavaScript
import { resolve } from "path";
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
function _type_of(obj) {
"@swc/helpers - typeof";
return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
}
var PROJECT_ROOT = resolve("/project");
var PUBLIC_DIR = resolve("/project/public");
var COMPONENTS_DIR = resolve("/project/src/components");
var HERO_FILE = resolve("/project/src/components/Hero.tsx");
vi.mock("node:fs", async function () {
var actual = await vi.importActual("node:fs");
return {
...actual,
existsSync: vi.fn(function (path) {
return path.includes("test-image.jpg") || path.includes("hero.png");
})
};
});
function mockConfig() {
return {
publicDir: PUBLIC_DIR,
root: PROJECT_ROOT
};
}
describe("imageDataPlugin", function () {
beforeEach(function () {
vi.resetModules();
});
afterEach(function () {
vi.clearAllMocks();
});
describe("resolveId", function () {
it("should return null for non-imagedata imports", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var result = await plugin.resolveId("./image.jpg", void 0);
expect(result).toBeNull();
});
it("should return null for imports with imagedata not as suffix", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var result = await plugin.resolveId("./image?imagedata.jpg", void 0);
expect(result).toBeNull();
});
it("should resolve public dir paths starting with /", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var result = await plugin.resolveId("/test-image.jpg?imagedata", void 0);
expect(result).toBe("\0imagedata:" + resolve(PUBLIC_DIR, "test-image.jpg"));
});
it("should resolve relative imports", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var result = await plugin.resolveId("./test-image.jpg?imagedata", HERO_FILE);
expect(result).toBe("\0imagedata:" + resolve(COMPONENTS_DIR, "test-image.jpg"));
});
it("should return null for non-existent files", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var result = await plugin.resolveId("/nonexistent.jpg?imagedata", void 0);
expect(result).toBeNull();
});
});
describe("path traversal prevention", function () {
it("should block path traversal from public dir", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var result = await plugin.resolveId("/../../../etc/passwd?imagedata", void 0);
expect(result).toBeNull();
});
it("should block path traversal from relative imports", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var result = await plugin.resolveId("../../../../etc/passwd?imagedata", HERO_FILE);
expect(result).toBeNull();
});
it("should block path traversal from root", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var result = await plugin.resolveId("../../../etc/passwd?imagedata", void 0);
expect(result).toBeNull();
});
it("should allow paths within project boundaries", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var result = await plugin.resolveId("../../src/test-image.jpg?imagedata", HERO_FILE);
expect(result).toBe("\0imagedata:" + resolve(PROJECT_ROOT, "src/test-image.jpg"));
});
});
describe("load", function () {
it("should return null for non-virtual modules", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var mockContext = {
addWatchFile: vi.fn()
};
var result = await plugin.load.call(mockContext, "./image.jpg");
expect(result).toBeNull();
});
it("should return fallback data when sharp fails", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var mockContext = {
addWatchFile: vi.fn()
};
var testFilePath = resolve(PUBLIC_DIR, "test-image.jpg");
var result = await plugin.load.call(mockContext, "\0imagedata:" + testFilePath);
expect(result).toContain("export default");
expect(result).toContain('"src":"/test-image.jpg"');
expect(result).toContain('"width":');
expect(result).toContain('"height":');
expect(mockContext.addWatchFile).toHaveBeenCalledWith(testFilePath);
});
});
describe("plugin metadata", function () {
it("should have correct name", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
expect(plugin.name).toBe("one:imagedata");
});
it("should enforce pre", async function () {
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
expect(plugin.enforce).toBe("pre");
});
});
});
describe("imageDataPlugin output format", function () {
it("should export a valid JSON object", async function () {
vi.resetModules();
var {
imageDataPlugin
} = await import("./imageDataPlugin.native.js");
var plugin = imageDataPlugin();
if (plugin.configResolved) {
;
plugin.configResolved(mockConfig());
}
var mockContext = {
addWatchFile: vi.fn()
};
var testFilePath = resolve(PUBLIC_DIR, "test-image.jpg");
var result = await plugin.load.call(mockContext, "\0imagedata:" + testFilePath);
var jsonMatch = result === null || result === void 0 ? void 0 : result.match(/export default (.+)$/);
expect(jsonMatch).toBeTruthy();
if (jsonMatch) {
var parsed = JSON.parse(jsonMatch[1]);
expect(parsed).toHaveProperty("src");
expect(parsed).toHaveProperty("width");
expect(parsed).toHaveProperty("height");
expect(parsed).toHaveProperty("blurDataURL");
expect(_type_of(parsed.src)).toBe("string");
expect(_type_of(parsed.width)).toBe("number");
expect(_type_of(parsed.height)).toBe("number");
expect(_type_of(parsed.blurDataURL)).toBe("string");
}
});
});
//# sourceMappingURL=imageDataPlugin.test.native.js.map