mirror of
https://github.com/storybookjs/storybook.git
synced 2025-03-28 05:10:17 +08:00
50 lines
1.3 KiB
Plaintext
50 lines
1.3 KiB
Plaintext
```js
|
|
// LoginForm.stories.js
|
|
|
|
import { within, userEvent } from '@storybook/testing-library';
|
|
|
|
import { expect } from '@storybook/jest';
|
|
|
|
import LoginForm from './LoginForm.svelte';
|
|
|
|
export default {
|
|
/* 👇 The title prop is optional.
|
|
* See https://storybook.js.org/docs/svelte/configure/overview#configure-story-loading
|
|
* to learn how to generate automatic titles
|
|
*/
|
|
title: 'Form',
|
|
component: LoginForm,
|
|
};
|
|
|
|
const Template = (args) => ({
|
|
Component: LoginForm,
|
|
props: args,
|
|
});
|
|
|
|
export const EmptyForm = Template.bind({});
|
|
|
|
export const FilledForm = Template.bind({});
|
|
FilledForm.play = async ({ canvasElement }) => {
|
|
// Starts querying the component from its root element
|
|
const canvas = within(canvasElement);
|
|
|
|
// 👇 Simulate interactions with the component
|
|
await userEvent.type(canvas.getByTestId('email'), 'email@provider.com', {
|
|
delay: 100,
|
|
});
|
|
|
|
await userEvent.type(canvas.getByTestId('password'), 'a-random-password', {
|
|
delay: 100,
|
|
});
|
|
|
|
// See https://storybook.js.org/docs/svelte/essentials/actions#automatically-matching-args to learn how to setup logging in the Actions panel
|
|
await userEvent.click(canvas.getByRole('button'));
|
|
|
|
// 👇 Assert DOM structure
|
|
await expect(
|
|
canvas.getByText(
|
|
'Everything is perfect. Your account is ready and we should probably get you started!'
|
|
)
|
|
).toBeInTheDocument();
|
|
};
|
|
``` |