mirror of
https://github.com/microsoft/playwright.git
synced 2025-06-26 21:40:17 +00:00

Closes https://github.com/microsoft/playwright/issues/32853 Vite turns the shorthand fragment notation `<></>` into `import { Fragment } from "react"; <Fragment></Fragment>`. On the Node.js side of things, this `react` import resolves to our mock version of React, which currently mocks `Fragment` as `{}`. Currently, we pass that straight to `React.createElement`, which throws an error. The fix is to make our `Fragment` mock detectable with a tag, and when we render it replace it with the real `__pwReact.Fragment`.
54 lines
2.3 KiB
TypeScript
54 lines
2.3 KiB
TypeScript
import { test, expect } from '@playwright/experimental-ct-react';
|
|
import Button from '@/components/Button';
|
|
import EmptyFragment from '@/components/EmptyFragment';
|
|
import { ComponentAsProp } from '@/components/ComponentAsProp';
|
|
import DefaultChildren from '@/components/DefaultChildren';
|
|
|
|
test('render props', async ({ mount }) => {
|
|
const component = await mount(<Button title="Submit" />);
|
|
await expect(component).toContainText('Submit');
|
|
});
|
|
|
|
test('render component as props', async ({ mount }) => {
|
|
const component = await mount(<ComponentAsProp component={<Button title="Submit" />} />);
|
|
await expect(component.getByRole('button', { name: 'submit' })).toBeVisible();
|
|
});
|
|
|
|
test('render jsx array as props', async ({ mount }) => {
|
|
const component = await mount(<ComponentAsProp component={[<h4>{[4]}</h4>,[[<p>[2,3]</p>]]]} />);
|
|
await expect(component.getByRole('heading', { level: 4 })).toHaveText('4');
|
|
await expect(component.getByRole('paragraph')).toHaveText('[2,3]');
|
|
});
|
|
|
|
test('render attributes', async ({ mount }) => {
|
|
const component = await mount(<Button className="primary" title="Submit" />);
|
|
await expect(component).toHaveClass('primary');
|
|
});
|
|
|
|
test('render an empty component', async ({ mount, page }) => {
|
|
const component = await mount(<EmptyFragment />);
|
|
expect(await page.evaluate(() => 'props' in window && window.props)).toEqual({});
|
|
expect(await component.allTextContents()).toEqual(['']);
|
|
expect(await component.textContent()).toBe('');
|
|
await expect(component).toHaveText('');
|
|
});
|
|
|
|
function MyInlineComponent({ value }: { value: string }) {
|
|
return <>Hello {value}</>;
|
|
}
|
|
|
|
test('render inline component with an error', async ({ mount }) => {
|
|
await expect(mount(<MyInlineComponent value="Max" />)).rejects.toThrow('Component "MyInlineComponent" cannot be mounted.');
|
|
});
|
|
|
|
test('render inline component with an error if its nested', async ({ mount }) => {
|
|
await expect(mount(<DefaultChildren>
|
|
<MyInlineComponent value="Max" />
|
|
</DefaultChildren>)).rejects.toThrow('Component "MyInlineComponent" cannot be mounted.');
|
|
});
|
|
|
|
test('render Fragment shorthand notation', { annotation: { type: 'issue', description: 'https://github.com/microsoft/playwright/issues/32853' } }, async ({ mount }) => {
|
|
const component = await mount(<>Learn React</>);
|
|
await expect(component).toContainText('Learn React');
|
|
});
|