Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
34 changes: 34 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -172,6 +172,9 @@ jobs:
changed_bun_integration:
${{ needs.job_get_metadata.outputs.changed_ci == 'true' || contains(steps.checkForAffected.outputs.affected,
'@sentry-internal/bun-integration-tests') }}
changed_deno_integration:
${{ needs.job_get_metadata.outputs.changed_ci == 'true' || contains(steps.checkForAffected.outputs.affected,
'@sentry-internal/deno-integration-tests') }}
changed_browser_integration:
${{ needs.job_get_metadata.outputs.changed_ci == 'true' || contains(steps.checkForAffected.outputs.affected,
'@sentry-internal/browser-integration-tests') }}
Expand Down Expand Up @@ -953,6 +956,36 @@ jobs:
working-directory: dev-packages/bun-integration-tests
run: yarn test

job_deno_integration_tests:
name: Deno Integration Tests
needs: [job_get_metadata, job_build]
if: needs.job_build.outputs.changed_deno_integration == 'true' || github.event_name != 'pull_request'
runs-on: ubuntu-24.04
timeout-minutes: 15
steps:
- name: Check out current commit (${{ needs.job_get_metadata.outputs.commit_label }})
uses: actions/checkout@v6
with:
ref: ${{ env.HEAD_COMMIT }}
- name: Set up Node
uses: actions/setup-node@v6
with:
node-version-file: 'package.json'
- name: Set up Deno
uses: denoland/setup-deno@v2.0.4
with:
deno-version: 'v2.8.0'
- name: Restore caches
uses: ./.github/actions/restore-cache
with:
dependency_cache_key: ${{ needs.job_build.outputs.dependency_cache_key }}
- name: Build @sentry/deno
working-directory: packages/deno
run: yarn build
- name: Run integration tests
working-directory: dev-packages/deno-integration-tests
run: yarn test

job_build_tarballs:
name: Build tarballs
# We want to run this if:
Expand Down Expand Up @@ -1252,6 +1285,7 @@ jobs:
job_cloudflare_integration_tests,
job_bundler_plugin_integration_tests,
job_bun_integration_tests,
job_deno_integration_tests,
job_browser_playwright_tests,
job_browser_loader_tests,
job_e2e_tests,
Expand Down
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ tmp.js
packages/deno/build-types
packages/deno/build-test
packages/deno/lib.deno.d.ts
dev-packages/deno-integration-tests/lib.deno.d.ts
deno.lock

# gatsby
Expand Down
25 changes: 25 additions & 0 deletions dev-packages/deno-integration-tests/.oxlintrc.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
{
"$schema": "../../node_modules/oxlint/configuration_schema.json",
"extends": ["../.oxlintrc.json"],
"env": {
"node": true
},
"overrides": [
{
"files": ["suites/**/*.ts", "suites/**/*.mjs"],
"globals": {
"Deno": "readonly"
},
"rules": {
"typescript/ban-ts-comment": [
"error",
{
"ts-ignore": "allow-with-description",
"ts-expect-error": true
}
],
"import/first": "off"
}
}
]
}
25 changes: 25 additions & 0 deletions dev-packages/deno-integration-tests/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
{

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

l: Could you add this folder into the CODEOWNERS file?

"name": "@sentry-internal/deno-integration-tests",
"version": "10.62.0",

@JPeer264 JPeer264 Jul 1, 2026

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

m: Just that we don't forget to update. 10.63.0 has been released recently (same for the dependencies below)

"license": "MIT",
"engines": {
"node": ">=18"
},
"private": true,
"scripts": {
"deno-types": "node ./scripts/download-deno-types.mjs",
"install:deno": "node ./scripts/install-deno.mjs",
"lint": "OXLINT_TSGOLINT_DANGEROUSLY_SUPPRESS_PROGRAM_DIAGNOSTICS=true oxlint . --type-aware",
"lint:fix": "OXLINT_TSGOLINT_DANGEROUSLY_SUPPRESS_PROGRAM_DIAGNOSTICS=true oxlint . --fix --type-aware",
"test": "run-s install:deno deno-types test:unit",
"test:unit": "deno test --allow-net --allow-read --allow-run --allow-env --no-check"
},
"dependencies": {
"@sentry/core": "10.62.0",
"@sentry/deno": "10.62.0",
"mysql": "^2.18.1"
Comment thread
cursor[bot] marked this conversation as resolved.
},
"volta": {
"extends": "../../package.json"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
import { existsSync, writeFileSync } from 'fs';
import { download } from './download.mjs';

if (!existsSync('lib.deno.d.ts')) {
const code = await download('https://github.com/denoland/deno/releases/download/v2.8.0/lib.deno.d.ts');
writeFileSync('lib.deno.d.ts', code);
Comment thread
isaacs marked this conversation as resolved.
Dismissed
}
10 changes: 10 additions & 0 deletions dev-packages/deno-integration-tests/scripts/download.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
/** Download a url to a string */
export async function download(url) {
try {
return await fetch(url).then(res => res.text());
} catch (e) {
// eslint-disable-next-line no-console
console.error('Failed to download', url, e);
process.exit(1);
}
}
26 changes: 26 additions & 0 deletions dev-packages/deno-integration-tests/scripts/install-deno.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import { execSync } from 'child_process';

import { download } from './download.mjs';

try {
execSync('deno --version', { stdio: 'inherit' });
} catch {
// eslint-disable-next-line no-console
console.error('Deno is not installed. Installing...');
if (process.platform === 'win32') {
// TODO
// eslint-disable-next-line no-console
console.error('Please install Deno manually: https://docs.deno.com/runtime/manual/getting_started/installation');
process.exit(1);
} else {
const script = await download('https://deno.land/install.sh');

try {
execSync(script, { stdio: 'inherit' });
} catch (e) {
// eslint-disable-next-line no-console
console.error('Failed to install Deno', e);
process.exit(1);
}
}
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// Spawned by orchestrion-mysql.test.ts via `deno run`.
// Spawned by test.ts via `deno run`.
//
// Importing `@sentry/deno/import` FIRST registers the orchestrion module hook,
// so the subsequent `mysql` import is transformed to publish to the
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,11 @@

import { tracingChannel } from 'node:diagnostics_channel';
import type { TransactionEvent } from '@sentry/core';
import type { DenoClient } from '@sentry/deno';
import { getCurrentScope, getGlobalScope, getIsolationScope, init, startSpan } from '@sentry/deno';
import { assert } from 'https://deno.land/std@0.212.0/assert/assert.ts';
import { assertEquals } from 'https://deno.land/std@0.212.0/assert/assert_equals.ts';
import { assertExists } from 'https://deno.land/std@0.212.0/assert/assert_exists.ts';
import type { DenoClient } from '../build/esm/index.js';
import { getCurrentScope, getGlobalScope, getIsolationScope, init, startSpan } from '../build/esm/index.js';

function resetGlobals(): void {
getCurrentScope().clear();
Expand Down Expand Up @@ -65,10 +65,11 @@ Deno.test('denoMysqlIntegration: included in default integrations (Deno 2.8.0+)'
// import inside the entry graph in Deno 2.8.0 through 2.8.2.
// TODO: revisit a `--import` or `--preload` approach once Deno 2.8.3 ships.
Deno.test('@sentry/deno/import: transforms mysql so it publishes the orchestrion channel', async () => {
const scenario = new URL('./orchestrion-mysql/scenario.mjs', import.meta.url);
const scenario = new URL('./scenario.mjs', import.meta.url);

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

l: For this PR its alright, but it feels like if we add more test cases it would be nice if we have a helper for the execution of the scenario.


// packages/deno — where node_modules resolves
const cwd = new URL('../', import.meta.url);
// The package root — where `node_modules` (and thus `@sentry/deno` / `mysql`)
// resolves for the spawned `deno run`.
const cwd = new URL('../../', import.meta.url);

const command = new Deno.Command('deno', {
args: ['run', '--allow-all', scenario.pathname],
Expand Down
8 changes: 8 additions & 0 deletions dev-packages/deno-integration-tests/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "../../tsconfig.json",
"include": ["suites/**/*"],
"compilerOptions": {
"lib": ["esnext"],
"target": "esnext"
}
}
7 changes: 4 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -34,11 +34,11 @@
"dedupe-deps:check": "yarn-deduplicate yarn.lock --list --fail",
"dedupe-deps:fix": "yarn-deduplicate yarn.lock",
"postpublish": "nx run-many -t postpublish --parallel=1",
"test": "nx run-many -t test --exclude \"@sentry-internal/{browser-integration-tests,bun-integration-tests,e2e-tests,integration-shims,node-integration-tests,node-core-integration-tests,cloudflare-integration-tests,bundler-plugin-integration-tests}\"",
"test": "nx run-many -t test --exclude \"@sentry-internal/{browser-integration-tests,bun-integration-tests,deno-integration-tests,e2e-tests,integration-shims,node-integration-tests,node-core-integration-tests,cloudflare-integration-tests,bundler-plugin-integration-tests}\"",
"test:scripts": "vitest run scripts/*.test.ts",
"test:unit": "nx run-many -t test:unit --exclude \"@sentry-internal/{browser-integration-tests,bun-integration-tests,e2e-tests,integration-shims,node-integration-tests,node-core-integration-tests,cloudflare-integration-tests,bundler-plugin-integration-tests}\"",
"test:unit": "nx run-many -t test:unit --exclude \"@sentry-internal/{browser-integration-tests,bun-integration-tests,deno-integration-tests,e2e-tests,integration-shims,node-integration-tests,node-core-integration-tests,cloudflare-integration-tests,bundler-plugin-integration-tests}\"",
"test:update-snapshots": "nx run-many -t test:update-snapshots",
"test:pr": "nx affected -t test --exclude \"@sentry-internal/{browser-integration-tests,bun-integration-tests,e2e-tests,integration-shims,node-integration-tests,node-core-integration-tests,cloudflare-integration-tests,bundler-plugin-integration-tests}\"",
"test:pr": "nx affected -t test --exclude \"@sentry-internal/{browser-integration-tests,bun-integration-tests,deno-integration-tests,e2e-tests,integration-shims,node-integration-tests,node-core-integration-tests,cloudflare-integration-tests,bundler-plugin-integration-tests}\"",
"test:pr:browser": "UNIT_TEST_ENV=browser ts-node ./scripts/ci-unit-tests.ts --affected",
"test:pr:node": "UNIT_TEST_ENV=node ts-node ./scripts/ci-unit-tests.ts --affected",
"test:ci:browser": "UNIT_TEST_ENV=browser ts-node ./scripts/ci-unit-tests.ts",
Expand Down Expand Up @@ -105,6 +105,7 @@
"dev-packages/e2e-tests",
"dev-packages/node-integration-tests",
"dev-packages/bun-integration-tests",
"dev-packages/deno-integration-tests",
Comment thread
cursor[bot] marked this conversation as resolved.
"dev-packages/cloudflare-integration-tests",
"dev-packages/node-core-integration-tests",
"dev-packages/test-utils",
Expand Down
3 changes: 0 additions & 3 deletions packages/deno/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -31,9 +31,6 @@
"@sentry/core": "10.62.0",
"@sentry/server-utils": "10.62.0"
},
"devDependencies": {

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

farewell devDependency 👋

"mysql": "^2.18.1"
},
"scripts": {
"deno-types": "node ./scripts/download-deno-types.mjs",
"build": "run-s build:transpile build:types",
Expand Down