$ /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=2f70a61d71d252e434ac6d7a1eedf827125605c7#packages.x86_64-linux.e2e-tests --print-build-logs  Downloading cached import-from-tinybeans from https://cache.nix-ci.com Progress: 0 of 2 built, 1 of 1 downloaded from cache Building little-moments-e2e [little-moments-e2e] Phase: unpackPhase [little-moments-e2e] unpacking source archive /nix/store/9sca80swbisjsgqp3p2f43pqqmzly3s8-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 639ms [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/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/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/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/acorn/bin/acorn: 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/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_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_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_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_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_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_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_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_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/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/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/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/playwright/cli.js: 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 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied cde9f5bf-f8ec-4ad8-b61c-99e3faf39321-full.avif [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied cde9f5bf-f8ec-4ad8-b61c-99e3faf39321-250px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied cde9f5bf-f8ec-4ad8-b61c-99e3faf39321-150px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 463a560f-d015-4c65-9357-b9bfefabed66-full.mp4 [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 463a560f-d015-4c65-9357-b9bfefabed66-thumb-250px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 463a560f-d015-4c65-9357-b9bfefabed66-thumb-150px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied dcfeca76-f6c1-4083-b7e2-4df357cb43ce-full.mp4 [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied dcfeca76-f6c1-4083-b7e2-4df357cb43ce-thumb-250px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied dcfeca76-f6c1-4083-b7e2-4df357cb43ce-thumb-150px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 50eb7166-7654-42d9-a1f3-c22e65ea0051-full.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 50eb7166-7654-42d9-a1f3-c22e65ea0051-850px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 50eb7166-7654-42d9-a1f3-c22e65ea0051-250px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 50eb7166-7654-42d9-a1f3-c22e65ea0051-150px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 75b02ca1-38f5-4f92-903d-61a8788fc27f-full.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 75b02ca1-38f5-4f92-903d-61a8788fc27f-850px.jpg [little-moments-e2e] 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 75b02ca1-38f5-4f92-903d-61a8788fc27f-250px.jpg [little-moments-e2e] 2026/05/30 23:24:52 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 75b02ca1-38f5-4f92-903d-61a8788fc27f-150px.jpg [little-moments-e2e] 2026/05/30 23:24:52 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 23:24:52 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] ·FTTTTTTTSkipping 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:38675/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:38675/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]  Error: expect(received).toBe(expected) // Object.is equality [little-moments-e2e]  [little-moments-e2e]  Expected: "/" [little-moments-e2e]  Received: null [little-moments-e2e]  [little-moments-e2e]  Call Log: [little-moments-e2e]  - Test timeout of 5000ms exceeded [little-moments-e2e]  [little-moments-e2e]  21 | await page.goto("/"); [little-moments-e2e]  22 | await expect(page).toHaveURL("/login?next=%2F"); [little-moments-e2e]  > 23 | await expect [little-moments-e2e]  | ^ [little-moments-e2e]  24 | .poll(() => page.evaluate(() => localStorage.getItem("next"))) [little-moments-e2e]  25 | .toBe("/"); [little-moments-e2e]  26 | [little-moments-e2e]  at /build/source/e2e/auth.spec.ts:23:5 [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:38795/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:38795/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:41373/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:41373/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:36163/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:36163/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:37641/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:37641/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:42643/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:42643/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:35835/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   8 × unexpected value "http://127.0.0.1:35835/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:41839/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:41839/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:43769/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   8 × unexpected value "http://127.0.0.1:43769/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:34087/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   8 × unexpected value "http://127.0.0.1:34087/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:43155/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   8 × unexpected value "http://127.0.0.1:43155/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:33949/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   8 × unexpected value "http://127.0.0.1:33949/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:44313/login" [little-moments-e2e]  [little-moments-e2e]  Call log: [little-moments-e2e]   - Expect "toHaveURL" with timeout 5000ms [little-moments-e2e]   8 × unexpected value "http://127.0.0.1:44313/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 (14.7s) Progress: 0 of 1 built (1 failed), 1 of 1 downloaded from cache Cannot build '/nix/store/kapdgh2fvaz382x4x1k7yf211a5m0hgk-little-moments-e2e-0.0.1.drv'. Reason: builder failed with exit code 1. Output paths: /nix/store/v42b9ldvngmdqx5gs48gv3zp56rrkib6-little-moments-e2e-0.0.1 Last 751 log lines: > Running phase: unpackPhase > unpacking source archive /nix/store/9sca80swbisjsgqp3p2f43pqqmzly3s8-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 639ms > > 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/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/test/cli.js: 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/acorn/bin/acorn: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > 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_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_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_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_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_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_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_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_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/playwright-core/lib/utilsBundleImpl/xdg-open: interpreter directive changed from "#!/bin/sh" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/sh" > 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/which/bin/node-which: 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" > 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 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied cde9f5bf-f8ec-4ad8-b61c-99e3faf39321-full.avif > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied cde9f5bf-f8ec-4ad8-b61c-99e3faf39321-250px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied cde9f5bf-f8ec-4ad8-b61c-99e3faf39321-150px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 463a560f-d015-4c65-9357-b9bfefabed66-full.mp4 > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 463a560f-d015-4c65-9357-b9bfefabed66-thumb-250px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 463a560f-d015-4c65-9357-b9bfefabed66-thumb-150px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied dcfeca76-f6c1-4083-b7e2-4df357cb43ce-full.mp4 > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied dcfeca76-f6c1-4083-b7e2-4df357cb43ce-thumb-250px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied dcfeca76-f6c1-4083-b7e2-4df357cb43ce-thumb-150px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 50eb7166-7654-42d9-a1f3-c22e65ea0051-full.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 50eb7166-7654-42d9-a1f3-c22e65ea0051-850px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 50eb7166-7654-42d9-a1f3-c22e65ea0051-250px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 50eb7166-7654-42d9-a1f3-c22e65ea0051-150px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 75b02ca1-38f5-4f92-903d-61a8788fc27f-full.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 75b02ca1-38f5-4f92-903d-61a8788fc27f-850px.jpg > 2026/05/30 23:24:51 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 75b02ca1-38f5-4f92-903d-61a8788fc27f-250px.jpg > 2026/05/30 23:24:52 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 75b02ca1-38f5-4f92-903d-61a8788fc27f-150px.jpg > 2026/05/30 23:24:52 codeberg.org/mtlynch/little-moments/store/sqlite/sqlite.go:18: reading DB from /build/source/test-imported-media/test-store.db > 2026/05/30 23:24:52 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. > ·FTTTTTTTSkipping 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:38675/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:38675/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 > > Error: expect(received).toBe(expected) // Object.is equality > > Expected: "/" > Received: null > > Call Log: > - Test timeout of 5000ms exceeded > > 21 | await page.goto("/"); > 22 | await expect(page).toHaveURL("/login?next=%2F"); > > 23 | await expect > | ^ > 24 | .poll(() => page.evaluate(() => localStorage.getItem("next"))) > 25 | .toBe("/"); > 26 | > at /build/source/e2e/auth.spec.ts:23:5 > > 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:38795/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:38795/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:41373/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:41373/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:36163/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:36163/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:37641/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:37641/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:42643/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:42643/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:35835/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  8 × unexpected value "http://127.0.0.1:35835/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:41839/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:41839/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:43769/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  8 × unexpected value "http://127.0.0.1:43769/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:34087/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  8 × unexpected value "http://127.0.0.1:34087/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:43155/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  8 × unexpected value "http://127.0.0.1:43155/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:33949/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  8 × unexpected value "http://127.0.0.1:33949/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:44313/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  8 × unexpected value "http://127.0.0.1:44313/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 (14.7s) For full logs, run: nix log /nix/store/kapdgh2fvaz382x4x1k7yf211a5m0hgk-little-moments-e2e-0.0.1.drv