12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- import { describe, it, expect, afterEach, assertType, expectTypeOf } from 'vitest';
- import { render, cleanup } from '@testing-library/react'
- import { IconAccessible, IconAccessibleFilled, createReactComponent } from "./src/tabler-icons-react"
- import type { IconNode } from './src/tabler-icons-react';
- import { ReactNode } from 'react';
- describe("React Icon component", () => {
- afterEach(() => {
- cleanup();
- });
- it("should render icon component", () => {
- const { container } = render(<IconAccessible/>)
- expect(container.getElementsByTagName("svg").length).toBeGreaterThan(0)
- })
- it("should update svg attributes when there are props passed to the component", () => {
- const { container } = render(<IconAccessible 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")
- expect(svg.getAttribute("fill")).toBe("none")
- })
- it("should update svg attributes when there are props passed to the filled version of component", () => {
- const { container } = render(<IconAccessibleFilled 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 apply all classNames to the element', () => {
- const testClass = 'test-class';
- const { container } = render(
- <IconAccessible className={testClass} />,
- );
- expect(container.firstChild).toHaveClass(testClass);
- expect(container.firstChild).toHaveClass('tabler-icon');
- expect(container.firstChild).toHaveClass('tabler-icon-accessible');
- });
- it('should add a style attribute to the element', () => {
- const { container } = render(<IconAccessible style={{ color: "red" }}/>)
- const svg = container.getElementsByTagName("svg")[0]
- expect(svg).toHaveStyle('color: rgb(255, 0, 0)')
- })
- it('should have proper type', () => {
- expectTypeOf(IconAccessible).toBeFunction();
- expectTypeOf(IconAccessible).toEqualTypeOf(createReactComponent('outline', 'accessible', 'Accessible', []));
- });
- it("should match snapshot", () => {
- const { container } = render(<IconAccessible/>)
- expect(container.innerHTML).toMatchInlineSnapshot(`
- <svg xmlns="http://www.w3.org/2000/svg"
- width="24"
- height="24"
- viewbox="0 0 24 24"
- fill="none"
- stroke="currentColor"
- stroke-width="2"
- stroke-linecap="round"
- stroke-linejoin="round"
- class="tabler-icon tabler-icon-accessible "
- >
- <path d="M12 12m-9 0a9 9 0 1 0 18 0a9 9 0 1 0 -18 0">
- </path>
- <path d="M10 16.5l2 -3l2 3m-2 -3v-2l3 -1m-6 0l3 1">
- </path>
- <circle cx="12"
- cy="7.5"
- r=".5"
- fill="currentColor"
- >
- </circle>
- </svg>
- `)
- })
- })
|