tiny-vue_version0/examples/sites/demos/pc/app/file-upload/upload-events.spec.ts

32 lines
1.2 KiB
TypeScript

import { test, expect } from '@playwright/test'
test('事件', async ({ page }) => {
page.on('pageerror', (exception) => expect(exception).toBeNull())
await page.goto('file-upload#upload-events')
const upload = page.getByRole('button', { name: '点击上传' })
const lists = page.locator('.tiny-upload-list__item')
const [fileChooser] = await Promise.all([page.waitForEvent('filechooser'), upload.click()])
const modals = page.locator('.tiny-modal')
const delButton = page
.getByRole('listitem')
.filter({ hasText: 'test1按 delete 键可删除' })
.getByTitle('删除文件')
.locator('svg')
const path = require('node:path')
const currentPath = path.resolve(__dirname, '测试.jpg')
await fileChooser.setFiles(currentPath)
await page.getByText('文件上传失败回调').isVisible()
await expect(page.getByText('触发上传文件改变回调事件')).toHaveCount(2)
await page.waitForTimeout(100)
await lists.nth(0).hover()
await delButton.click()
await page.getByText('触发删除文件回调事件').isVisible()
await fileChooser.setFiles([currentPath, currentPath, currentPath, currentPath])
await page.getByText('触发文件超出个数限制回调事件').isVisible()
})