import { describe, it, expect, vi, afterEach } from 'vitest'; import { render, fireEvent, cleanup } from "@testing-library/vue" import { IconAccessible, IconAccessibleFilled } from "./src/tabler-icons-vue.ts" describe("Vue Icon component", () => { afterEach(() => cleanup()) it("should render icon component", () => { const { container } = render(IconAccessible) expect(container.getElementsByTagName("svg").length).toBeGreaterThan(0); }) it('should add a class to the element', () => { const { container } = render(IconAccessible, { props: { class: 'test-class', }, }) const svg = container.getElementsByTagName("svg")[0] expect(svg).toHaveClass('test-class') expect(svg).toHaveClass('tabler-icon') expect(svg).toHaveClass('tabler-icon-accessible') }) it('should add a style attribute to the element', () => { const { container } = render(IconAccessible, { props: { style: 'color: red', }, }) const svg = container.getElementsByTagName("svg")[0] expect(svg).toHaveStyle('color: rgb(255, 0, 0)') }) it("should update svg attributes when there are props passed to the component", () => { const { container } = render(IconAccessible, { props: { size: 48, color: "red", "stroke": 4, }, }) const svg = container.getElementsByTagName("svg")[0] expect(svg.getAttribute("width")).toBe("48") expect(svg.getAttribute("stroke")).toBe("red") expect(svg.getAttribute("stroke-width")).toBe("4") }) it("should update svg attributes when there are props passed to the filled version of component", () => { const { container } = render(IconAccessibleFilled, { props: { size: 48, color: "red" }, }) const svg = container.getElementsByTagName("svg")[0] expect(svg.getAttribute("width")).toBe("48") expect(svg.getAttribute("fill")).toBe("red") expect(svg.getAttribute("stroke")).toBe("none") expect(svg.getAttribute("stroke-width")).toBe(null) }) it('should call the onClick event', async () => { const onClick = vi.fn() const { container } = render(IconAccessible, { attrs: { onClick, } }) const svg = container.getElementsByTagName("svg")[0] await fireEvent.click(svg) expect(onClick).toHaveBeenCalled() }) it('should pass children to the icon slot', () => { const testText = 'Hello World' const template = { name: 'Stub', template: `${testText}` } const { getByText, container } = render(IconAccessible, { slots: { default: template } }) const textElement = getByText(testText) expect(textElement).toBeInTheDocument() expect(container.innerHTML).toMatchInlineSnapshot(`"Hello World"`); }); it("should match snapshot", () => { const { container } = render(IconAccessible); expect(container.innerHTML).toMatchInlineSnapshot(`""`) }) })