107.75 s[grosiree-e2e] Validating consistency between /build/source/package-lock.json and /nix/store/xg9n2cx43bwcgqzw3a1nj3wjf6f8x10c-grosiree-e2e-0.0.1-npm-deps/package-lock.json
107.78 s[grosiree-e2e] Setting npm_config_cache to /nix/store/xg9n2cx43bwcgqzw3a1nj3wjf6f8x10c-grosiree-e2e-0.0.1-npm-deps
108.60 s[grosiree-e2e] patching script interpreter paths in node_modules
108.61 s[grosiree-e2e] node_modules/acorn/bin/acorn: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node"
108.63 s[grosiree-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"
108.64 s[grosiree-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"
108.65 s[grosiree-e2e] node_modules/playwright/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node"
108.66 s[grosiree-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"
108.67 s[grosiree-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"
108.68 s[grosiree-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"
108.69 s[grosiree-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"
108.70 s[grosiree-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"
108.71 s[grosiree-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"
108.72 s[grosiree-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"
108.73 s[grosiree-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"
108.74 s[grosiree-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"
108.75 s[grosiree-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"
108.76 s[grosiree-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"
108.77 s[grosiree-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"
108.78 s[grosiree-e2e] node_modules/playwright-core/lib/utilsBundleImpl/xdg-open: interpreter directive changed from "#!/bin/sh" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/sh"
108.79 s[grosiree-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"
108.80 s[grosiree-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"
108.82 s[grosiree-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"
108.90 s[grosiree-e2e] npmwarnUnknown env config "nodedir". This will stop working in the next major version of npm.
108.90 s[grosiree-e2e] npmwarnUnknown env config "platform". This will stop working in the next major version of npm.
108.90 s[grosiree-e2e] npmwarnUnknown env config "arch". This will stop working in the next major version of npm.
111.18 s[grosiree-e2e] Running 4 tests using 1 worker
111.69 s[grosiree-e2e] Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set.
111.80 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/db_dev.go:81: provisioning a new private database with token BfDosycj9KRktQfV45RfByODm6PgXR
111.80 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/store/sqlite/sqlite.go:24: reading DB from :memory:
111.80 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /login 200 4498
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/css/solid.min.css 200 572
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/css/fontawesome.min.css 200 80651
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/css/style.css 200 574
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813
111.81 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/confirm-dialog.js 200 3023
111.94 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: POST /login 303 0
111.94 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET / 200 22396
111.98 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/items 200 3
111.98 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/sections 200 3
112.00 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: POST /api/groceries 200 943
112.01 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: POST /api/groceries/clear 200 87
112.01 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET / 200 22408
112.04 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/items 200 36
112.04 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/sections 200 10
112.11 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: POST /api/groceries 200 943
112.13 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/items 200 36
112.13 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/webfonts/fa-solid-900.woff2 200 150472
112.13 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:10 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/sections 200 10
112.44 s[grosiree-e2e] ·[WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/db_dev.go:81: provisioning a new private database with token 2GCINfiLD2cdCqyHIxoY8pS7zHNG4t
112.44 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/store/sqlite/sqlite.go:24: reading DB from :memory:
112.44 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /login 200 4498
112.44 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901
112.45 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/css/solid.min.css 200 572
112.45 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/css/fontawesome.min.css 200 80651
112.45 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/css/style.css 200 574
112.45 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496
112.45 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722
112.45 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917
112.45 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775
112.45 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813
112.45 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/confirm-dialog.js 200 3023
112.58 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: POST /login 303 0
112.58 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET / 200 22408
112.61 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/items 200 3
112.64 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/sections 200 3
112.64 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET / 200 22396
112.65 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/items 200 3
112.65 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:11 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/sections 200 3
114.19 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:12 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: POST /api/groceries 200 952
114.20 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/items 200 34
114.20 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/webfonts/fa-solid-900.woff2 200 150472
114.20 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/sections 200 3
114.42 s[grosiree-e2e] ·[WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/db_dev.go:81: provisioning a new private database with token oT8A9n0dSjiiYd7XYVHe2oy45gyf4F
114.42 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/store/sqlite/sqlite.go:24: reading DB from :memory:
114.42 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /login 200 4498
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/css/solid.min.css 200 572
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/css/style.css 200 574
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/css/fontawesome.min.css 200 80651
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813
114.43 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/confirm-dialog.js 200 3023
114.54 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: POST /login 303 0
114.54 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET / 200 22408
114.57 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/items 200 3
114.57 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /api/autocomplete/sections 200 3
114.58 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: POST /api/groceries 200 960
114.58 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /grocery-items 200 9068
114.61 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:13 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/webfonts/fa-solid-900.woff2 200 150472
115.76 s[grosiree-e2e] ·[WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/db_dev.go:81: provisioning a new private database with token 45gXU6rZFck3o0tAcbMsTLXhBspgjG
115.76 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/store/sqlite/sqlite.go:24: reading DB from :memory:
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET / 303 33
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /login 200 4498
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/css/solid.min.css 200 572
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/fontawesome@6.2.0/css/fontawesome.min.css 200 80651
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/css/style.css 200 574
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813
115.77 s[grosiree-e2e] [WebServer] 2026/04/27 00:42:14 codeberg.org/mtlynch/grosiree/handlers/middleware.go:13: GET /static/js/confirm-dialog.js 200 3023