import {assert, fixture, html} from "@open-wc/testing"; import "@shoelace-style/shoelace/dist/components/format-bytes/format-bytes.js"; import {Et2FileItem} from "../Et2FileItem"; // @ts-ignore window.egw = { ajaxUrl: () => "", decodePath: (_path : string) => _path, image: () => "", preference: i => "", tooltipUnbind: () => {}, webserverUrl: "" }; describe("Et2FileItem", () => { // Make sure it works it('is defined', async() => { const el = await fixture(html` `); assert.instanceOf(el, Et2FileItem); }); // Test case: Component renders with default values it("should render with default properties", async() => { const el = await fixture(html` `); assert.ok(el.shadowRoot); assert.strictEqual(el.variant, "default"); assert.strictEqual(el.loading, false); assert.strictEqual(el.closable, false); assert.strictEqual(el.hidden, false); }); // Test case: Test different variants of the file item it("should apply correct class for 'primary' variant", async() => { const el = await fixture(html` `); const classList = el.shadowRoot?.querySelector(".file-item")?.classList; assert.ok(classList?.contains("file-item--primary")); }); // Test case: Check progress bar visibility when loading it("should show progress bar when loading is true", async() => { const el = await fixture(html` `); const progressBar = el.shadowRoot?.querySelector(".file-item__progress-bar"); assert.ok(progressBar); }); // Test case: Check if progress value is properly set it("should set progress value correctly when loading", async() => { const el = await fixture(html` `); const progressBar = el.shadowRoot?.querySelector("sl-progress-bar"); assert.strictEqual(progressBar?.getAttribute("value"), "50"); }); // Test case: Check if closable functionality works it("should hide the item when close button is clicked", async() => { const el = await fixture(html` `); const closeButton = el.shadowRoot?.querySelector(".file-item__close-button"); closeButton?.dispatchEvent(new MouseEvent("click")); assert.strictEqual(el.hidden, true); }); // Test case: Check slot content rendering (for example, image) it("should render the image slot content", async() => { const el = await fixture(html` Custom Image Slot `); const imageSlot = el.shadowRoot?.querySelector("slot[name='image']"); assert.ok(imageSlot); }); // Test case: Check size display when size is set it("should display file size when size is provided", async() => { const el = await fixture(html` `); const sizeElement = el.shadowRoot?.querySelector(".file-item__label__size"); assert.ok(sizeElement); assert.ok(sizeElement?.shadowRoot?.textContent?.includes("1 kB")); }); // Test case: Check if the component applies "hidden" class & attribute when hidden property is true it("should be hidden when hidden is true", async() => { const el = await fixture(html` `); const classList = el.shadowRoot?.querySelector(".file-item")?.classList; assert.ok(classList?.contains("file-item--hidden")); assert.ok(el.hasAttribute("hidden")); }); });