import { render } from '@solidjs/testing-library'; import { describe, expect, it } from 'vitest'; import { House, LucideProvider } from '../src/lucide-solid'; describe('Using LucideProvider', () => { it('should render the icon with LucideProvider', () => { const { container } = render(() => ( )); expect(container.firstChild).toMatchSnapshot(); }); it('should render the icon with default props when no provider is used', () => { const { container } = render(() => ); const IconComponent = container.firstElementChild; expect(IconComponent).toHaveAttribute('width', '24'); expect(IconComponent).toHaveAttribute('height', '24'); expect(IconComponent).toHaveAttribute('stroke', 'currentColor'); expect(IconComponent).toHaveAttribute('stroke-width', '2'); }); it('should render the icon with LucideProvider and custom strokeWidth', () => { const { container } = render(() => ( )); const IconComponent = container.firstElementChild; expect(IconComponent).toHaveAttribute('width', '48'); expect(IconComponent).toHaveAttribute('height', '48'); expect(IconComponent).toHaveAttribute('stroke', 'red'); expect(IconComponent).toHaveAttribute('stroke-width', '4'); }); it('should render the icon with LucideProvider and custom absoluteStrokeWidth', () => { const { container } = render(() => ( )); const IconComponent = container.firstElementChild; expect(IconComponent).toHaveAttribute('stroke-width', '1'); }); it("should override the provider's global props when passing props to the icon", () => { const { container } = render(() => ( )); const IconComponent = container.firstElementChild; expect(IconComponent).toHaveAttribute('width', '24'); expect(IconComponent).toHaveAttribute('height', '24'); expect(IconComponent).toHaveAttribute('stroke', 'blue'); expect(IconComponent).toHaveAttribute('stroke-width', '2'); }); it('should merge className from provider and icon', () => { const { container } = render(() => ( )); const IconComponent = container.firstElementChild; expect(IconComponent).toHaveAttribute( 'class', 'lucide lucide-icon provider-class lucide-house icon-class', ); }); });