import { render, screen, fireEvent } from '@testing-library/react'; import { describe, it, expect, vi } from 'vitest'; import { Drawer, DrawerTrigger, DrawerContent, DrawerHeader, DrawerTitle, DrawerDescription, DrawerFooter, } from './drawer'; import React from 'react'; // Mocking Vaul Portal vi.mock('vaul', async () => { const actual = await vi.importActual('vaul'); return { ...actual, Drawer: { ...(actual.Drawer as object), Portal: ({ children }: { children: React.ReactNode }) => (
{children}
), }, }; }); describe('Drawer', () => { it('renders correctly', () => { render( Open Drawer Title Description Footer ); expect(screen.getByText('Open Drawer')).toBeInTheDocument(); }); it('shows content when open is true', () => { render( Open Drawer Content ); expect(screen.getByText('Drawer Content')).toBeInTheDocument(); }); it('has correct data-slot attributes', () => { const { container } = render( Open ); expect(container.querySelector('[data-slot="drawer-trigger"]')).toBeInTheDocument(); }); });