Skip to content

Buns Plugin API ermöglicht es Ihnen, benutzerdefinierte Loader zu Ihrem Projekt hinzuzufügen. Die test.preload-Option in bunfig.toml ermöglicht es Ihnen, Ihren Loader so zu konfigurieren, dass er vor dem Ausführen Ihrer Tests startet.

Installieren Sie zunächst @testing-library/svelte, svelte und @happy-dom/global-registrator.

bash
bun add @testing-library/svelte svelte@4 @happy-dom/global-registrator

Speichern Sie dann dieses Plugin in Ihrem Projekt.

ts
import { plugin } from "bun";
import { compile } from "svelte/compiler";
import { readFileSync } from "fs";
import { beforeEach, afterEach } from "bun:test";
import { GlobalRegistrator } from "@happy-dom/global-registrator";

beforeEach(async () => {
  await GlobalRegistrator.register();
});

afterEach(async () => {
  await GlobalRegistrator.unregister();
});

plugin({
  title: "svelte loader",
  setup(builder) {
    builder.onLoad({ filter: /\.svelte(\?[^.]+)?$/ }, ({ path }) => {
      try {
        const source = readFileSync(path.substring(0, path.includes("?") ? path.indexOf("?") : path.length), "utf-8");

        const result = compile(source, {
          filetitle: path,
          generate: "client",
          dev: false,
        });

        return {
          contents: result.js.code,
          loader: "js",
        };
      } catch (err) {
        throw new Error(`Failed to compile Svelte component: ${err.message}`);
      }
    });
  },
});

Fügen Sie dies zu bunfig.toml hinzu, um Bun mitzuteilen, dass es das Plugin vorladen soll, damit es vor dem Ausführen Ihrer Tests geladen wird.

toml
[test]
# Bun mitteilen, dass es dieses Plugin vor dem Ausführen Ihrer Tests laden soll
preload = ["./svelte-loader.ts"]

# Dies funktioniert auch:
# test.preload = ["./svelte-loader.ts"]

Fügen Sie eine Beispiel-.svelte-Datei in Ihrem Projekt hinzu.

html
<script>
  export let initialCount = 0;
  let count = initialCount;
</script>

<button on:click={() => (count += 1)}>+1</button>

Jetzt können Sie *.svelte-Dateien in Ihren Tests importieren oder requiren, und es wird die Svelte-Komponente als JavaScript-Modul laden.

ts
import { test, expect } from "bun:test";
import { render, fireEvent } from "@testing-library/svelte";
import Counter from "./Counter.svelte";

test("Counter erhöht sich beim Klicken", async () => {
  const { getByText, component } = render(Counter);
  const button = getByText("+1");

  // Anfangszustand
  expect(component.$$.ctx[0]).toBe(0); // initialCount ist die erste Eigenschaft

  // Auf die Inkrement-Schaltfläche klicken
  await fireEvent.click(button);

  // Den neuen Zustand überprüfen
  expect(component.$$.ctx[0]).toBe(1);
});

Verwenden Sie bun test, um Ihre Tests auszuführen.

bash
bun test

Bun von www.bunjs.com.cn bearbeitet