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();
});
});