$ /nix/store/vzx1mi9c0xfadmsm9dhd83d005cb1qs9-coreutils-9.8/bin/timeout --kill-after=15s 7200s /nix/store/86n4l5yri6hys3zk2mwy2azcv9prqb8j-nix-2.31.4/bin/nix --extra-experimental-features nix-command --extra-experimental-features flakes --log-format internal-json build --no-link git+https://codeberg.org/mtlynch/little-moments?ref=email-auth&rev=f8e7560dd7f874e9c4159f08a782c33d691de284#packages.x86_64-linux.e2e-tests --print-build-logs  Building little-moments-e2e [little-moments-e2e] Phase: unpackPhase [little-moments-e2e] unpacking source archive /nix/store/sfikzia855qp9j1a9j3bkmqfwgyfgwjk-source [little-moments-e2e] source root is source [little-moments-e2e] Phase: patchPhase [little-moments-e2e] Executing npmConfigHook [little-moments-e2e] Configuring npm [little-moments-e2e] Validating consistency between /build/source/package-lock.json and /nix/store/s010d1fi38rq6sq05s7jvvqri9dwn7ci-little-moments-e2e-0.0.1-npm-deps/package-lock.json [little-moments-e2e] Setting npm_config_cache to /nix/store/s010d1fi38rq6sq05s7jvvqri9dwn7ci-little-moments-e2e-0.0.1-npm-deps [little-moments-e2e] Installing dependencies [little-moments-e2e] npm warn Unknown env config "nodedir". This will stop working in the next major version of npm. [little-moments-e2e] npm warn Unknown env config "platform". This will stop working in the next major version of npm. [little-moments-e2e] npm warn Unknown env config "arch". This will stop working in the next major version of npm. [little-moments-e2e]  [little-moments-e2e] added 100 packages, and audited 101 packages in 649ms [little-moments-e2e]  [little-moments-e2e] 25 packages are looking for funding [little-moments-e2e]  run `npm fund` for details [little-moments-e2e]  [little-moments-e2e] found 0 vulnerabilities [little-moments-e2e] patching script interpreter paths in node_modules [little-moments-e2e] node_modules/prettier/bin/prettier.cjs: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" [little-moments-e2e] node_modules/which/bin/node-which: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" [little-moments-e2e] node_modules/js-yaml/bin/js-yaml.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" [little-moments-e2e] node_modules/@playwright/test/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" [little-moments-e2e] node_modules/eslint/bin/eslint.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" [little-moments-e2e] node_modules/playwright/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" [little-moments-e2e] node_modules/playwright-core/lib/utilsBundleImpl/xdg-open: interpreter directive changed from "#!/bin/sh" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/sh" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_msedge_beta_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_chrome_beta_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_msedge_beta_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_chrome_beta_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_chrome_stable_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_msedge_dev_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_chrome_stable_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_msedge_stable_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_msedge_stable_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/bin/reinstall_msedge_dev_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" [little-moments-e2e] node_modules/playwright-core/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" [little-moments-e2e] node_modules/ulid/bin/cli.js: interpreter directive changed from "#! /usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" [little-moments-e2e] node_modules/acorn/bin/acorn: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" [little-moments-e2e] npm warn Unknown env config "nodedir". This will stop working in the next major version of npm. [little-moments-e2e] npm warn Unknown env config "platform". This will stop working in the next major version of npm. [little-moments-e2e] npm warn Unknown env config "arch". This will stop working in the next major version of npm. [little-moments-e2e] rebuilt dependencies successfully [little-moments-e2e] patching script interpreter paths in node_modules [little-moments-e2e] Finished npmConfigHook [little-moments-e2e] Phase: updateAutotoolsGnuConfigScriptsPhase [little-moments-e2e] Phase: configurePhase [little-moments-e2e] no configure script, doing nothing [little-moments-e2e] Phase: buildPhase [little-moments-e2e] no Makefile or custom buildPhase, doing nothing [little-moments-e2e] Phase: checkPhase [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied d0b19b5f-0fde-4e5c-acc1-bd3e66583811-full.avif [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied d0b19b5f-0fde-4e5c-acc1-bd3e66583811-250px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied d0b19b5f-0fde-4e5c-acc1-bd3e66583811-150px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 044fb4b0-604c-44dc-b57c-3e8236a9f3ed-full.mp4 [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 044fb4b0-604c-44dc-b57c-3e8236a9f3ed-thumb-250px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 044fb4b0-604c-44dc-b57c-3e8236a9f3ed-thumb-150px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied c9ebbcb4-07bc-4d36-bf8f-3dad37efa229-full.mp4 [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied c9ebbcb4-07bc-4d36-bf8f-3dad37efa229-thumb-250px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied c9ebbcb4-07bc-4d36-bf8f-3dad37efa229-thumb-150px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 689aa777-bcc2-4b05-b4ee-d4daf5cb387c-full.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 689aa777-bcc2-4b05-b4ee-d4daf5cb387c-850px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 689aa777-bcc2-4b05-b4ee-d4daf5cb387c-250px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 689aa777-bcc2-4b05-b4ee-d4daf5cb387c-150px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied fb2d0669-37d2-43f1-b013-c66d6a7c69f2-full.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied fb2d0669-37d2-43f1-b013-c66d6a7c69f2-850px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied fb2d0669-37d2-43f1-b013-c66d6a7c69f2-250px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied fb2d0669-37d2-43f1-b013-c66d6a7c69f2-150px.jpg [little-moments-e2e] 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/store/sqlite/sqlite.go:18: reading DB from /build/source/test-imported-media/test-store.db [little-moments-e2e] 2026/05/30 20:21:26 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:140: wrote /build/source/test-imported-media/test-store.db [little-moments-e2e] npm warn Unknown env config "nodedir". This will stop working in the next major version of npm. [little-moments-e2e] npm warn Unknown env config "platform". This will stop working in the next major version of npm. [little-moments-e2e] npm warn Unknown env config "arch". This will stop working in the next major version of npm. [little-moments-e2e]  [little-moments-e2e] Running 15 tests using 8 workers [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] ·TTTTTTTTSkipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. [little-moments-e2e] TTTTTT [little-moments-e2e]  [little-moments-e2e]  1) [chromium] › e2e/auth.spec.ts:13:7 › Authentication › logs in and shows the browse page ─────── [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded. [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:42659/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:42659/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/auth.spec.ts:14:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/auth-Authentication-logs-in-and-shows-the-browse-page-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/auth-Authentication-logs-in-and-shows-the-browse-page-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/auth-Authentication-logs-in-and-shows-the-browse-page-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/auth-Authentication-logs-in-and-shows-the-browse-page-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  2) [chromium] › e2e/auth.spec.ts:20:7 › Authentication › redirects to stored next path after login [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded. [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm\?token=[^&]+$/ [little-moments-e2e]  Received string: "http://127.0.0.1:46877/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:46877/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  27 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  28 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 29 | await expect(page).toHaveURL(/\/login\/confirm\?token=[^&]+$/); [little-moments-e2e]  | ^ [little-moments-e2e]  30 | [little-moments-e2e]  31 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  32 | [little-moments-e2e]  at /build/source/e2e/auth.spec.ts:29:24 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/auth-Authentication-redire-2d7b2-tored-next-path-after-login-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/auth-Authentication-redire-2d7b2-tored-next-path-after-login-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/auth-Authentication-redire-2d7b2-tored-next-path-after-login-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/auth-Authentication-redire-2d7b2-tored-next-path-after-login-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  3) [chromium] › e2e/auth.spec.ts:39:7 › Authentication › logs out and redirects to the login page [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded. [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:37357/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:37357/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/auth.spec.ts:40:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/auth-Authentication-logs-out-and-redirects-to-the-login-page-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/auth-Authentication-logs-out-and-redirects-to-the-login-page-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/auth-Authentication-logs-out-and-redirects-to-the-login-page-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/auth-Authentication-logs-out-and-redirects-to-the-login-page-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  4) [chromium] › e2e/auth.spec.ts:47:7 › Authentication › cannot access protected routes after logging out [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded. [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:38551/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:38551/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/auth.spec.ts:48:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/auth-Authentication-cannot-a27fd-ed-routes-after-logging-out-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/auth-Authentication-cannot-a27fd-ed-routes-after-logging-out-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/auth-Authentication-cannot-a27fd-ed-routes-after-logging-out-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/auth-Authentication-cannot-a27fd-ed-routes-after-logging-out-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  5) [chromium] › e2e/browse.spec.ts:68:7 › Browse media › shows the imported media entries on the browse page [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  62 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  63 | [little-moments-e2e]  > 64 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  65 | await logIn(page); [little-moments-e2e]  66 | }); [little-moments-e2e]  67 | [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:64:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:41785/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:41785/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:65:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-shows--02a6e--entries-on-the-browse-page-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/browse-Browse-media-shows--02a6e--entries-on-the-browse-page-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-shows--02a6e--entries-on-the-browse-page-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/browse-Browse-media-shows--02a6e--entries-on-the-browse-page-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  6) [chromium] › e2e/browse.spec.ts:81:7 › Browse media › shows media thumbnails from newest to oldest [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  62 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  63 | [little-moments-e2e]  > 64 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  65 | await logIn(page); [little-moments-e2e]  66 | }); [little-moments-e2e]  67 | [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:64:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:40281/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:40281/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:65:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-shows--19f8f-nails-from-newest-to-oldest-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/browse-Browse-media-shows--19f8f-nails-from-newest-to-oldest-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-shows--19f8f-nails-from-newest-to-oldest-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/browse-Browse-media-shows--19f8f-nails-from-newest-to-oldest-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  7) [chromium] › e2e/browse.spec.ts:92:7 › Browse media › shows a video indicator on video thumbnails only [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  62 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  63 | [little-moments-e2e]  > 64 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  65 | await logIn(page); [little-moments-e2e]  66 | }); [little-moments-e2e]  67 | [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:64:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:33435/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:33435/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:65:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-shows--c7537-or-on-video-thumbnails-only-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/browse-Browse-media-shows--c7537-or-on-video-thumbnails-only-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-shows--c7537-or-on-video-thumbnails-only-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/browse-Browse-media-shows--c7537-or-on-video-thumbnails-only-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  8) [chromium] › e2e/browse.spec.ts:113:7 › Browse media › opens the first entry from the browse page and shows its details [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  62 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  63 | [little-moments-e2e]  > 64 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  65 | await logIn(page); [little-moments-e2e]  66 | }); [little-moments-e2e]  67 | [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:64:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:42753/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:42753/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:65:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-opens--542e7--page-and-shows-its-details-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/browse-Browse-media-opens--542e7--page-and-shows-its-details-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-opens--542e7--page-and-shows-its-details-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/browse-Browse-media-opens--542e7--page-and-shows-its-details-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  9) [chromium] › e2e/browse.spec.ts:135:7 › Browse media › moves through adjacent entries with Previous and Next links [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  62 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  63 | [little-moments-e2e]  > 64 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  65 | await logIn(page); [little-moments-e2e]  66 | }); [little-moments-e2e]  67 | [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:64:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:40603/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:40603/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:65:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-moves--c86ee-ith-Previous-and-Next-links-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/browse-Browse-media-moves--c86ee-ith-Previous-and-Next-links-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-moves--c86ee-ith-Previous-and-Next-links-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/browse-Browse-media-moves--c86ee-ith-Previous-and-Next-links-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  10) [chromium] › e2e/browse.spec.ts:166:7 › Browse media › moves through adjacent entries with left and right arrow keys [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  62 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  63 | [little-moments-e2e]  > 64 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  65 | await logIn(page); [little-moments-e2e]  66 | }); [little-moments-e2e]  67 | [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:64:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:43329/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:43329/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:65:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-moves--d7942-h-left-and-right-arrow-keys-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/browse-Browse-media-moves--d7942-h-left-and-right-arrow-keys-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-moves--d7942-h-left-and-right-arrow-keys-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/browse-Browse-media-moves--d7942-h-left-and-right-arrow-keys-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  11) [chromium] › e2e/browse.spec.ts:187:7 › Browse media › moves through adjacent entries with swipe gestures on mobile [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  62 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  63 | [little-moments-e2e]  > 64 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  65 | await logIn(page); [little-moments-e2e]  66 | }); [little-moments-e2e]  67 | [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:64:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:34557/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:34557/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:65:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-moves--23055-th-swipe-gestures-on-mobile-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/browse-Browse-media-moves--23055-th-swipe-gestures-on-mobile-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-moves--23055-th-swipe-gestures-on-mobile-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/browse-Browse-media-moves--23055-th-swipe-gestures-on-mobile-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  12) [chromium] › e2e/browse.spec.ts:215:7 › Browse media › shows the current media position within the full list [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  62 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  63 | [little-moments-e2e]  > 64 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  65 | await logIn(page); [little-moments-e2e]  66 | }); [little-moments-e2e]  67 | [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:64:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:37797/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:37797/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:65:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-shows--fa2ac-sition-within-the-full-list-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/browse-Browse-media-shows--fa2ac-sition-within-the-full-list-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-shows--fa2ac-sition-within-the-full-list-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/browse-Browse-media-shows--fa2ac-sition-within-the-full-list-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  13) [chromium] › e2e/browse.spec.ts:232:7 › Browse media › opens the last entry from the browse page and shows the oldest media [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  62 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  63 | [little-moments-e2e]  > 64 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  65 | await logIn(page); [little-moments-e2e]  66 | }); [little-moments-e2e]  67 | [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:64:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:45291/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:45291/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/browse.spec.ts:65:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-opens--bb8a3--and-shows-the-oldest-media-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/browse-Browse-media-opens--bb8a3--and-shows-the-oldest-media-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/browse-Browse-media-opens--bb8a3--and-shows-the-oldest-media-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/browse-Browse-media-opens--bb8a3--and-shows-the-oldest-media-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  14) [chromium] › e2e/media.spec.ts:10:7 › View media › shows reaction with a tooltip of the exact date [little-moments-e2e]  [little-moments-e2e]  Test timeout of 5000ms exceeded while running "beforeEach" hook. [little-moments-e2e]  [little-moments-e2e]  4 | test.describe.configure({ mode: "parallel" }); [little-moments-e2e]  5 | [little-moments-e2e]  > 6 | test.beforeEach(async ({ page }) => { [little-moments-e2e]  | ^ [little-moments-e2e]  7 | await logIn(page); [little-moments-e2e]  8 | }); [little-moments-e2e]  9 | [little-moments-e2e]  at /build/source/e2e/media.spec.ts:6:8 [little-moments-e2e]  [little-moments-e2e]  Error: expect(page).toHaveURL(expected) failed [little-moments-e2e]  [little-moments-e2e]  Expected pattern: /\/login\/confirm/ [little-moments-e2e]  Received string: "http://127.0.0.1:41637/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   7 × unexpected value "http://127.0.0.1:41637/login" [little-moments-e2e]  [little-moments-e2e]  [little-moments-e2e]  at fixtures.ts:200 [little-moments-e2e]  [little-moments-e2e]  198 | await page.getByLabel("Email address").fill("homer@example.com"); [little-moments-e2e]  199 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  > 200 | await expect(page).toHaveURL(/\/login\/confirm/); [little-moments-e2e]  | ^ [little-moments-e2e]  201 | await page.getByRole("button", { name: "Log in" }).click(); [little-moments-e2e]  202 | await expect(page).toHaveURL("/"); [little-moments-e2e]  203 | } [little-moments-e2e]  at logIn (/build/source/e2e/fixtures.ts:200:22) [little-moments-e2e]  at /build/source/e2e/media.spec.ts:7:5 [little-moments-e2e]  [little-moments-e2e]  attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/media-View-media-shows-rea-844de-a-tooltip-of-the-exact-date-chromium/video.webm [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  Error Context: e2e-results/media-View-media-shows-rea-844de-a-tooltip-of-the-exact-date-chromium/error-context.md [little-moments-e2e]  [little-moments-e2e]  attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── [little-moments-e2e]  e2e-results/media-View-media-shows-rea-844de-a-tooltip-of-the-exact-date-chromium/trace.zip [little-moments-e2e]  Usage: [little-moments-e2e]  [little-moments-e2e]  npx playwright show-trace e2e-results/media-View-media-shows-rea-844de-a-tooltip-of-the-exact-date-chromium/trace.zip [little-moments-e2e]  [little-moments-e2e]  ──────────────────────────────────────────────────────────────────────────────────────────────── [little-moments-e2e]  [little-moments-e2e]  14 failed [little-moments-e2e]  [chromium] › e2e/auth.spec.ts:13:7 › Authentication › logs in and shows the browse page ──────── [little-moments-e2e]  [chromium] › e2e/auth.spec.ts:20:7 › Authentication › redirects to stored next path after login [little-moments-e2e]  [chromium] › e2e/auth.spec.ts:39:7 › Authentication › logs out and redirects to the login page ─ [little-moments-e2e]  [chromium] › e2e/auth.spec.ts:47:7 › Authentication › cannot access protected routes after logging out [little-moments-e2e]  [chromium] › e2e/browse.spec.ts:68:7 › Browse media › shows the imported media entries on the browse page [little-moments-e2e]  [chromium] › e2e/browse.spec.ts:81:7 › Browse media › shows media thumbnails from newest to oldest [little-moments-e2e]  [chromium] › e2e/browse.spec.ts:92:7 › Browse media › shows a video indicator on video thumbnails only [little-moments-e2e]  [chromium] › e2e/browse.spec.ts:113:7 › Browse media › opens the first entry from the browse page and shows its details [little-moments-e2e]  [chromium] › e2e/browse.spec.ts:135:7 › Browse media › moves through adjacent entries with Previous and Next links [little-moments-e2e]  [chromium] › e2e/browse.spec.ts:166:7 › Browse media › moves through adjacent entries with left and right arrow keys [little-moments-e2e]  [chromium] › e2e/browse.spec.ts:187:7 › Browse media › moves through adjacent entries with swipe gestures on mobile [little-moments-e2e]  [chromium] › e2e/browse.spec.ts:215:7 › Browse media › shows the current media position within the full list [little-moments-e2e]  [chromium] › e2e/browse.spec.ts:232:7 › Browse media › opens the last entry from the browse page and shows the oldest media [little-moments-e2e]  [chromium] › e2e/media.spec.ts:10:7 › View media › shows reaction with a tooltip of the exact date [little-moments-e2e]  1 passed (15.3s) Progress: 0 of 1 built (1 failed) Cannot build '/nix/store/0svp39a4wcb66ridvcrr0i9wv5f632rx-little-moments-e2e-0.0.1.drv'. Reason: builder failed with exit code 1. Output paths: /nix/store/lnmi1pcqrjp8ar06dg3vv5020147v1v1-little-moments-e2e-0.0.1 Last 755 log lines: > Running phase: unpackPhase > unpacking source archive /nix/store/sfikzia855qp9j1a9j3bkmqfwgyfgwjk-source > source root is source > Running phase: patchPhase > Executing npmConfigHook > Configuring npm > Validating consistency between /build/source/package-lock.json and /nix/store/s010d1fi38rq6sq05s7jvvqri9dwn7ci-little-moments-e2e-0.0.1-npm-deps/package-lock.json > Setting npm_config_cache to /nix/store/s010d1fi38rq6sq05s7jvvqri9dwn7ci-little-moments-e2e-0.0.1-npm-deps > Installing dependencies > npm warn Unknown env config "nodedir". This will stop working in the next major version of npm. > npm warn Unknown env config "platform". This will stop working in the next major version of npm. > npm warn Unknown env config "arch". This will stop working in the next major version of npm. > > added 100 packages, and audited 101 packages in 649ms > > 25 packages are looking for funding > run `npm fund` for details > > found 0 vulnerabilities > patching script interpreter paths in node_modules > node_modules/prettier/bin/prettier.cjs: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > node_modules/which/bin/node-which: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > node_modules/js-yaml/bin/js-yaml.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > node_modules/@playwright/test/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > node_modules/eslint/bin/eslint.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > node_modules/playwright/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > node_modules/playwright-core/lib/utilsBundleImpl/xdg-open: interpreter directive changed from "#!/bin/sh" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/sh" > node_modules/playwright-core/bin/reinstall_msedge_beta_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/bin/reinstall_chrome_beta_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/bin/reinstall_msedge_beta_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/bin/reinstall_chrome_beta_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/bin/reinstall_chrome_stable_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/bin/reinstall_msedge_dev_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/bin/reinstall_chrome_stable_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/bin/reinstall_msedge_stable_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/bin/reinstall_msedge_stable_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/bin/reinstall_msedge_dev_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" > node_modules/playwright-core/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > node_modules/ulid/bin/cli.js: interpreter directive changed from "#! /usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > node_modules/acorn/bin/acorn: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > npm warn Unknown env config "nodedir". This will stop working in the next major version of npm. > npm warn Unknown env config "platform". This will stop working in the next major version of npm. > npm warn Unknown env config "arch". This will stop working in the next major version of npm. > rebuilt dependencies successfully > patching script interpreter paths in node_modules > Finished npmConfigHook > Running phase: updateAutotoolsGnuConfigScriptsPhase > Running phase: configurePhase > no configure script, doing nothing > Running phase: buildPhase > no Makefile or custom buildPhase, doing nothing > Running phase: checkPhase > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied d0b19b5f-0fde-4e5c-acc1-bd3e66583811-full.avif > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied d0b19b5f-0fde-4e5c-acc1-bd3e66583811-250px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied d0b19b5f-0fde-4e5c-acc1-bd3e66583811-150px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 044fb4b0-604c-44dc-b57c-3e8236a9f3ed-full.mp4 > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 044fb4b0-604c-44dc-b57c-3e8236a9f3ed-thumb-250px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 044fb4b0-604c-44dc-b57c-3e8236a9f3ed-thumb-150px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied c9ebbcb4-07bc-4d36-bf8f-3dad37efa229-full.mp4 > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied c9ebbcb4-07bc-4d36-bf8f-3dad37efa229-thumb-250px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied c9ebbcb4-07bc-4d36-bf8f-3dad37efa229-thumb-150px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 689aa777-bcc2-4b05-b4ee-d4daf5cb387c-full.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 689aa777-bcc2-4b05-b4ee-d4daf5cb387c-850px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 689aa777-bcc2-4b05-b4ee-d4daf5cb387c-250px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 689aa777-bcc2-4b05-b4ee-d4daf5cb387c-150px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied fb2d0669-37d2-43f1-b013-c66d6a7c69f2-full.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied fb2d0669-37d2-43f1-b013-c66d6a7c69f2-850px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied fb2d0669-37d2-43f1-b013-c66d6a7c69f2-250px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied fb2d0669-37d2-43f1-b013-c66d6a7c69f2-150px.jpg > 2026/05/30 20:21:25 codeberg.org/mtlynch/little-moments/store/sqlite/sqlite.go:18: reading DB from /build/source/test-imported-media/test-store.db > 2026/05/30 20:21:26 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:140: wrote /build/source/test-imported-media/test-store.db > npm warn Unknown env config "nodedir". This will stop working in the next major version of npm. > npm warn Unknown env config "platform". This will stop working in the next major version of npm. > npm warn Unknown env config "arch". This will stop working in the next major version of npm. > > Running 15 tests using 8 workers > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > ·TTTTTTTTSkipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. > TTTTTT > > 1) [chromium] › e2e/auth.spec.ts:13:7 › Authentication › logs in and shows the browse page ─────── > > Test timeout of 5000ms exceeded. > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:42659/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:42659/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/auth.spec.ts:14:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/auth-Authentication-logs-in-and-shows-the-browse-page-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/auth-Authentication-logs-in-and-shows-the-browse-page-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/auth-Authentication-logs-in-and-shows-the-browse-page-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/auth-Authentication-logs-in-and-shows-the-browse-page-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 2) [chromium] › e2e/auth.spec.ts:20:7 › Authentication › redirects to stored next path after login > > Test timeout of 5000ms exceeded. > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm\?token=[^&]+$/ > Received string: "http://127.0.0.1:46877/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:46877/login" > > > 27 | await page.getByLabel("Email address").fill("homer@example.com"); > 28 | await page.getByRole("button", { name: "Log in" }).click(); > > 29 | await expect(page).toHaveURL(/\/login\/confirm\?token=[^&]+$/); > | ^ > 30 | > 31 | await page.getByRole("button", { name: "Log in" }).click(); > 32 | > at /build/source/e2e/auth.spec.ts:29:24 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/auth-Authentication-redire-2d7b2-tored-next-path-after-login-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/auth-Authentication-redire-2d7b2-tored-next-path-after-login-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/auth-Authentication-redire-2d7b2-tored-next-path-after-login-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/auth-Authentication-redire-2d7b2-tored-next-path-after-login-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 3) [chromium] › e2e/auth.spec.ts:39:7 › Authentication › logs out and redirects to the login page > > Test timeout of 5000ms exceeded. > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:37357/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:37357/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/auth.spec.ts:40:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/auth-Authentication-logs-out-and-redirects-to-the-login-page-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/auth-Authentication-logs-out-and-redirects-to-the-login-page-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/auth-Authentication-logs-out-and-redirects-to-the-login-page-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/auth-Authentication-logs-out-and-redirects-to-the-login-page-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 4) [chromium] › e2e/auth.spec.ts:47:7 › Authentication › cannot access protected routes after logging out > > Test timeout of 5000ms exceeded. > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:38551/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:38551/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/auth.spec.ts:48:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/auth-Authentication-cannot-a27fd-ed-routes-after-logging-out-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/auth-Authentication-cannot-a27fd-ed-routes-after-logging-out-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/auth-Authentication-cannot-a27fd-ed-routes-after-logging-out-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/auth-Authentication-cannot-a27fd-ed-routes-after-logging-out-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 5) [chromium] › e2e/browse.spec.ts:68:7 › Browse media › shows the imported media entries on the browse page > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 62 | test.describe.configure({ mode: "parallel" }); > 63 | > > 64 | test.beforeEach(async ({ page }) => { > | ^ > 65 | await logIn(page); > 66 | }); > 67 | > at /build/source/e2e/browse.spec.ts:64:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:41785/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:41785/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/browse.spec.ts:65:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-shows--02a6e--entries-on-the-browse-page-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/browse-Browse-media-shows--02a6e--entries-on-the-browse-page-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-shows--02a6e--entries-on-the-browse-page-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/browse-Browse-media-shows--02a6e--entries-on-the-browse-page-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 6) [chromium] › e2e/browse.spec.ts:81:7 › Browse media › shows media thumbnails from newest to oldest > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 62 | test.describe.configure({ mode: "parallel" }); > 63 | > > 64 | test.beforeEach(async ({ page }) => { > | ^ > 65 | await logIn(page); > 66 | }); > 67 | > at /build/source/e2e/browse.spec.ts:64:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:40281/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:40281/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/browse.spec.ts:65:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-shows--19f8f-nails-from-newest-to-oldest-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/browse-Browse-media-shows--19f8f-nails-from-newest-to-oldest-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-shows--19f8f-nails-from-newest-to-oldest-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/browse-Browse-media-shows--19f8f-nails-from-newest-to-oldest-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 7) [chromium] › e2e/browse.spec.ts:92:7 › Browse media › shows a video indicator on video thumbnails only > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 62 | test.describe.configure({ mode: "parallel" }); > 63 | > > 64 | test.beforeEach(async ({ page }) => { > | ^ > 65 | await logIn(page); > 66 | }); > 67 | > at /build/source/e2e/browse.spec.ts:64:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:33435/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:33435/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/browse.spec.ts:65:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-shows--c7537-or-on-video-thumbnails-only-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/browse-Browse-media-shows--c7537-or-on-video-thumbnails-only-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-shows--c7537-or-on-video-thumbnails-only-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/browse-Browse-media-shows--c7537-or-on-video-thumbnails-only-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 8) [chromium] › e2e/browse.spec.ts:113:7 › Browse media › opens the first entry from the browse page and shows its details > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 62 | test.describe.configure({ mode: "parallel" }); > 63 | > > 64 | test.beforeEach(async ({ page }) => { > | ^ > 65 | await logIn(page); > 66 | }); > 67 | > at /build/source/e2e/browse.spec.ts:64:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:42753/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:42753/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/browse.spec.ts:65:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-opens--542e7--page-and-shows-its-details-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/browse-Browse-media-opens--542e7--page-and-shows-its-details-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-opens--542e7--page-and-shows-its-details-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/browse-Browse-media-opens--542e7--page-and-shows-its-details-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 9) [chromium] › e2e/browse.spec.ts:135:7 › Browse media › moves through adjacent entries with Previous and Next links > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 62 | test.describe.configure({ mode: "parallel" }); > 63 | > > 64 | test.beforeEach(async ({ page }) => { > | ^ > 65 | await logIn(page); > 66 | }); > 67 | > at /build/source/e2e/browse.spec.ts:64:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:40603/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:40603/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/browse.spec.ts:65:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-moves--c86ee-ith-Previous-and-Next-links-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/browse-Browse-media-moves--c86ee-ith-Previous-and-Next-links-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-moves--c86ee-ith-Previous-and-Next-links-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/browse-Browse-media-moves--c86ee-ith-Previous-and-Next-links-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 10) [chromium] › e2e/browse.spec.ts:166:7 › Browse media › moves through adjacent entries with left and right arrow keys > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 62 | test.describe.configure({ mode: "parallel" }); > 63 | > > 64 | test.beforeEach(async ({ page }) => { > | ^ > 65 | await logIn(page); > 66 | }); > 67 | > at /build/source/e2e/browse.spec.ts:64:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:43329/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:43329/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/browse.spec.ts:65:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-moves--d7942-h-left-and-right-arrow-keys-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/browse-Browse-media-moves--d7942-h-left-and-right-arrow-keys-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-moves--d7942-h-left-and-right-arrow-keys-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/browse-Browse-media-moves--d7942-h-left-and-right-arrow-keys-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 11) [chromium] › e2e/browse.spec.ts:187:7 › Browse media › moves through adjacent entries with swipe gestures on mobile > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 62 | test.describe.configure({ mode: "parallel" }); > 63 | > > 64 | test.beforeEach(async ({ page }) => { > | ^ > 65 | await logIn(page); > 66 | }); > 67 | > at /build/source/e2e/browse.spec.ts:64:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:34557/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:34557/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/browse.spec.ts:65:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-moves--23055-th-swipe-gestures-on-mobile-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/browse-Browse-media-moves--23055-th-swipe-gestures-on-mobile-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-moves--23055-th-swipe-gestures-on-mobile-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/browse-Browse-media-moves--23055-th-swipe-gestures-on-mobile-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 12) [chromium] › e2e/browse.spec.ts:215:7 › Browse media › shows the current media position within the full list > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 62 | test.describe.configure({ mode: "parallel" }); > 63 | > > 64 | test.beforeEach(async ({ page }) => { > | ^ > 65 | await logIn(page); > 66 | }); > 67 | > at /build/source/e2e/browse.spec.ts:64:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:37797/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:37797/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/browse.spec.ts:65:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-shows--fa2ac-sition-within-the-full-list-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/browse-Browse-media-shows--fa2ac-sition-within-the-full-list-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-shows--fa2ac-sition-within-the-full-list-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/browse-Browse-media-shows--fa2ac-sition-within-the-full-list-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 13) [chromium] › e2e/browse.spec.ts:232:7 › Browse media › opens the last entry from the browse page and shows the oldest media > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 62 | test.describe.configure({ mode: "parallel" }); > 63 | > > 64 | test.beforeEach(async ({ page }) => { > | ^ > 65 | await logIn(page); > 66 | }); > 67 | > at /build/source/e2e/browse.spec.ts:64:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:45291/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:45291/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/browse.spec.ts:65:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-opens--bb8a3--and-shows-the-oldest-media-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/browse-Browse-media-opens--bb8a3--and-shows-the-oldest-media-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/browse-Browse-media-opens--bb8a3--and-shows-the-oldest-media-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/browse-Browse-media-opens--bb8a3--and-shows-the-oldest-media-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 14) [chromium] › e2e/media.spec.ts:10:7 › View media › shows reaction with a tooltip of the exact date > > Test timeout of 5000ms exceeded while running "beforeEach" hook. > > 4 | test.describe.configure({ mode: "parallel" }); > 5 | > > 6 | test.beforeEach(async ({ page }) => { > | ^ > 7 | await logIn(page); > 8 | }); > 9 | > at /build/source/e2e/media.spec.ts:6:8 > > Error: expect(page).toHaveURL(expected) failed > > Expected pattern: /\/login\/confirm/ > Received string: "http://127.0.0.1:41637/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:41637/login" > > > at fixtures.ts:200 > > 198 | await page.getByLabel("Email address").fill("homer@example.com"); > 199 | await page.getByRole("button", { name: "Log in" }).click(); > > 200 | await expect(page).toHaveURL(/\/login\/confirm/); > | ^ > 201 | await page.getByRole("button", { name: "Log in" }).click(); > 202 | await expect(page).toHaveURL("/"); > 203 | } > at logIn (/build/source/e2e/fixtures.ts:200:22) > at /build/source/e2e/media.spec.ts:7:5 > > attachment #1: video (video/webm) ────────────────────────────────────────────────────────────── > e2e-results/media-View-media-shows-rea-844de-a-tooltip-of-the-exact-date-chromium/video.webm > ──────────────────────────────────────────────────────────────────────────────────────────────── > > Error Context: e2e-results/media-View-media-shows-rea-844de-a-tooltip-of-the-exact-date-chromium/error-context.md > > attachment #3: trace (application/zip) ───────────────────────────────────────────────────────── > e2e-results/media-View-media-shows-rea-844de-a-tooltip-of-the-exact-date-chromium/trace.zip > Usage: > > npx playwright show-trace e2e-results/media-View-media-shows-rea-844de-a-tooltip-of-the-exact-date-chromium/trace.zip > > ──────────────────────────────────────────────────────────────────────────────────────────────── > > 14 failed > [chromium] › e2e/auth.spec.ts:13:7 › Authentication › logs in and shows the browse page ──────── > [chromium] › e2e/auth.spec.ts:20:7 › Authentication › redirects to stored next path after login > [chromium] › e2e/auth.spec.ts:39:7 › Authentication › logs out and redirects to the login page ─ > [chromium] › e2e/auth.spec.ts:47:7 › Authentication › cannot access protected routes after logging out > [chromium] › e2e/browse.spec.ts:68:7 › Browse media › shows the imported media entries on the browse page > [chromium] › e2e/browse.spec.ts:81:7 › Browse media › shows media thumbnails from newest to oldest > [chromium] › e2e/browse.spec.ts:92:7 › Browse media › shows a video indicator on video thumbnails only > [chromium] › e2e/browse.spec.ts:113:7 › Browse media › opens the first entry from the browse page and shows its details > [chromium] › e2e/browse.spec.ts:135:7 › Browse media › moves through adjacent entries with Previous and Next links > [chromium] › e2e/browse.spec.ts:166:7 › Browse media › moves through adjacent entries with left and right arrow keys > [chromium] › e2e/browse.spec.ts:187:7 › Browse media › moves through adjacent entries with swipe gestures on mobile > [chromium] › e2e/browse.spec.ts:215:7 › Browse media › shows the current media position within the full list > [chromium] › e2e/browse.spec.ts:232:7 › Browse media › opens the last entry from the browse page and shows the oldest media > [chromium] › e2e/media.spec.ts:10:7 › View media › shows reaction with a tooltip of the exact date > 1 passed (15.3s) For full logs, run: nix log /nix/store/0svp39a4wcb66ridvcrr0i9wv5f632rx-little-moments-e2e-0.0.1.drv