使用 open-wc 测试 Lit 元素时如何访问 ShadowDom

0xC*_*AF2 2 testing lit

Lit 文档将 Web Test Runner 称为测试。它导航到此示例页面

我尝试过测试MyElement,结果只有一个<p>

import { LitElement, html } from "lit";
import { customElement } from "lit/decorators.js";

@customElement("my-element")
export class MyElement extends LitElement {
  render() {
    return html`<p>Hello, World.</p>`;
  }
}

declare global {
  interface HTMLElementTagNameMap {
    "my-element": MyElement;
  }
}
Run Code Online (Sandbox Code Playgroud)

通过 open-wc 测试时,该元素shadowDom没有<p>in descendant

import { expect, fixture, html } from "@open-wc/testing";
import { MyElement } from "../src/MyElement";

it("get shadowDom", async () => {
  const el: MyElement = await fixture(html`<my-element></my-element>`);
  expect(el).shadowDom.to.be.not.null; // passed
  expect(el).shadowDom.to.have.descendant("p"); // failed
});
Run Code Online (Sandbox Code Playgroud)

使用 open-wc 测试 Lit 元素是否需要更多设置?web-test-runner.config.js 是:

import { esbuildPlugin } from '@web/dev-server-esbuild';

export default {
  files: ['test/*.test.ts'],
  plugins: [esbuildPlugin({ ts: true })],
};
Run Code Online (Sandbox Code Playgroud)

Chr*_*ian 5

尝试使用shadowRoot代替shadowDom:

it("get shadowDom", async () => {
    const el = await fixture(
      html` <my-element></my-element>`
    );
    const descendant = el.shadowRoot!.querySelector("p")!;
    expect(descendant).to.be.not.null;
});
Run Code Online (Sandbox Code Playgroud)