پرش به محتوای اصلی

لیت

لیت یک کتابخانه ساده برای ساخت کامپوننت‌های وب سریع و سبک است. تست کامپوننت‌های وب لیت با WebdriverIO به لطف انتخابگرهای shadow DOM WebdriverIO بسیار آسان است. با یک دستور واحد می‌توانید عناصر تودرتو در shadow roots را جستجو کنید.

راه‌اندازی

برای راه‌اندازی WebdriverIO در پروژه لیت خود، دستورالعمل‌های موجود در مستندات تست کامپوننت ما را دنبال کنید. برای لیت نیازی به پیش‌تنظیمات ندارید زیرا کامپوننت‌های وب لیت نیازی به اجرا از طریق کامپایلر ندارند، آنها بهبودهای خالص کامپوننت‌های وب هستند.

پس از راه‌اندازی، می‌توانید تست‌ها را با اجرای دستور زیر شروع کنید:

npx wdio run ./wdio.conf.js

نوشتن تست‌ها

با فرض اینکه شما کامپوننت لیت زیر را دارید:

./components/Component.ts
import { LitElement, css, html } from 'lit'
import { customElement, property } from 'lit/decorators.js'

@customElement('simple-greeting')
export class SimpleGreeting extends LitElement {
@property()
name?: string = 'World'

// Render the UI as a function of component state
render() {
return html`<p>Hello, ${this.name}!</p>`
}
}

برای تست کامپوننت، باید آن را قبل از شروع تست در صفحه تست رندر کنید و اطمینان حاصل کنید که بعداً پاکسازی می‌شود:

lit.test.js
import expect from 'expect'
import { waitFor } from '@testing-library/dom'

// import Lit component
import './components/Component.ts'

describe('Lit Component testing', () => {
let elem: HTMLElement

beforeEach(() => {
elem = document.createElement('simple-greeting')
})

it('should render component', async () => {
elem.setAttribute('name', 'WebdriverIO')
document.body.appendChild(elem)

await waitFor(() => {
expect(elem.shadowRoot.textContent).toBe('Hello, WebdriverIO!')
})
})

afterEach(() => {
elem.remove()
})
})

شما می‌توانید یک نمونه کامل از مجموعه تست کامپوننت WebdriverIO برای لیت را در مخزن نمونه ما بیابید.

Welcome! How can I help?

WebdriverIO AI Copilot