$ /nix/store/wkkwxc04gdw6b263l1h29pjarjnjdyb6-coreutils-9.8/bin/timeout --kill-after=15s 1800s /nix/store/99b1z08awpxj8b6mzggn59gp1shljnff-nix-2.34.5/bin/nix --extra-experimental-features nix-command --extra-experimental-features flakes build --no-link git+https://codeberg.org/mtlynch/little-moments?ref=email-auth&rev=aa20d0aded934004aaa4cfffebb5b4df1a33ee7d#packages.x86_64-linux.e2e-tests --print-build-logs these 3 derivations will be built: /nix/store/8s5qn27mgprdrf59qqb75q0pgh7z7xb9-import-from-tinybeans-0.0.1-go-modules.drv /nix/store/lqx19x8l1kmasifhgmls1jwl32k3xi0a-import-from-tinybeans-0.0.1.drv /nix/store/2h9d0pvks044fm9lhprmz1srsy4a5m9v-little-moments-e2e-0.0.1.drv building '/nix/store/8s5qn27mgprdrf59qqb75q0pgh7z7xb9-import-from-tinybeans-0.0.1-go-modules.drv'... import-from-tinybeans> Running phase: unpackPhase import-from-tinybeans> unpacking source archive /nix/store/izqk69cdsb14d8a9c5rjbn7cxk4h6wxf-source import-from-tinybeans> source root is source import-from-tinybeans> Running phase: patchPhase import-from-tinybeans> Running phase: updateAutotoolsGnuConfigScriptsPhase import-from-tinybeans> Running phase: configurePhase import-from-tinybeans> Running phase: buildPhase import-from-tinybeans> go: downloading codeberg.org/mtlynch/go-evolutionary-migrate v0.0.1 import-from-tinybeans> go: downloading golang.org/x/image v0.38.0 import-from-tinybeans> go: downloading github.com/ncruces/go-sqlite3 v0.22.0 import-from-tinybeans> go: downloading github.com/google/uuid v1.6.0 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2 v1.41.5 import-from-tinybeans> go: downloading github.com/mtlynch/simpleauth/v2 v2.0.0-20241108014613-2f32145d692d import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/config v1.32.13 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/credentials v1.19.13 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/service/s3 v1.97.3 import-from-tinybeans> go: downloading github.com/mtlynch/jeff v0.2.4 import-from-tinybeans> go: downloading github.com/tinylib/msgp v1.1.6 import-from-tinybeans> go: downloading github.com/philhofer/fwd v1.1.1 import-from-tinybeans> go: downloading golang.org/x/sys v0.29.0 import-from-tinybeans> go: downloading github.com/tetratelabs/wazero v1.8.2 import-from-tinybeans> go: downloading github.com/ncruces/julianday v1.0.0 import-from-tinybeans> go: downloading github.com/aws/smithy-go v1.24.2 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.7.8 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/internal/configsources v1.4.21 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/internal/v4a v1.4.22 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/service/internal/accept-encoding v1.13.7 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/service/internal/checksum v1.9.13 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.13.21 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/service/internal/s3shared v1.19.21 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/internal/ini v1.8.6 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/service/signin v1.0.9 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/service/sso v1.30.14 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/service/ssooidc v1.35.18 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/feature/ec2/imds v1.18.21 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/service/sts v1.41.10 import-from-tinybeans> go: downloading github.com/aws/aws-sdk-go-v2/internal/endpoints/v2 v2.7.21 import-from-tinybeans> Running phase: installPhase import-from-tinybeans (post)> Uploading paths from nix-ci to the NixCI cache /nix/store/s5hgf9aihgdwxdy13sjln8l9az2cq20i-import-from-tinybeans-0.0.1-go-modules import-from-tinybeans (post)> warning: 'warn-short-path-literals' is deprecated, use 'lint-short-path-literals = ignore' instead import-from-tinybeans (post)> copying 1 paths... import-from-tinybeans (post)> copying path '/nix/store/s5hgf9aihgdwxdy13sjln8l9az2cq20i-import-from-tinybeans-0.0.1-go-modules' to 'https://cache.nix-ci.com'... import-from-tinybeans (post)> warning: 'warn-short-path-literals' is deprecated, use 'lint-short-path-literals = ignore' instead import-from-tinybeans (post)> copying 1 paths... import-from-tinybeans (post)> copying path '/nix/store/8s5qn27mgprdrf59qqb75q0pgh7z7xb9-import-from-tinybeans-0.0.1-go-modules.drv' to 'https://cache.nix-ci.com'... building '/nix/store/lqx19x8l1kmasifhgmls1jwl32k3xi0a-import-from-tinybeans-0.0.1.drv'... import-from-tinybeans> Running phase: unpackPhase import-from-tinybeans> unpacking source archive /nix/store/izqk69cdsb14d8a9c5rjbn7cxk4h6wxf-source import-from-tinybeans> source root is source import-from-tinybeans> Running phase: patchPhase import-from-tinybeans> Running phase: updateAutotoolsGnuConfigScriptsPhase import-from-tinybeans> Running phase: configurePhase import-from-tinybeans> Running phase: buildPhase import-from-tinybeans> Building subPackage ./cmd/import-from-tinybeans import-from-tinybeans> Running phase: checkPhase import-from-tinybeans> ? codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans [no test files] import-from-tinybeans> Running phase: installPhase import-from-tinybeans> Running phase: fixupPhase import-from-tinybeans> shrinking RPATHs of ELF executables and libraries in /nix/store/crkqf9ml9vgrfc5ph1dy9a0218bxiqk9-import-from-tinybeans-0.0.1 import-from-tinybeans> shrinking /nix/store/crkqf9ml9vgrfc5ph1dy9a0218bxiqk9-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/crkqf9ml9vgrfc5ph1dy9a0218bxiqk9-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/crkqf9ml9vgrfc5ph1dy9a0218bxiqk9-import-from-tinybeans-0.0.1 import-from-tinybeans> stripping (with command strip and flags -S -p) in /nix/store/crkqf9ml9vgrfc5ph1dy9a0218bxiqk9-import-from-tinybeans-0.0.1/bin import-from-tinybeans (post)> Uploading paths from nix-ci to the NixCI cache /nix/store/crkqf9ml9vgrfc5ph1dy9a0218bxiqk9-import-from-tinybeans-0.0.1 import-from-tinybeans (post)> warning: 'warn-short-path-literals' is deprecated, use 'lint-short-path-literals = ignore' instead import-from-tinybeans (post)> copying 1 paths... import-from-tinybeans (post)> copying path '/nix/store/crkqf9ml9vgrfc5ph1dy9a0218bxiqk9-import-from-tinybeans-0.0.1' to 'https://cache.nix-ci.com'... import-from-tinybeans (post)> warning: 'warn-short-path-literals' is deprecated, use 'lint-short-path-literals = ignore' instead import-from-tinybeans (post)> copying 0 paths... building '/nix/store/2h9d0pvks044fm9lhprmz1srsy4a5m9v-little-moments-e2e-0.0.1.drv'... little-moments-e2e> Running phase: unpackPhase little-moments-e2e> unpacking source archive /nix/store/izqk69cdsb14d8a9c5rjbn7cxk4h6wxf-source little-moments-e2e> source root is source little-moments-e2e> Running 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 668ms 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/which/bin/node-which: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" little-moments-e2e> node_modules/js-yaml/bin/js-yaml.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" little-moments-e2e> node_modules/playwright-core/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" little-moments-e2e> node_modules/playwright-core/lib/utilsBundleImpl/xdg-open: interpreter directive changed from "#!/bin/sh" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/sh" little-moments-e2e> node_modules/playwright-core/bin/reinstall_msedge_beta_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" little-moments-e2e> node_modules/playwright-core/bin/reinstall_msedge_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_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_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_stable_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" little-moments-e2e> node_modules/playwright-core/bin/reinstall_msedge_stable_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" little-moments-e2e> node_modules/playwright-core/bin/reinstall_chrome_beta_linux.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" little-moments-e2e> node_modules/playwright-core/bin/reinstall_msedge_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_chrome_stable_mac.sh: interpreter directive changed from "#!/usr/bin/env bash" to "/nix/store/rlq03x4cwf8zn73hxaxnx0zn5q9kifls-bash-5.3p3/bin/bash" little-moments-e2e> node_modules/playwright-core/bin/reinstall_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/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" little-moments-e2e> node_modules/ulid/bin/cli.js: interpreter directive changed from "#! /usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" little-moments-e2e> node_modules/acorn/bin/acorn: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" little-moments-e2e> node_modules/eslint/bin/eslint.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" little-moments-e2e> node_modules/@playwright/test/cli.js: interpreter directive changed from "#!/usr/bin/env node" to "/nix/store/lgggxsrdzisnbligi7irlh4qmqczs0xk-nodejs-24.11.1/bin/node" little-moments-e2e> node_modules/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> 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> Running phase: updateAutotoolsGnuConfigScriptsPhase little-moments-e2e> Running phase: configurePhase little-moments-e2e> no configure script, doing nothing little-moments-e2e> Running phase: buildPhase little-moments-e2e> no Makefile or custom buildPhase, doing nothing little-moments-e2e> Running phase: checkPhase little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied a82271e4-bc65-480c-af39-738a407b3b5b-full.avif little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:121: copied a82271e4-bc65-480c-af39-738a407b3b5b-150px.jpg little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-full.mp4 little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-150px.jpg little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 9f15c4cf-6b71-4db0-b972-ac101951155a-full.mp4 little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:128: copied 9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-150px.jpg little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied a1bfb899-880c-49e2-b9c5-71216b531e3f-full.jpg little-moments-e2e> 2026/04/12 13:27:56 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied a1bfb899-880c-49e2-b9c5-71216b531e3f-850px.jpg little-moments-e2e> 2026/04/12 13:27:57 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg little-moments-e2e> 2026/04/12 13:27:57 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied a1bfb899-880c-49e2-b9c5-71216b531e3f-150px.jpg little-moments-e2e> 2026/04/12 13:27:57 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:100: copied 6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-full.jpg little-moments-e2e> 2026/04/12 13:27:57 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:108: copied 6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-850px.jpg little-moments-e2e> 2026/04/12 13:27:57 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg little-moments-e2e> 2026/04/12 13:27:57 codeberg.org/mtlynch/little-moments/cmd/import-from-tinybeans/main.go:114: copied 6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-150px.jpg little-moments-e2e> 2026/04/12 13:27:57 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/04/12 13:27:57 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> [WebServer] 2026/04/12 13:27:59 codeberg.org/mtlynch/little-moments/cmd/app/main.go:20: starting little-moments server little-moments-e2e> [WebServer] 2026/04/12 13:27:59 codeberg.org/mtlynch/little-moments/store/sqlite/sqlite.go:18: reading DB from /build/source/test-imported-media/test-store.db little-moments-e2e> [WebServer] 2026/04/12 13:27:59 codeberg.org/mtlynch/little-moments/handlers/csp.go:43: CSP media origin: "" little-moments-e2e> [WebServer] 2026/04/12 13:27:59 codeberg.org/mtlynch/little-moments/cmd/app/main.go:78: listening on http://localhost:6001 little-moments-e2e> little-moments-e2e> Running 14 tests using 1 worker little-moments-e2e> Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set. little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 303 33 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:00 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6740 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /logout 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:01 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /logout 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 303 33 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:02 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6744 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:03 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1000 200 7547 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/swipe-events.js 200 1608 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-full.avif 200 262753 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1001 200 8858 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/swipe-events.js 200 1608 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-full.mp4 206 13136 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1002 200 7794 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-full.mp4 206 12623 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1003 200 9236 little-moments-e2e> [WebServer] 2026/04/12 13:28:04 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-850px.jpg 200 14082 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1002 200 7786 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6740 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1002 200 7786 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/swipe-events.js 200 1608 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-full.mp4 206 12623 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1003 200 9236 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-850px.jpg 200 14082 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1002 200 7786 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:05 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6740 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1002 200 7786 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/swipe-events.js 200 1608 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-full.mp4 206 12623 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1003 200 9236 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-850px.jpg 200 14082 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1002 200 7786 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:06 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1000 200 7555 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/swipe-events.js 200 1608 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-full.avif 200 262753 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1001 200 8858 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-full.mp4 206 13136 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1004 200 7604 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-850px.jpg 200 14295 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:07 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1004 200 7604 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/swipe-events.js 200 1608 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-850px.jpg 200 14295 little-moments-e2e> ·[WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login 200 2970 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/css/bootstrap.min.css 200 194901 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/css/style.css 200 25 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/bootstrap@5.2.2/js/bootstrap.bundle.min.js 200 80496 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx@2.0.4/htmx.min.js 200 50917 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/htmx-ext-response-targets@2.0.0/response-targets.js 200 3722 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/third-party/lucide@1.6.0/lucide.min.js 200 397128 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-ext/clear-before-send.js 200 775 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/lucide.js 200 478 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/htmx-settings.js 200 813 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/store/sqlite/login_tokens.go:17: inserting login token for user 700001 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/login_dev.go:47: login: generated token for homer@example.com (user 700001) little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /login/confirm 200 2840 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/login.go:88: login confirm: consumed token for user 700001 (homer@example.com) little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: POST /login/confirm 303 0 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6736 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a82271e4-bc65-480c-af39-738a407b3b5b-250px.jpg 200 3217 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/f39707e9-6cb8-4aa9-b69e-2e0c1e3e17a2-thumb-250px.jpg 200 3190 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/9f15c4cf-6b71-4db0-b972-ac101951155a-thumb-250px.jpg 200 3063 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-250px.jpg 200 3134 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/6a4b3ba2-4adf-4b14-b820-ea58772aa7a4-250px.jpg 200 3228 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET / 200 6740 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /m/1003 200 9252 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /static/js/swipe-events.js 200 1608 little-moments-e2e> [WebServer] 2026/04/12 13:28:08 codeberg.org/mtlynch/little-moments/handlers/middleware.go:13: GET /media/a1bfb899-880c-49e2-b9c5-71216b531e3f-850px.jpg 200 14082 little-moments-e2e> · little-moments-e2e> 14 passed (9.8s) little-moments-e2e> Running phase: installPhase little-moments-e2e> Running phase: fixupPhase little-moments-e2e> shrinking RPATHs of ELF executables and libraries in /nix/store/fnnkzrh8611946v593w2ialy12gi5wvw-little-moments-e2e-0.0.1 little-moments-e2e> checking for references to /build/ in /nix/store/fnnkzrh8611946v593w2ialy12gi5wvw-little-moments-e2e-0.0.1... little-moments-e2e> patching script interpreter paths in /nix/store/fnnkzrh8611946v593w2ialy12gi5wvw-little-moments-e2e-0.0.1 little-moments-e2e (post)> Uploading paths from nix-ci to the NixCI cache /nix/store/fnnkzrh8611946v593w2ialy12gi5wvw-little-moments-e2e-0.0.1 little-moments-e2e (post)> warning: 'warn-short-path-literals' is deprecated, use 'lint-short-path-literals = ignore' instead little-moments-e2e (post)> copying 1 paths... little-moments-e2e (post)> copying path '/nix/store/fnnkzrh8611946v593w2ialy12gi5wvw-little-moments-e2e-0.0.1' to 'https://cache.nix-ci.com'... little-moments-e2e (post)> warning: 'warn-short-path-literals' is deprecated, use 'lint-short-path-literals = ignore' instead little-moments-e2e (post)> copying 2 paths... little-moments-e2e (post)> copying path '/nix/store/9mgxgxc4dnmm1sinpma4aqw5cm4g6ss7-little-moments-e2e-0.0.1-npm-deps.drv' to 'https://cache.nix-ci.com'... little-moments-e2e (post)> copying path '/nix/store/2h9d0pvks044fm9lhprmz1srsy4a5m9v-little-moments-e2e-0.0.1.drv' to 'https://cache.nix-ci.com'...