Skip to content

feat(analytics): gzip event batch body to bypass adblockers (#1407) #12679

feat(analytics): gzip event batch body to bypass adblockers (#1407)

feat(analytics): gzip event batch body to bypass adblockers (#1407) #12679

Triggered via push May 5, 2026 23:38
Status Failure
Total duration 1h 14m 38s
Artifacts
Matrix: build
Fit to window
Zoom out
Zoom in

Annotations

12 errors and 2 warnings
tests/backend/endpoints/api/v1/auth/password/sign-up.test.ts > should sign up new users: apps/e2e/tests/helpers.ts#L254
StackAssertionError: Expected at least 1 messages with subject containing "Verify your email", but found 0 This is likely an error in Stack. Please make sure you are running the newest version and report it. ❯ Mailbox.waitForMessagesWithSubjectCount tests/helpers.ts:254:13 ❯ Mailbox.waitForMessagesWithSubject tests/helpers.ts:240:14 ❯ Object.signUpWithEmail tests/backend/backend-helpers.ts:586:9 ❯ tests/backend/endpoints/api/v1/auth/password/sign-up.test.ts:7:15 ⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯ Serialized Error: { extraData: { messages: [] }, customCaptureExtraArgs: [ { messages: [] } ] }
tests/backend/endpoints/api/v1/auth/otp/sign-in.test.ts > should sign in users created with the server API even if sign up is disabled: apps/e2e/tests/backend/backend-helpers.ts#L494
StackAssertionError: Sign-in code message not found after 40 attempts This is likely an error in Stack. Please make sure you are running the newest version and report it. ❯ sendSignInCode tests/backend/backend-helpers.ts:494:17 ❯ Object.signIn tests/backend/backend-helpers.ts:507:33 ❯ tests/backend/endpoints/api/v1/auth/otp/sign-in.test.ts:72:16 ⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯⎯ Serialized Error: { extraData: { response: { status: 200, headers: { constructor: 'Function<Headers>', append: 'Function<append>', delete: 'Function<delete>', get: 'Function<get>', has: 'Function<has>', set: 'Function<set>', getSetCookie: 'Function<getSetCookie>', keys: 'Function<keys>', values: 'Function<values>', entries: 'Function<entries>', forEach: 'Function<forEach>' }, body: { nonce: 'tzk6na8ex0342dxa8288jmzcm7wwcrdp6yk2nz0' }, fromRequestInit: { method: 'POST', body: '{"email":"default-mailbox--b5369b75-7980-4bf4-986c-519c524448f9@stack-generated.example.com","callback_url":"http://localhost:12345/some-callback-url","bot_challenge_token":"mock-turnstile-ok:send_magic_link_email"}', headers: { 'content-type': 'application/json', 'x-stack-access-type': 'client', 'x-stack-project-id': '122573fd-5709-44e4-b5ef-e9460a3463a8', 'x-stack-admin-access-token': '***', 'x-stack-allow-anonymous-user': 'true' } }, constructor: 'Function<NiceResponse>', getNicifiableKeys: 'Function<getNicifiableKeys>', follow: 'Function<follow>' }, messages: [], outboxEmails: [ { id: 'e4d01911-460a-4e3c-9572-394bcd04ae58', created_at_millis: 1778027636117, updated_at_millis: 1778027637837, tsx_source: 'import { type } from \'arktype\';\nimport { Section, Hr, Text, Heading } from \'@react-email/components\';\nimport { Subject, NotificationCategory, Props } from \'@stackframe/emails\';\n\nexport const variablesSchema = type({\n magicLink: \'string\',\n otp: \'string\',\n});\n\nexport function EmailTemplate({ user, project, variables }: Props<typeof variablesSchema.infer>) {\n return (\n <>\n <Subject value={"Sign in to " + project.displayName + ": Your code is " + variables.otp} />\n <NotificationCategory value="Transactional" />\n <div className="font-sans text-base font-normal tracking-[0.15008px] leading-6 m-0 py-8 w-full min-h-full">\n <Section className="mx-auto">\n <Heading as="h3" className="font-sans font-bold text-xl text-center px-6 py-4 m-0">\n Sign in to {project.displayName}\n </Heading>\n <p className="text-sm font-sans font-normal text-center px-6 py-4 m-0 opacity-80">\n Hi{user.displayName ? ", " + user.displayName : ""}! This is your one-time-password for signing in:\n </p>\n <p className="text-2xl font-mono font-bold text-center px-6 py-4 m-0">\n {variables.otp}\n </p>\n <p className="text-sm font-sans font-normal text-center px-6 py-4 m-0">\n Or you can click on{\' \'}\n <a\n key={20}\n href={variables.magicLink}\n rel="noopener noreferrer"\n className="text-blue-600 underline"\n >\n this link\n </a>{\' \'}\n to sign in\n </p>\n <Hr className="px-6 py-4 opacity-20" />\n <p className="text-xs font-sans font-normal text-center px-6 pt-1 pb-6 m-0 opacity-60">\n If you were not expecting this email, you can safely ignore it.\n </p>\n </Section>\n </div>\n </>\n );\n}\n\nEmailTemplate.PreviewVariables = {\n magicLink: "#",\n otp: "3SLSWZ"\n} satisfies typeof variablesSchema.infer', theme_id: '1df07ae6-abf3-4a40-83a5-a1a2cbe336ac', to: { type: 'custom-emails', emails: [ 'default-mailbox--b5369b75-7980-4bf4-986c-519c524448f9@stack-generated.example.com' ] }, variables: { otp: '736EMN', magicLink: 'http://localhost:12345/some-callback-url?code=736emntzk6na8ex0342dxa8288jmzcm7wwcrdp6yk2nz0' }, skip_deliverability_check: true, scheduled_at_millis: 1778027636116, created_with: 'programmatic-cal
tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts > with valid credentials > should return 200 and process dry run request: apps/e2e/tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts#L127
Error: Snapshot `with valid credentials > should return 200 and process dry run request 30` mismatched - Expected + Received - [ - { - "emails": [ - { - "subject": "", - "to": ["User ID: <stripped UUID>"], - }, - { - "subject": "Verify your email at Test Failed Emails Project", - "to": ["default-mailbox--<stripped UUID>@stack-generated.example.com"], - }, - ], - "project_id": "<stripped UUID>", - "tenancy_id": "<stripped UUID>", - "tenant_owner_emails": [ - "default-mailbox--<stripped UUID>@stack-generated.example.com", - "default-mailbox--<stripped UUID>@stack-generated.example.com", - ], - }, - ] + [] ❯ testFailedEmails tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:127:39 ❯ it.repeats tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:158:37
tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts > with valid credentials > should return 200 and process dry run request: apps/e2e/tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts#L127
Error: Snapshot `with valid credentials > should return 200 and process dry run request 21` mismatched - Expected + Received [ { "emails": [ { - "subject": "", - "to": ["User ID: <stripped UUID>"], - }, - { "subject": "Verify your email at Test Failed Emails Project", "to": ["default-mailbox--<stripped UUID>@stack-generated.example.com"], }, ], "project_id": "<stripped UUID>", "tenancy_id": "<stripped UUID>", - "tenant_owner_emails": [ - "default-mailbox--<stripped UUID>@stack-generated.example.com", - "default-mailbox--<stripped UUID>@stack-generated.example.com", - ], + "tenant_owner_emails": ["default-mailbox--<stripped UUID>@stack-generated.example.com"], }, ] ❯ testFailedEmails tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:127:39 ❯ it.repeats tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:158:37
tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts > with valid credentials > should return 200 and process dry run request: apps/e2e/tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts#L127
Error: Snapshot `with valid credentials > should return 200 and process dry run request 17` mismatched - Expected + Received [ { "emails": [ { - "subject": "", - "to": ["User ID: <stripped UUID>"], - }, - { "subject": "Verify your email at Test Failed Emails Project", "to": ["default-mailbox--<stripped UUID>@stack-generated.example.com"], }, ], "project_id": "<stripped UUID>", "tenancy_id": "<stripped UUID>", - "tenant_owner_emails": [ - "default-mailbox--<stripped UUID>@stack-generated.example.com", - "default-mailbox--<stripped UUID>@stack-generated.example.com", - ], + "tenant_owner_emails": ["default-mailbox--<stripped UUID>@stack-generated.example.com"], }, ] ❯ testFailedEmails tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:127:39 ❯ it.repeats tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:158:37
tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts > with valid credentials > should return 200 and process dry run request: apps/e2e/tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts#L127
Error: Snapshot `with valid credentials > should return 200 and process dry run request 13` mismatched - Expected + Received [ { "emails": [ { - "subject": "", - "to": ["User ID: <stripped UUID>"], - }, - { "subject": "Verify your email at Test Failed Emails Project", "to": ["default-mailbox--<stripped UUID>@stack-generated.example.com"], }, ], "project_id": "<stripped UUID>", "tenancy_id": "<stripped UUID>", - "tenant_owner_emails": [ - "default-mailbox--<stripped UUID>@stack-generated.example.com", - "default-mailbox--<stripped UUID>@stack-generated.example.com", - ], + "tenant_owner_emails": ["default-mailbox--<stripped UUID>@stack-generated.example.com"], }, ] ❯ testFailedEmails tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:127:39 ❯ it.repeats tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:158:37
tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts > with valid credentials > should return 200 and process dry run request: apps/e2e/tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts#L127
Error: Snapshot `with valid credentials > should return 200 and process dry run request 9` mismatched - Expected + Received [ { "emails": [ { - "subject": "", - "to": ["User ID: <stripped UUID>"], - }, - { "subject": "Verify your email at Test Failed Emails Project", "to": ["default-mailbox--<stripped UUID>@stack-generated.example.com"], }, ], "project_id": "<stripped UUID>", "tenancy_id": "<stripped UUID>", - "tenant_owner_emails": [ - "default-mailbox--<stripped UUID>@stack-generated.example.com", - "default-mailbox--<stripped UUID>@stack-generated.example.com", - ], + "tenant_owner_emails": ["default-mailbox--<stripped UUID>@stack-generated.example.com"], }, ] ❯ testFailedEmails tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:127:39 ❯ it.repeats tests/backend/endpoints/api/v1/internal/failed-emails-digest.test.ts:158:37
tests/backend/endpoints/api/v1/emails/delivery-info.test.ts > with valid credentials > should track sent emails: apps/e2e/tests/backend/endpoints/api/v1/emails/delivery-info.test.ts#L178
Error: Snapshot `with valid credentials > should track sent emails 3` mismatched - Expected + Received @@ -4,32 +4,32 @@ "capacity": { "boost_expires_at": null, "boost_multiplier": 1, "is_boost_active": false, "penalty_factor": 1, - "rate_per_second": 27.777779320987655, + "rate_per_second": 27.77777777777778, }, "stats": { "day": { "bounced": 0, "marked_as_spam": 0, - "sent": 1, + "sent": 0, }, "hour": { "bounced": 0, "marked_as_spam": 0, - "sent": 1, + "sent": 0, }, "month": { "bounced": 0, "marked_as_spam": 0, - "sent": 1, + "sent": 0, }, "week": { "bounced": 0, "marked_as_spam": 0, - "sent": 1, + "sent": 0, }, }, }, "headers": Headers { <some fields may have been hidden> }, } ❯ tests/backend/endpoints/api/v1/emails/delivery-info.test.ts:178:22
tests/backend/endpoints/api/v1/internal-metrics.test.ts > should handle anonymous users with activity correctly: apps/e2e/tests/backend/endpoints/api/v1/internal-metrics.test.ts#L311
AssertionError: expected +0 to be 1 // Object.is equality - Expected + Received - 1 + 0 ❯ it.timeout tests/backend/endpoints/api/v1/internal-metrics.test.ts:311:29
tests/backend/endpoints/api/v1/internal-metrics.test.ts > should return metrics data with users: apps/e2e/tests/backend/endpoints/api/v1/internal-metrics.test.ts#L179
Error: Snapshot `should return metrics data with users > metrics_result_with_users 1` mismatched - Expected + Received @@ -18,20 +18,10 @@ "primary_email": "mailbox-2--<stripped UUID>@stack-generated.example.com", "profile_image_url": null, "signed_up_at_millis": <stripped field 'signed_up_at_millis'>, }, ], - "CH": [ - { - "display_name": null, - "id": "<stripped UUID>", - "last_active_at_millis": <stripped field 'last_active_at_millis'>, - "primary_email": "mailbox-3--<stripped UUID>@stack-generated.example.com", - "profile_image_url": null, - "signed_up_at_millis": <stripped field 'signed_up_at_millis'>, - }, - ], }, "analytics_overview": { "anonymous_visitors_fallback": 0, "avg_session_seconds": 0, "daily_anonymous_visitors_fallback": [ @@ -3021,12 +3011,9 @@ "server_metadata": null, "signed_up_at_millis": <stripped field 'signed_up_at_millis'>, }, ], "total_users": 9, - "users_by_country": { - "AQ": 2, - "CH": 1, - }, + "users_by_country": { "AQ": 2 }, }, "headers": Headers { <some fields may have been hidden> }, } ❯ it.timeout tests/backend/endpoints/api/v1/internal-metrics.test.ts:179:20
E2E Tests (Node 22.x, Freestyle prod)
The strategy configuration was canceled because "build._22_x_mock" failed
E2E Tests (Node 22.x, Freestyle prod)
The operation was canceled.
E2E Tests (Node 22.x, Freestyle mock)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: JarvusInnovations/background-action@v1.0.7, pnpm/action-setup@v4. Actions will be forced to run with Node.js 24 by default starting June 2nd, 2026. Node.js 20 will be removed from the runner on September 16th, 2026. Please check if updated versions of these actions are available that support Node.js 24. To opt into Node.js 24 now, set the FORCE_JAVASCRIPT_ACTIONS_TO_NODE24=true environment variable on the runner or in your workflow file. Once Node.js 24 becomes the default, you can temporarily opt out by setting ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION=true. For more information see: https://github.blog/changelog/2025-09-19-deprecation-of-node-20-on-github-actions-runners/
E2E Tests (Node 22.x, Freestyle prod)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: JarvusInnovations/background-action@v1.0.7, pnpm/action-setup@v4. Actions will be forced to run with Node.js 24 by default starting June 2nd, 2026. Node.js 20 will be removed from the runner on September 16th, 2026. Please check if updated versions of these actions are available that support Node.js 24. To opt into Node.js 24 now, set the FORCE_JAVASCRIPT_ACTIONS_TO_NODE24=true environment variable on the runner or in your workflow file. Once Node.js 24 becomes the default, you can temporarily opt out by setting ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION=true. For more information see: https://github.blog/changelog/2025-09-19-deprecation-of-node-20-on-github-actions-runners/