name: archestra-dev-e2e description: Use when writing, debugging, or running Archestra Playwright e2e tests, API/UI fixtures, WireMock-backed tests, local/CI e2e setup, or test selectors.
Archestra E2E Testing
Use this skill for files under platform/e2e-tests/ and for frontend/backend changes that require Playwright coverage.
Run commands from platform/ unless specifically instructed otherwise.
Commands
pnpm test:e2e
tilt trigger e2e-test-dependencies
tilt trigger e2e-test-dependencies starts WireMock and seeds test data to the database.
In development, e2e tests use the development database. Local data can make e2e tests fail locally.
Check WireMock health at http://localhost:9092/__admin/health.
WireMock environment variables
Use port 9092 for the Tilt e2e dependency setup:
ARCHESTRA_OPENAI_BASE_URL=http://localhost:9092/v1
ARCHESTRA_ANTHROPIC_BASE_URL=http://localhost:9092
ARCHESTRA_GEMINI_BASE_URL=http://localhost:9092
Use port 9091 for the alternate local WireMock setup:
ARCHESTRA_OPENAI_BASE_URL=http://localhost:9091/v1
ARCHESTRA_ANTHROPIC_BASE_URL=http://localhost:9091
ARCHESTRA_GEMINI_BASE_URL=http://localhost:9091
Local and CI setup
- Local e2e uses docker-compose setup through
Tiltfile.test. - CI uses a kind cluster and Helm deployment.
- CI kind config is
.github/kind.yaml. - CI Helm values are
.github/values-ci.yaml. - CI NodePort services use frontend
3000, backend9000, and metrics9050. - CI e2e checks include
drizzle-kit check, codegen, and database migrations.
Fixtures
- Use the Playwright fixtures pattern.
- Import from
./fixturesin API/UI test directories. - API fixtures include
makeApiRequest,createAgent,deleteAgent,createApiKey,deleteApiKey,createToolInvocationPolicy,deleteToolInvocationPolicy,createTrustedDataPolicy, anddeleteTrustedDataPolicy. - UI fixtures include
goToPageandmakeRandomString.
Example:
import { test } from "./fixtures";
test("API example", async ({ request, createAgent, deleteAgent }) => {
const response = await createAgent(request, "Test Agent");
const agent = await response.json();
// test logic...
await deleteAgent(request, agent.id);
});
Locator best practices
Prefer Playwright's recommended locators over raw locator() calls. In priority order:
page.getByRole()- accessible elements by ARIA role, such as buttons, links, and headings.page.getByText()- text content.page.getByLabel()- form controls by label.page.getByPlaceholder()- input elements by placeholder.page.getByTestId()- custom test IDs usingE2eTestIdconstants from@archestra/shared.
Avoid raw CSS selectors, XPath selectors, and arbitrary timeouts. Use Playwright auto-waiting instead.
// good
await page.getByRole("button", { name: /Submit/i }).click();
await page.getByLabel(/Email/i).fill("test@example.com");
await page.getByTestId(E2eTestId.CreateAgentButton).click();
// avoid
await page.locator(".submit-btn").click();
await page.locator("#email-input").fill("test@example.com");
await page.waitForTimeout(1000); // use auto-waiting instead