```ts filename="MyComponent.stories.ts" renderer="angular" language="ts" import type { Meta, StoryObj } from '@storybook/angular'; import { userEvent, within } from '@storybook/test'; import { MyComponent } from './MyComponent.component'; const meta: Meta = { component: MyComponent, }; export default meta; type Story = StoryObj; /* * See https://storybook.js.org/docs/writing-stories/play-function#working-with-the-canvas * to learn more about using the canvasElement to query the DOM */ export const ExampleWithRole: Story = { play: async ({ canvasElement }) => { const canvas = within(canvasElement); // See https://storybook.js.org/docs/essentials/actions#automatically-matching-args to learn how to setup logging in the Actions panel await userEvent.click(canvas.getByRole('button', { name: / button label/i })); }, }; ``` ```js filename="MyComponent.stories.js|jsx" renderer="common" language="js" import { userEvent, within } from '@storybook/test'; import { MyComponent } from './MyComponent'; export default { component: MyComponent, }; /* See https://storybook.js.org/docs/writing-stories/play-function#working-with-the-canvas * to learn more about using the canvasElement to query the DOM */ export const ExampleWithRole = { play: async ({ canvasElement }) => { const canvas = within(canvasElement); // See https://storybook.js.org/docs/essentials/actions#automatically-matching-args to learn how to setup logging in the Actions panel await userEvent.click(canvas.getByRole('button', { name: / button label/i })); }, }; ``` ```ts filename="MyComponent.stories.ts|tsx" renderer="common" language="ts-4-9" // Replace your-framework with the name of your framework import type { Meta, StoryObj } from '@storybook/your-framework'; import { userEvent, within } from '@storybook/test'; import { MyComponent } from './MyComponent'; const meta = { component: MyComponent, } satisfies Meta; export default meta; type Story = StoryObj; /* See https://storybook.js.org/docs/writing-stories/play-function#working-with-the-canvas * to learn more about using the canvasElement to query the DOM */ export const ExampleWithRole: Story = { play: async ({ canvasElement }) => { const canvas = within(canvasElement); // See https://storybook.js.org/docs/essentials/actions#automatically-matching-args to learn how to setup logging in the Actions panel await userEvent.click(canvas.getByRole('button', { name: / button label/i })); }, }; ``` ```ts filename="MyComponent.stories.ts|tsx" renderer="common" language="ts" // Replace your-framework with the name of your framework import type { Meta, StoryObj } from '@storybook/your-framework'; import { userEvent, within } from '@storybook/test'; import { MyComponent } from './MyComponent'; const meta: Meta = { component: MyComponent, }; export default meta; type Story = StoryObj; /* See https://storybook.js.org/docs/writing-stories/play-function#working-with-the-canvas * to learn more about using the canvasElement to query the DOM */ export const ExampleWithRole: Story = { play: async ({ canvasElement }) => { const canvas = within(canvasElement); // See https://storybook.js.org/docs/essentials/actions#automatically-matching-args to learn how to setup logging in the Actions panel await userEvent.click(canvas.getByRole('button', { name: / button label/i })); }, }; ``` ```js filename="MyComponent.stories.js" renderer="web-components" language="js" import { userEvent, within } from '@storybook/test'; export default { component: 'demo-my-component', }; /* See https://storybook.js.org/docs/writing-stories/play-function#working-with-the-canvas * to learn more about using the canvasElement to query the DOM */ export const ExampleWithRole = { play: async ({ canvasElement }) => { const canvas = within(canvasElement); // See https://storybook.js.org/docs/essentials/actions#automatically-matching-args to learn how to setup logging in the Actions panel await userEvent.click(canvas.getByRole('button', { name: / button label/i })); }, }; ``` ```ts filename="MyComponent.stories.ts" renderer="web-components" language="ts" import type { Meta, StoryObj } from '@storybook/web-components'; import { userEvent, within } from '@storybook/test'; const meta: Meta = { component: 'demo-my-component', }; export default meta; type Story = StoryObj; /* See https://storybook.js.org/docs/writing-stories/play-function#working-with-the-canvas * to learn more about using the canvasElement to query the DOM */ export const ExampleWithRole: Story = { play: async ({ canvasElement }) => { const canvas = within(canvasElement); // See https://storybook.js.org/docs/essentials/actions#automatically-matching-args to learn how to setup logging in the Actions panel await userEvent.click(canvas.getByRole('button', { name: / button label/i })); }, }; ```