import { render, screen, fireEvent } from '@testing-library/react'; import { describe, it, expect, vi } from 'vitest'; import { ContextMenu, ContextMenuTrigger, ContextMenuContent, ContextMenuItem, } from './context-menu'; import React from 'react'; // Mocking Portal vi.mock('@radix-ui/react-context-menu', async () => { const actual = await vi.importActual('@radix-ui/react-context-menu'); return { ...actual, Portal: ({ children }: { children: React.ReactNode }) => (
{children}
), }; }); describe('ContextMenu', () => { it('renders correctly', () => { render( Right click here Edit Delete ); expect(screen.getByText('Right click here')).toBeInTheDocument(); }); it('opens content on right click', () => { render( Trigger Option 1 ); const trigger = screen.getByText('Trigger'); fireEvent.contextMenu(trigger); expect(screen.getByText('Option 1')).toBeInTheDocument(); }); it('has correct data-slot attributes', () => { const { container } = render( Trigger ); expect(container.querySelector('[data-slot="context-menu-trigger"]')).toBeInTheDocument(); }); });