$ /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=edd4981e9248168cfdcc612e460ec5cf6baf4f7b#packages.x86_64-linux.e2e-tests --print-build-logs fetching Git repository 'https://codeberg.org/mtlynch/little-moments'  Building import-from-tinybeans Building little-moments-dev [import-from-tinybeans] Phase: unpackPhase [import-from-tinybeans] unpacking source archive /nix/store/9990sm2dk6dzldlfy681p7npj45jka5q-source [little-moments-dev] Phase: unpackPhase [import-from-tinybeans] source root is source [little-moments-dev] unpacking source archive /nix/store/9990sm2dk6dzldlfy681p7npj45jka5q-source [import-from-tinybeans] Phase: patchPhase [import-from-tinybeans] Phase: updateAutotoolsGnuConfigScriptsPhase [little-moments-dev] source root is source [import-from-tinybeans] Phase: configurePhase [little-moments-dev] Phase: patchPhase [little-moments-dev] Phase: updateAutotoolsGnuConfigScriptsPhase [little-moments-dev] Phase: configurePhase [import-from-tinybeans] Phase: buildPhase [import-from-tinybeans] Building subPackage ./cmd/import-from-tinybeans [little-moments-dev] Phase: buildPhase [little-moments-dev] Building subPackage ./cmd/app [little-moments-dev] Phase: checkPhase [import-from-tinybeans] Phase: checkPhase [little-moments-dev] ? codeberg.org/mtlynch/little-moments/cmd/app [no test files] [little-moments-dev] Phase: installPhase [little-moments-dev] Phase: fixupPhase [little-moments-dev] shrinking RPATHs of ELF executables and libraries in /nix/store/wgdrvg9prbns5mz33wkjcs4d6b1mz7km-little-moments-dev-0.0.1 [little-moments-dev] shrinking /nix/store/wgdrvg9prbns5mz33wkjcs4d6b1mz7km-little-moments-dev-0.0.1/bin/app-dev [little-moments-dev] patchelf: cannot find section '.dynamic'. The input file is most likely statically linked [little-moments-dev] checking for references to /build/ in /nix/store/wgdrvg9prbns5mz33wkjcs4d6b1mz7km-little-moments-dev-0.0.1... [little-moments-dev] patchelf: cannot find section '.dynamic'. The input file is most likely statically linked [little-moments-dev] patching script interpreter paths in /nix/store/wgdrvg9prbns5mz33wkjcs4d6b1mz7km-little-moments-dev-0.0.1 [little-moments-dev] stripping (with command strip and flags -S -p) in /nix/store/wgdrvg9prbns5mz33wkjcs4d6b1mz7km-little-moments-dev-0.0.1/bin [post-build-hook] Uploading to the NixCI cache: /nix/store/wgdrvg9prbns5mz33wkjcs4d6b1mz7km-little-moments-dev-0.0.1 [post-build-hook] copying 1 paths... [post-build-hook] copying path '/nix/store/wgdrvg9prbns5mz33wkjcs4d6b1mz7km-little-moments-dev-0.0.1' to 'https://cache.nix-ci.com'... [post-build-hook] copying 0 paths... Progress: 1 of 4 built (1 building) [import-from-tinybeans] ? codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans [no test files] [import-from-tinybeans] Phase: installPhase [import-from-tinybeans] Phase: fixupPhase [import-from-tinybeans] shrinking RPATHs of ELF executables and libraries in /nix/store/3r9m6v87bg1qa2mv0raivpk076450bq7-import-from-tinybeans-0.0.1 [import-from-tinybeans] shrinking /nix/store/3r9m6v87bg1qa2mv0raivpk076450bq7-import-from-tinybeans-0.0.1/bin/.import-from-tinybeans-wrapped [import-from-tinybeans] patchelf: cannot find section '.dynamic'. The input file is most likely statically linked [import-from-tinybeans] checking for references to /build/ in /nix/store/3r9m6v87bg1qa2mv0raivpk076450bq7-import-from-tinybeans-0.0.1... [import-from-tinybeans] patchelf: cannot find section '.dynamic'. The input file is most likely statically linked [import-from-tinybeans] patching script interpreter paths in /nix/store/3r9m6v87bg1qa2mv0raivpk076450bq7-import-from-tinybeans-0.0.1 [import-from-tinybeans] stripping (with command strip and flags -S -p) in /nix/store/3r9m6v87bg1qa2mv0raivpk076450bq7-import-from-tinybeans-0.0.1/bin [post-build-hook] Uploading to the NixCI cache: /nix/store/3r9m6v87bg1qa2mv0raivpk076450bq7-import-from-tinybeans-0.0.1 [post-build-hook] copying 1 paths... [post-build-hook] copying path '/nix/store/3r9m6v87bg1qa2mv0raivpk076450bq7-import-from-tinybeans-0.0.1' to 'https://cache.nix-ci.com'... [post-build-hook] copying 2 paths... [post-build-hook] copying path '/nix/store/17gqiqxya6pki14qhby1s096yjw22dvr-import-from-tinybeans-0.0.1-go-modules.drv' to 'https://cache.nix-ci.com'... [post-build-hook] copying path '/nix/store/gyggpxkgjxynd42q7lgfl13lcs0liypr-import-from-tinybeans-0.0.1.drv' to 'https://cache.nix-ci.com'... Progress: 2 of 4 built Building little-moments-e2e [little-moments-e2e] Phase: unpackPhase [little-moments-e2e] unpacking source archive /nix/store/9990sm2dk6dzldlfy681p7npj45jka5q-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 785ms [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/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_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_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_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_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/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/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/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/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/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/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/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 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied d8acc6b3-82b4-4b6b-9de7-533b07c2c7f8-full.avif [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied d8acc6b3-82b4-4b6b-9de7-533b07c2c7f8-250px.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied d8acc6b3-82b4-4b6b-9de7-533b07c2c7f8-150px.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied dddc1a7b-61b9-43db-9dc2-a9e6cddb0b62-full.mp4 [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied dddc1a7b-61b9-43db-9dc2-a9e6cddb0b62-thumb-250px.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied dddc1a7b-61b9-43db-9dc2-a9e6cddb0b62-thumb-150px.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied f2933a84-43e6-4daf-bbde-204f39df385b-full.mp4 [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied f2933a84-43e6-4daf-bbde-204f39df385b-thumb-250px.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied f2933a84-43e6-4daf-bbde-204f39df385b-thumb-150px.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 5a15fc79-78f4-4378-9355-6655c3791297-full.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 5a15fc79-78f4-4378-9355-6655c3791297-850px.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 5a15fc79-78f4-4378-9355-6655c3791297-250px.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 5a15fc79-78f4-4378-9355-6655c3791297-150px.jpg [little-moments-e2e] 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 7f305234-fb6f-4410-a683-e7eecfd0a3cd-full.jpg [little-moments-e2e] 2026/05/30 23:44:36 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 7f305234-fb6f-4410-a683-e7eecfd0a3cd-850px.jpg [little-moments-e2e] 2026/05/30 23:44:36 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 7f305234-fb6f-4410-a683-e7eecfd0a3cd-250px.jpg [little-moments-e2e] 2026/05/30 23:44:36 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 7f305234-fb6f-4410-a683-e7eecfd0a3cd-150px.jpg [little-moments-e2e] 2026/05/30 23:44:36 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:44:36 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:38941/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:38941/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:42001/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:42001/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:45017/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:45017/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:38595/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:38595/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:38821/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:38821/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:34697/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:34697/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:33081/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:33081/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:42183/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:42183/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:39147/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:39147/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: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/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:35289/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:35289/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:42521/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:42521/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:39029/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:39029/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.8s) Progress: 2 of 3 built (1 failed) Cannot build '/nix/store/75i6lnv7gz4qwcn5r990jyjz3j9dzvg8-little-moments-e2e-0.0.1.drv'. Reason: builder failed with exit code 1. Output paths: /nix/store/3iwqsxncm15zmh6p2604y6a9p4hfz63k-little-moments-e2e-0.0.1 Last 751 log lines: > Running phase: unpackPhase > unpacking source archive /nix/store/9990sm2dk6dzldlfy681p7npj45jka5q-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 785ms > > 25 packages are looking for funding > run `npm fund` for details > > found 0 vulnerabilities > patching script interpreter paths in node_modules > 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_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_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_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_dev_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_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/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/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/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/test/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" > 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/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 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied d8acc6b3-82b4-4b6b-9de7-533b07c2c7f8-full.avif > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied d8acc6b3-82b4-4b6b-9de7-533b07c2c7f8-250px.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied d8acc6b3-82b4-4b6b-9de7-533b07c2c7f8-150px.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied dddc1a7b-61b9-43db-9dc2-a9e6cddb0b62-full.mp4 > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied dddc1a7b-61b9-43db-9dc2-a9e6cddb0b62-thumb-250px.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied dddc1a7b-61b9-43db-9dc2-a9e6cddb0b62-thumb-150px.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied f2933a84-43e6-4daf-bbde-204f39df385b-full.mp4 > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied f2933a84-43e6-4daf-bbde-204f39df385b-thumb-250px.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied f2933a84-43e6-4daf-bbde-204f39df385b-thumb-150px.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 5a15fc79-78f4-4378-9355-6655c3791297-full.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 5a15fc79-78f4-4378-9355-6655c3791297-850px.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 5a15fc79-78f4-4378-9355-6655c3791297-250px.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 5a15fc79-78f4-4378-9355-6655c3791297-150px.jpg > 2026/05/30 23:44:35 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 7f305234-fb6f-4410-a683-e7eecfd0a3cd-full.jpg > 2026/05/30 23:44:36 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 7f305234-fb6f-4410-a683-e7eecfd0a3cd-850px.jpg > 2026/05/30 23:44:36 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 7f305234-fb6f-4410-a683-e7eecfd0a3cd-250px.jpg > 2026/05/30 23:44:36 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 7f305234-fb6f-4410-a683-e7eecfd0a3cd-150px.jpg > 2026/05/30 23:44:36 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:44:36 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:38941/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:38941/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:42001/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:42001/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:45017/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:45017/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:38595/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:38595/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:38821/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:38821/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:34697/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:34697/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:33081/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  8 × unexpected value "http://127.0.0.1:33081/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:42183/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  8 × unexpected value "http://127.0.0.1:42183/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:39147/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:39147/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: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/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:35289/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:35289/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:42521/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:42521/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:39029/login" > > Call log: >  - Expect "toHaveURL" with timeout 5000ms >  7 × unexpected value "http://127.0.0.1:39029/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.8s) For full logs, run: nix log /nix/store/75i6lnv7gz4qwcn5r990jyjz3j9dzvg8-little-moments-e2e-0.0.1.drv