@trigger.dev/build 0.0.0-v3-prerelease-20250108142426 → 0.0.0-v4-prerelease-20250916125920
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/dist/commonjs/extensions/audioWaveform.js +1 -1
- package/dist/commonjs/extensions/audioWaveform.js.map +1 -1
- package/dist/commonjs/extensions/core/additionalFiles.js +2 -53
- package/dist/commonjs/extensions/core/additionalFiles.js.map +1 -1
- package/dist/commonjs/extensions/core/ffmpeg.d.ts +12 -1
- package/dist/commonjs/extensions/core/ffmpeg.js +34 -2
- package/dist/commonjs/extensions/core/ffmpeg.js.map +1 -1
- package/dist/commonjs/extensions/core/syncEnvVars.d.ts +2 -0
- package/dist/commonjs/extensions/core/syncEnvVars.js +33 -17
- package/dist/commonjs/extensions/core/syncEnvVars.js.map +1 -1
- package/dist/commonjs/extensions/core/vercelSyncEnvVars.d.ts +1 -0
- package/dist/commonjs/extensions/core/vercelSyncEnvVars.js +27 -11
- package/dist/commonjs/extensions/core/vercelSyncEnvVars.js.map +1 -1
- package/dist/commonjs/extensions/lightpanda.d.ts +7 -0
- package/dist/commonjs/extensions/lightpanda.js +30 -0
- package/dist/commonjs/extensions/lightpanda.js.map +1 -0
- package/dist/commonjs/extensions/playwright.d.ts +55 -0
- package/dist/commonjs/extensions/playwright.js +308 -0
- package/dist/commonjs/extensions/playwright.js.map +1 -0
- package/dist/commonjs/internal/additionalFiles.d.ts +6 -0
- package/dist/commonjs/internal/additionalFiles.js +63 -0
- package/dist/commonjs/internal/additionalFiles.js.map +1 -0
- package/dist/commonjs/internal.d.ts +1 -0
- package/dist/commonjs/internal.js +18 -0
- package/dist/commonjs/internal.js.map +1 -0
- package/dist/commonjs/version.js +1 -1
- package/dist/esm/extensions/audioWaveform.js +1 -1
- package/dist/esm/extensions/audioWaveform.js.map +1 -1
- package/dist/esm/extensions/core/additionalFiles.js +2 -53
- package/dist/esm/extensions/core/additionalFiles.js.map +1 -1
- package/dist/esm/extensions/core/ffmpeg.d.ts +12 -1
- package/dist/esm/extensions/core/ffmpeg.js +34 -2
- package/dist/esm/extensions/core/ffmpeg.js.map +1 -1
- package/dist/esm/extensions/core/syncEnvVars.d.ts +2 -0
- package/dist/esm/extensions/core/syncEnvVars.js +33 -17
- package/dist/esm/extensions/core/syncEnvVars.js.map +1 -1
- package/dist/esm/extensions/core/vercelSyncEnvVars.d.ts +1 -0
- package/dist/esm/extensions/core/vercelSyncEnvVars.js +27 -11
- package/dist/esm/extensions/core/vercelSyncEnvVars.js.map +1 -1
- package/dist/esm/extensions/lightpanda.d.ts +7 -0
- package/dist/esm/extensions/lightpanda.js +26 -0
- package/dist/esm/extensions/lightpanda.js.map +1 -0
- package/dist/esm/extensions/playwright.d.ts +55 -0
- package/dist/esm/extensions/playwright.js +305 -0
- package/dist/esm/extensions/playwright.js.map +1 -0
- package/dist/esm/internal/additionalFiles.d.ts +6 -0
- package/dist/esm/internal/additionalFiles.js +60 -0
- package/dist/esm/internal/additionalFiles.js.map +1 -0
- package/dist/esm/internal.d.ts +1 -0
- package/dist/esm/internal.js +2 -0
- package/dist/esm/internal.js.map +1 -0
- package/dist/esm/version.js +1 -1
- package/package.json +49 -6
|
@@ -55,23 +55,14 @@ export function syncEnvVars(fn, options) {
|
|
|
55
55
|
return;
|
|
56
56
|
}
|
|
57
57
|
const $spinner = context.logger.spinner("Invoking syncEnvVars callback");
|
|
58
|
-
const result = await callSyncEnvVarsFn(fn, manifest.deploy.env ?? {}, manifest.environment, context);
|
|
58
|
+
const result = await callSyncEnvVarsFn(fn, manifest.deploy.env ?? {}, manifest.environment, manifest.branch, context);
|
|
59
59
|
if (!result) {
|
|
60
60
|
$spinner.stop("No env vars detected");
|
|
61
61
|
return;
|
|
62
62
|
}
|
|
63
|
-
const env =
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
}
|
|
67
|
-
// Strip out any TRIGGER_ prefix env vars
|
|
68
|
-
if (UNSYNCABLE_ENV_VARS_PREFIXES.some((prefix) => key.startsWith(prefix))) {
|
|
69
|
-
return acc;
|
|
70
|
-
}
|
|
71
|
-
acc[key] = value;
|
|
72
|
-
return acc;
|
|
73
|
-
}, {});
|
|
74
|
-
const numberOfEnvVars = Object.keys(env).length;
|
|
63
|
+
const env = stripUnsyncableEnvVars(result.env);
|
|
64
|
+
const parentEnv = result.parentEnv ? stripUnsyncableEnvVars(result.parentEnv) : undefined;
|
|
65
|
+
const numberOfEnvVars = Object.keys(env).length + (parentEnv ? Object.keys(parentEnv).length : 0);
|
|
75
66
|
if (numberOfEnvVars === 0) {
|
|
76
67
|
$spinner.stop("No env vars detected");
|
|
77
68
|
return;
|
|
@@ -86,21 +77,38 @@ export function syncEnvVars(fn, options) {
|
|
|
86
77
|
id: "sync-env-vars",
|
|
87
78
|
deploy: {
|
|
88
79
|
env,
|
|
80
|
+
parentEnv,
|
|
89
81
|
override: options?.override ?? true,
|
|
90
82
|
},
|
|
91
83
|
});
|
|
92
84
|
},
|
|
93
85
|
};
|
|
94
86
|
}
|
|
95
|
-
|
|
87
|
+
function stripUnsyncableEnvVars(env) {
|
|
88
|
+
return Object.entries(env).reduce((acc, [key, value]) => {
|
|
89
|
+
if (UNSYNCABLE_ENV_VARS.includes(key)) {
|
|
90
|
+
return acc;
|
|
91
|
+
}
|
|
92
|
+
// Strip out any TRIGGER_ prefix env vars
|
|
93
|
+
if (UNSYNCABLE_ENV_VARS_PREFIXES.some((prefix) => key.startsWith(prefix))) {
|
|
94
|
+
return acc;
|
|
95
|
+
}
|
|
96
|
+
acc[key] = value;
|
|
97
|
+
return acc;
|
|
98
|
+
}, {});
|
|
99
|
+
}
|
|
100
|
+
async function callSyncEnvVarsFn(syncEnvVarsFn, env, environment, branch, context) {
|
|
96
101
|
if (syncEnvVarsFn && typeof syncEnvVarsFn === "function") {
|
|
97
|
-
let resolvedEnvVars = {
|
|
102
|
+
let resolvedEnvVars = {
|
|
103
|
+
env: {},
|
|
104
|
+
};
|
|
98
105
|
let result;
|
|
99
106
|
try {
|
|
100
107
|
result = await syncEnvVarsFn({
|
|
101
108
|
projectRef: context.config.project,
|
|
102
109
|
environment,
|
|
103
110
|
env,
|
|
111
|
+
branch,
|
|
104
112
|
});
|
|
105
113
|
}
|
|
106
114
|
catch (error) {
|
|
@@ -117,12 +125,20 @@ async function callSyncEnvVarsFn(syncEnvVarsFn, env, environment, context) {
|
|
|
117
125
|
"value" in item &&
|
|
118
126
|
typeof item.name === "string" &&
|
|
119
127
|
typeof item.value === "string") {
|
|
120
|
-
|
|
128
|
+
if (item.isParentEnv) {
|
|
129
|
+
if (!resolvedEnvVars.parentEnv) {
|
|
130
|
+
resolvedEnvVars.parentEnv = {};
|
|
131
|
+
}
|
|
132
|
+
resolvedEnvVars.parentEnv[item.name] = item.value;
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
resolvedEnvVars.env[item.name] = item.value;
|
|
136
|
+
}
|
|
121
137
|
}
|
|
122
138
|
}
|
|
123
139
|
}
|
|
124
140
|
else if (result) {
|
|
125
|
-
resolvedEnvVars = result;
|
|
141
|
+
resolvedEnvVars.env = result;
|
|
126
142
|
}
|
|
127
143
|
return resolvedEnvVars;
|
|
128
144
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"syncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/syncEnvVars.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"syncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/syncEnvVars.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,16 @@
|
|
|
1
1
|
import { syncEnvVars } from "../core.js";
|
|
2
2
|
export function syncVercelEnvVars(options) {
|
|
3
3
|
const sync = syncEnvVars(async (ctx) => {
|
|
4
|
-
const projectId = options?.projectId ?? process.env.VERCEL_PROJECT_ID ??
|
|
5
|
-
ctx.env.VERCEL_PROJECT_ID;
|
|
4
|
+
const projectId = options?.projectId ?? process.env.VERCEL_PROJECT_ID ?? ctx.env.VERCEL_PROJECT_ID;
|
|
6
5
|
const vercelAccessToken = options?.vercelAccessToken ??
|
|
7
6
|
process.env.VERCEL_ACCESS_TOKEN ??
|
|
8
|
-
ctx.env.VERCEL_ACCESS_TOKEN
|
|
9
|
-
|
|
10
|
-
|
|
7
|
+
ctx.env.VERCEL_ACCESS_TOKEN ??
|
|
8
|
+
process.env.VERCEL_TOKEN;
|
|
9
|
+
const vercelTeamId = options?.vercelTeamId ?? process.env.VERCEL_TEAM_ID ?? ctx.env.VERCEL_TEAM_ID;
|
|
10
|
+
const branch = options?.branch ??
|
|
11
|
+
process.env.VERCEL_PREVIEW_BRANCH ??
|
|
12
|
+
ctx.env.VERCEL_PREVIEW_BRANCH ??
|
|
13
|
+
ctx.branch;
|
|
11
14
|
if (!projectId) {
|
|
12
15
|
throw new Error("syncVercelEnvVars: you did not pass in a projectId or set the VERCEL_PROJECT_ID env var.");
|
|
13
16
|
}
|
|
@@ -18,6 +21,7 @@ export function syncVercelEnvVars(options) {
|
|
|
18
21
|
prod: "production",
|
|
19
22
|
staging: "preview",
|
|
20
23
|
dev: "development",
|
|
24
|
+
preview: "preview",
|
|
21
25
|
};
|
|
22
26
|
const vercelEnvironment = environmentMap[ctx.environment];
|
|
23
27
|
if (!vercelEnvironment) {
|
|
@@ -26,6 +30,7 @@ export function syncVercelEnvVars(options) {
|
|
|
26
30
|
const params = new URLSearchParams({ decrypt: "true" });
|
|
27
31
|
if (vercelTeamId)
|
|
28
32
|
params.set("teamId", vercelTeamId);
|
|
33
|
+
params.set("target", vercelEnvironment);
|
|
29
34
|
const vercelApiUrl = `https://api.vercel.com/v8/projects/${projectId}/env?${params}`;
|
|
30
35
|
try {
|
|
31
36
|
const response = await fetch(vercelApiUrl, {
|
|
@@ -37,13 +42,24 @@ export function syncVercelEnvVars(options) {
|
|
|
37
42
|
throw new Error(`HTTP error! status: ${response.status}`);
|
|
38
43
|
}
|
|
39
44
|
const data = await response.json();
|
|
45
|
+
const isBranchable = ctx.environment === "preview";
|
|
40
46
|
const filteredEnvs = data.envs
|
|
41
|
-
.filter((env) =>
|
|
42
|
-
env.
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
+
.filter((env) => {
|
|
48
|
+
if (!env.value)
|
|
49
|
+
return false;
|
|
50
|
+
if (!env.target.includes(vercelEnvironment))
|
|
51
|
+
return false;
|
|
52
|
+
if (isBranchable && env.gitBranch && env.gitBranch !== branch)
|
|
53
|
+
return false;
|
|
54
|
+
return true;
|
|
55
|
+
})
|
|
56
|
+
.map((env) => {
|
|
57
|
+
return {
|
|
58
|
+
name: env.key,
|
|
59
|
+
value: env.value,
|
|
60
|
+
isParentEnv: isBranchable && !env.gitBranch,
|
|
61
|
+
};
|
|
62
|
+
});
|
|
47
63
|
return filteredEnvs;
|
|
48
64
|
}
|
|
49
65
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vercelSyncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/vercelSyncEnvVars.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"vercelSyncEnvVars.js","sourceRoot":"","sources":["../../../../src/extensions/core/vercelSyncEnvVars.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { BuildExtension } from "@trigger.dev/core/v3/build";
|
|
2
|
+
type LightpandaOpts = {
|
|
3
|
+
version?: "nightly" | "latest";
|
|
4
|
+
disableTelemetry?: boolean;
|
|
5
|
+
};
|
|
6
|
+
export declare const lightpanda: ({ version, disableTelemetry, }?: LightpandaOpts) => BuildExtension;
|
|
7
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export const lightpanda = ({ version = "latest", disableTelemetry = false, } = {}) => ({
|
|
2
|
+
name: "lightpanda",
|
|
3
|
+
onBuildComplete: async (context) => {
|
|
4
|
+
if (context.target === "dev") {
|
|
5
|
+
return;
|
|
6
|
+
}
|
|
7
|
+
context.logger.debug(`Adding lightpanda`, { version, disableTelemetry });
|
|
8
|
+
const instructions = [
|
|
9
|
+
`COPY --from=lightpanda/browser:${version} /usr/bin/lightpanda /usr/local/bin/lightpanda`,
|
|
10
|
+
`RUN /usr/local/bin/lightpanda version || (echo "lightpanda binary is not functional" && exit 1)`,
|
|
11
|
+
];
|
|
12
|
+
context.addLayer({
|
|
13
|
+
id: "lightpanda",
|
|
14
|
+
image: {
|
|
15
|
+
instructions,
|
|
16
|
+
},
|
|
17
|
+
deploy: {
|
|
18
|
+
env: {
|
|
19
|
+
...(disableTelemetry ? { LIGHTPANDA_DISABLE_TELEMETRY: "true" } : {}),
|
|
20
|
+
},
|
|
21
|
+
override: true,
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
},
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=lightpanda.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lightpanda.js","sourceRoot":"","sources":["../../../src/extensions/lightpanda.ts"],"names":[],"mappings":"AAOA,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EACzB,OAAO,GAAG,QAAQ,EAClB,gBAAgB,GAAG,KAAK,MACN,EAAE,EAAkB,EAAE,CAAC,CAAC;IAC1C,IAAI,EAAE,YAAY;IAClB,eAAe,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;QACjC,IAAI,OAAO,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,EAAE,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC,CAAC;QAEzE,MAAM,YAAY,GAAG;YACnB,kCAAkC,OAAO,gDAAgD;YACzF,iGAAiG;SAC/E,CAAC;QAErB,OAAO,CAAC,QAAQ,CAAC;YACf,EAAE,EAAE,YAAY;YAChB,KAAK,EAAE;gBACL,YAAY;aACb;YACD,MAAM,EAAE;gBACN,GAAG,EAAE;oBACH,GAAG,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,4BAA4B,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;iBACtE;gBACD,QAAQ,EAAE,IAAI;aACf;SACF,CAAC,CAAC;IACL,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import type { BuildContext, BuildExtension } from "@trigger.dev/core/v3/build";
|
|
2
|
+
import type { BuildManifest, BuildTarget } from "@trigger.dev/core/v3";
|
|
3
|
+
type PlaywrightBrowser = "chromium" | "firefox" | "webkit";
|
|
4
|
+
interface PlaywrightExtensionOptions {
|
|
5
|
+
/**
|
|
6
|
+
* Browsers to install. Select only needed browsers to optimize build time and size.
|
|
7
|
+
* @default ["chromium"]
|
|
8
|
+
*/
|
|
9
|
+
browsers?: PlaywrightBrowser[];
|
|
10
|
+
/**
|
|
11
|
+
* Run the browsers in headless mode (Recommended)
|
|
12
|
+
* @default true
|
|
13
|
+
*/
|
|
14
|
+
headless?: boolean;
|
|
15
|
+
/**
|
|
16
|
+
* Playwright version override. If not provided, we will try to detect the version automatically.
|
|
17
|
+
*/
|
|
18
|
+
version?: string;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Installs Playwright browsers and dependencies for your Trigger.dev deployments.
|
|
22
|
+
*
|
|
23
|
+
* @param options - Configuration options for the Playwright extension.
|
|
24
|
+
* @param options.browsers Browsers to install. Accepts an array of strings. Default: `["chromium"]`
|
|
25
|
+
* @param options.headless Whether to run browsers in headless mode. Default: `true`
|
|
26
|
+
* @param options.version Playwright version to use for browser installation. When not set, will automatically detect the version (recommended). Default: `undefined`
|
|
27
|
+
*
|
|
28
|
+
*/
|
|
29
|
+
export declare function playwright(options?: PlaywrightExtensionOptions): PlaywrightExtension;
|
|
30
|
+
/**
|
|
31
|
+
* Background:
|
|
32
|
+
*
|
|
33
|
+
* Running `npx playwright install --with-deps` normally will install the browsers and the dependencies.
|
|
34
|
+
* However, this is not possible in a build context, because we don't have sudo access.
|
|
35
|
+
*
|
|
36
|
+
* So we need to install the dependencies manually and then download and install the browsers.
|
|
37
|
+
* This has a few challenges:
|
|
38
|
+
* 1. We don't want to download all browsers, only the ones we need with it's dependencies
|
|
39
|
+
* The less dependencies we have to install, the faster the build, and the smaller the image.
|
|
40
|
+
* 2. We need to know where to download the browsers from
|
|
41
|
+
* while we can hardcode the download url it might change over time (as it has in the past)
|
|
42
|
+
* so we need to download the browser info first and then parse the output to get the download url.
|
|
43
|
+
*
|
|
44
|
+
* Note: While this looks like we are downloading & installing a lot of stuff, it's actually not that bad
|
|
45
|
+
* since running `npx playwright install --with-deps` will result in the same amount of downloads.
|
|
46
|
+
*/
|
|
47
|
+
declare class PlaywrightExtension implements BuildExtension {
|
|
48
|
+
readonly name = "PlaywrightExtension";
|
|
49
|
+
private moduleExternals;
|
|
50
|
+
private readonly options;
|
|
51
|
+
constructor({ browsers, headless, version, }?: PlaywrightExtensionOptions);
|
|
52
|
+
externalsForTarget(target: BuildTarget): string[];
|
|
53
|
+
onBuildComplete(context: BuildContext, manifest: BuildManifest): void;
|
|
54
|
+
}
|
|
55
|
+
export {};
|
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This list is from the official playwright registry.
|
|
3
|
+
*
|
|
4
|
+
* @see https://github.com/microsoft/playwright/blob/main/packages/playwright-core/src/server/registry/nativeDeps.ts
|
|
5
|
+
*/
|
|
6
|
+
const debian12Deps = {
|
|
7
|
+
tools: [
|
|
8
|
+
"xvfb",
|
|
9
|
+
"fonts-noto-color-emoji",
|
|
10
|
+
"fonts-unifont",
|
|
11
|
+
"libfontconfig1",
|
|
12
|
+
"libfreetype6",
|
|
13
|
+
"xfonts-scalable",
|
|
14
|
+
"fonts-liberation",
|
|
15
|
+
"fonts-ipafont-gothic",
|
|
16
|
+
"fonts-wqy-zenhei",
|
|
17
|
+
"fonts-tlwg-loma-otf",
|
|
18
|
+
"fonts-freefont-ttf",
|
|
19
|
+
],
|
|
20
|
+
chromium: [
|
|
21
|
+
"libasound2",
|
|
22
|
+
"libatk-bridge2.0-0",
|
|
23
|
+
"libatk1.0-0",
|
|
24
|
+
"libatspi2.0-0",
|
|
25
|
+
"libcairo2",
|
|
26
|
+
"libcups2",
|
|
27
|
+
"libdbus-1-3",
|
|
28
|
+
"libdrm2",
|
|
29
|
+
"libgbm1",
|
|
30
|
+
"libglib2.0-0",
|
|
31
|
+
"libnspr4",
|
|
32
|
+
"libnss3",
|
|
33
|
+
"libpango-1.0-0",
|
|
34
|
+
"libx11-6",
|
|
35
|
+
"libxcb1",
|
|
36
|
+
"libxcomposite1",
|
|
37
|
+
"libxdamage1",
|
|
38
|
+
"libxext6",
|
|
39
|
+
"libxfixes3",
|
|
40
|
+
"libxkbcommon0",
|
|
41
|
+
"libxrandr2",
|
|
42
|
+
],
|
|
43
|
+
firefox: [
|
|
44
|
+
"libasound2",
|
|
45
|
+
"libatk1.0-0",
|
|
46
|
+
"libcairo-gobject2",
|
|
47
|
+
"libcairo2",
|
|
48
|
+
"libdbus-1-3",
|
|
49
|
+
"libdbus-glib-1-2",
|
|
50
|
+
"libfontconfig1",
|
|
51
|
+
"libfreetype6",
|
|
52
|
+
"libgdk-pixbuf-2.0-0",
|
|
53
|
+
"libglib2.0-0",
|
|
54
|
+
"libgtk-3-0",
|
|
55
|
+
"libharfbuzz0b",
|
|
56
|
+
"libpango-1.0-0",
|
|
57
|
+
"libpangocairo-1.0-0",
|
|
58
|
+
"libx11-6",
|
|
59
|
+
"libx11-xcb1",
|
|
60
|
+
"libxcb-shm0",
|
|
61
|
+
"libxcb1",
|
|
62
|
+
"libxcomposite1",
|
|
63
|
+
"libxcursor1",
|
|
64
|
+
"libxdamage1",
|
|
65
|
+
"libxext6",
|
|
66
|
+
"libxfixes3",
|
|
67
|
+
"libxi6",
|
|
68
|
+
"libxrandr2",
|
|
69
|
+
"libxrender1",
|
|
70
|
+
"libxtst6",
|
|
71
|
+
],
|
|
72
|
+
webkit: [
|
|
73
|
+
"libsoup-3.0-0",
|
|
74
|
+
"gstreamer1.0-libav",
|
|
75
|
+
"gstreamer1.0-plugins-bad",
|
|
76
|
+
"gstreamer1.0-plugins-base",
|
|
77
|
+
"gstreamer1.0-plugins-good",
|
|
78
|
+
"libatk-bridge2.0-0",
|
|
79
|
+
"libatk1.0-0",
|
|
80
|
+
"libcairo2",
|
|
81
|
+
"libdbus-1-3",
|
|
82
|
+
"libdrm2",
|
|
83
|
+
"libegl1",
|
|
84
|
+
"libenchant-2-2",
|
|
85
|
+
"libepoxy0",
|
|
86
|
+
"libevdev2",
|
|
87
|
+
"libfontconfig1",
|
|
88
|
+
"libfreetype6",
|
|
89
|
+
"libgbm1",
|
|
90
|
+
"libgdk-pixbuf-2.0-0",
|
|
91
|
+
"libgles2",
|
|
92
|
+
"libglib2.0-0",
|
|
93
|
+
"libglx0",
|
|
94
|
+
"libgstreamer-gl1.0-0",
|
|
95
|
+
"libgstreamer-plugins-base1.0-0",
|
|
96
|
+
"libgstreamer1.0-0",
|
|
97
|
+
"libgtk-4-1",
|
|
98
|
+
"libgudev-1.0-0",
|
|
99
|
+
"libharfbuzz-icu0",
|
|
100
|
+
"libharfbuzz0b",
|
|
101
|
+
"libhyphen0",
|
|
102
|
+
"libicu72",
|
|
103
|
+
"libjpeg62-turbo",
|
|
104
|
+
"liblcms2-2",
|
|
105
|
+
"libmanette-0.2-0",
|
|
106
|
+
"libnotify4",
|
|
107
|
+
"libopengl0",
|
|
108
|
+
"libopenjp2-7",
|
|
109
|
+
"libopus0",
|
|
110
|
+
"libpango-1.0-0",
|
|
111
|
+
"libpng16-16",
|
|
112
|
+
"libproxy1v5",
|
|
113
|
+
"libsecret-1-0",
|
|
114
|
+
"libwayland-client0",
|
|
115
|
+
"libwayland-egl1",
|
|
116
|
+
"libwayland-server0",
|
|
117
|
+
"libwebp7",
|
|
118
|
+
"libwebpdemux2",
|
|
119
|
+
"libwoff1",
|
|
120
|
+
"libx11-6",
|
|
121
|
+
"libxcomposite1",
|
|
122
|
+
"libxdamage1",
|
|
123
|
+
"libxkbcommon0",
|
|
124
|
+
"libxml2",
|
|
125
|
+
"libxslt1.1",
|
|
126
|
+
"libatomic1",
|
|
127
|
+
"libevent-2.1-7",
|
|
128
|
+
"libavif15",
|
|
129
|
+
],
|
|
130
|
+
lib2package: {
|
|
131
|
+
"libavif.so.15": "libavif15",
|
|
132
|
+
"libsoup-3.0.so.0": "libsoup-3.0-0",
|
|
133
|
+
"libasound.so.2": "libasound2",
|
|
134
|
+
"libatk-1.0.so.0": "libatk1.0-0",
|
|
135
|
+
"libatk-bridge-2.0.so.0": "libatk-bridge2.0-0",
|
|
136
|
+
"libatspi.so.0": "libatspi2.0-0",
|
|
137
|
+
"libcairo.so.2": "libcairo2",
|
|
138
|
+
"libcups.so.2": "libcups2",
|
|
139
|
+
"libdbus-1.so.3": "libdbus-1-3",
|
|
140
|
+
"libdrm.so.2": "libdrm2",
|
|
141
|
+
"libgbm.so.1": "libgbm1",
|
|
142
|
+
"libgio-2.0.so.0": "libglib2.0-0",
|
|
143
|
+
"libglib-2.0.so.0": "libglib2.0-0",
|
|
144
|
+
"libgobject-2.0.so.0": "libglib2.0-0",
|
|
145
|
+
"libnspr4.so": "libnspr4",
|
|
146
|
+
"libnss3.so": "libnss3",
|
|
147
|
+
"libnssutil3.so": "libnss3",
|
|
148
|
+
"libpango-1.0.so.0": "libpango-1.0-0",
|
|
149
|
+
"libsmime3.so": "libnss3",
|
|
150
|
+
"libX11.so.6": "libx11-6",
|
|
151
|
+
"libxcb.so.1": "libxcb1",
|
|
152
|
+
"libXcomposite.so.1": "libxcomposite1",
|
|
153
|
+
"libXdamage.so.1": "libxdamage1",
|
|
154
|
+
"libXext.so.6": "libxext6",
|
|
155
|
+
"libXfixes.so.3": "libxfixes3",
|
|
156
|
+
"libxkbcommon.so.0": "libxkbcommon0",
|
|
157
|
+
"libXrandr.so.2": "libxrandr2",
|
|
158
|
+
"libgtk-4.so.1": "libgtk-4-1",
|
|
159
|
+
},
|
|
160
|
+
};
|
|
161
|
+
/**
|
|
162
|
+
* Installs Playwright browsers and dependencies for your Trigger.dev deployments.
|
|
163
|
+
*
|
|
164
|
+
* @param options - Configuration options for the Playwright extension.
|
|
165
|
+
* @param options.browsers Browsers to install. Accepts an array of strings. Default: `["chromium"]`
|
|
166
|
+
* @param options.headless Whether to run browsers in headless mode. Default: `true`
|
|
167
|
+
* @param options.version Playwright version to use for browser installation. When not set, will automatically detect the version (recommended). Default: `undefined`
|
|
168
|
+
*
|
|
169
|
+
*/
|
|
170
|
+
export function playwright(options = {}) {
|
|
171
|
+
return new PlaywrightExtension(options);
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Background:
|
|
175
|
+
*
|
|
176
|
+
* Running `npx playwright install --with-deps` normally will install the browsers and the dependencies.
|
|
177
|
+
* However, this is not possible in a build context, because we don't have sudo access.
|
|
178
|
+
*
|
|
179
|
+
* So we need to install the dependencies manually and then download and install the browsers.
|
|
180
|
+
* This has a few challenges:
|
|
181
|
+
* 1. We don't want to download all browsers, only the ones we need with it's dependencies
|
|
182
|
+
* The less dependencies we have to install, the faster the build, and the smaller the image.
|
|
183
|
+
* 2. We need to know where to download the browsers from
|
|
184
|
+
* while we can hardcode the download url it might change over time (as it has in the past)
|
|
185
|
+
* so we need to download the browser info first and then parse the output to get the download url.
|
|
186
|
+
*
|
|
187
|
+
* Note: While this looks like we are downloading & installing a lot of stuff, it's actually not that bad
|
|
188
|
+
* since running `npx playwright install --with-deps` will result in the same amount of downloads.
|
|
189
|
+
*/
|
|
190
|
+
class PlaywrightExtension {
|
|
191
|
+
name = "PlaywrightExtension";
|
|
192
|
+
moduleExternals;
|
|
193
|
+
options;
|
|
194
|
+
constructor({ browsers = ["chromium"], headless = true, version, } = {}) {
|
|
195
|
+
if (browsers && browsers.length === 0) {
|
|
196
|
+
throw new Error("At least one browser must be specified");
|
|
197
|
+
}
|
|
198
|
+
this.options = { browsers, headless, version };
|
|
199
|
+
this.moduleExternals = ["playwright"];
|
|
200
|
+
}
|
|
201
|
+
externalsForTarget(target) {
|
|
202
|
+
if (target === "dev") {
|
|
203
|
+
return [];
|
|
204
|
+
}
|
|
205
|
+
return this.moduleExternals;
|
|
206
|
+
}
|
|
207
|
+
onBuildComplete(context, manifest) {
|
|
208
|
+
if (context.target === "dev")
|
|
209
|
+
return;
|
|
210
|
+
// Detect Playwright version from manifest.externals or use override
|
|
211
|
+
const playwrightExternal = manifest.externals?.find((external) => external.name === "playwright" || external.name === "@playwright/test");
|
|
212
|
+
const version = playwrightExternal?.version ?? this.options.version;
|
|
213
|
+
if (!version) {
|
|
214
|
+
throw new Error("PlaywrightExtension could not determine the version of playwright. Please provide a version in the PlaywrightExtension options.");
|
|
215
|
+
}
|
|
216
|
+
context.logger.debug(`Adding ${this.name} to the build with browsers: ${this.options.browsers.join(", ")}, version: ${version}`);
|
|
217
|
+
const instructions = [
|
|
218
|
+
// Base dependencies, we need these to download the browsers
|
|
219
|
+
`RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
220
|
+
curl \
|
|
221
|
+
unzip \
|
|
222
|
+
jq \
|
|
223
|
+
grep \
|
|
224
|
+
sed \
|
|
225
|
+
npm \
|
|
226
|
+
&& apt-get clean && rm -rf /var/lib/apt/lists/*`,
|
|
227
|
+
// Install Playwright globally with detected version
|
|
228
|
+
`RUN npm install -g playwright@${version}`,
|
|
229
|
+
];
|
|
230
|
+
const deps = [...debian12Deps.tools, ...Object.values(debian12Deps.lib2package)];
|
|
231
|
+
if (this.options.browsers.includes("chromium"))
|
|
232
|
+
deps.push(...debian12Deps.chromium);
|
|
233
|
+
if (this.options.browsers.includes("firefox"))
|
|
234
|
+
deps.push(...debian12Deps.firefox);
|
|
235
|
+
if (this.options.browsers.includes("webkit"))
|
|
236
|
+
deps.push(...debian12Deps.webkit);
|
|
237
|
+
instructions.push(`RUN apt-get update && apt-get install -y --no-install-recommends ${deps.join(" ")} \
|
|
238
|
+
&& apt-get clean && rm -rf /var/lib/apt/lists/*`);
|
|
239
|
+
// Setup directory for playwright browsers
|
|
240
|
+
instructions.push(`RUN mkdir -p /ms-playwright`);
|
|
241
|
+
/**
|
|
242
|
+
* `npx playwright install --dry-run` prints the download urls for the browsers.
|
|
243
|
+
* We save this output to a file and then parse it to get the download urls for the browsers.
|
|
244
|
+
*/
|
|
245
|
+
instructions.push(`RUN npx playwright install --dry-run > /tmp/browser-info.txt`);
|
|
246
|
+
// Determine which browsers to actually install
|
|
247
|
+
const browsersToInstall = new Set();
|
|
248
|
+
this.options.browsers.forEach((browser) => {
|
|
249
|
+
if (browser === "chromium") {
|
|
250
|
+
if (this.options.headless) {
|
|
251
|
+
// For headless mode, only install chromium-headless-shell
|
|
252
|
+
browsersToInstall.add("chromium-headless-shell");
|
|
253
|
+
}
|
|
254
|
+
else {
|
|
255
|
+
// For non-headless mode, install both chromium and chromium-headless-shell
|
|
256
|
+
// This allows users to easily switch between headless and non-headless mode
|
|
257
|
+
browsersToInstall.add("chromium");
|
|
258
|
+
browsersToInstall.add("chromium-headless-shell");
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
browsersToInstall.add(browser);
|
|
263
|
+
}
|
|
264
|
+
});
|
|
265
|
+
Array.from(browsersToInstall).forEach((browser) => {
|
|
266
|
+
instructions.push(`RUN grep -A5 -m1 "browser: ${browser}" /tmp/browser-info.txt > /tmp/${browser}-info.txt`, `RUN INSTALL_DIR=$(grep "Install location:" /tmp/${browser}-info.txt | cut -d':' -f2- | xargs) && \
|
|
267
|
+
DIR_NAME=$(basename "$INSTALL_DIR") && \
|
|
268
|
+
if [ -z "$DIR_NAME" ]; then echo "Failed to extract installation directory for ${browser}"; exit 1; fi && \
|
|
269
|
+
MS_DIR="/ms-playwright/$DIR_NAME" && \
|
|
270
|
+
mkdir -p "$MS_DIR"`, `RUN DOWNLOAD_URL=$(grep "Download url:" /tmp/${browser}-info.txt | cut -d':' -f2- | xargs | sed "s/mac-arm64/linux/g" | sed "s/mac-15-arm64/ubuntu-20.04/g") && \
|
|
271
|
+
if [ -z "$DOWNLOAD_URL" ]; then echo "Failed to extract download URL for ${browser}"; exit 1; fi && \
|
|
272
|
+
echo "Downloading ${browser} from $DOWNLOAD_URL" && \
|
|
273
|
+
curl -L -o /tmp/${browser}.zip "$DOWNLOAD_URL" && \
|
|
274
|
+
if [ $? -ne 0 ]; then echo "Failed to download ${browser}"; exit 1; fi && \
|
|
275
|
+
unzip -q /tmp/${browser}.zip -d "/ms-playwright/$(basename $(grep "Install location:" /tmp/${browser}-info.txt | cut -d':' -f2- | xargs))" && \
|
|
276
|
+
if [ $? -ne 0 ]; then echo "Failed to extract ${browser}"; exit 1; fi && \
|
|
277
|
+
chmod -R +x "/ms-playwright/$(basename $(grep "Install location:" /tmp/${browser}-info.txt | cut -d':' -f2- | xargs))" && \
|
|
278
|
+
rm /tmp/${browser}.zip`);
|
|
279
|
+
});
|
|
280
|
+
// Environment variables
|
|
281
|
+
const envVars = {
|
|
282
|
+
PLAYWRIGHT_BROWSERS_PATH: "/ms-playwright", // where playwright will find the browsers
|
|
283
|
+
PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: "1", // we already downloaded the browsers
|
|
284
|
+
PLAYWRIGHT_SKIP_BROWSER_VALIDATION: "1", // we already downloaded the browsers
|
|
285
|
+
};
|
|
286
|
+
if (!this.options.headless) {
|
|
287
|
+
instructions.push(`RUN echo '#!/bin/sh' > /usr/local/bin/xvfb-exec`, `RUN echo 'Xvfb :99 -screen 0 1024x768x24 &' >> /usr/local/bin/xvfb-exec`, `RUN echo 'exec "$@"' >> /usr/local/bin/xvfb-exec`, `RUN chmod +x /usr/local/bin/xvfb-exec`);
|
|
288
|
+
envVars.DISPLAY = ":99"; // Virtual display for the browsers
|
|
289
|
+
}
|
|
290
|
+
context.addLayer({
|
|
291
|
+
id: "playwright",
|
|
292
|
+
image: {
|
|
293
|
+
instructions,
|
|
294
|
+
},
|
|
295
|
+
deploy: {
|
|
296
|
+
env: envVars,
|
|
297
|
+
override: true,
|
|
298
|
+
},
|
|
299
|
+
dependencies: {
|
|
300
|
+
playwright: version,
|
|
301
|
+
},
|
|
302
|
+
});
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
//# sourceMappingURL=playwright.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"playwright.js","sourceRoot":"","sources":["../../../src/extensions/playwright.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { BuildManifest } from "@trigger.dev/core/v3";
|
|
2
|
+
import { BuildContext } from "@trigger.dev/core/v3/build";
|
|
3
|
+
export type AdditionalFilesOptions = {
|
|
4
|
+
files: string[];
|
|
5
|
+
};
|
|
6
|
+
export declare function addAdditionalFilesToBuild(source: string, options: AdditionalFilesOptions, context: BuildContext, manifest: BuildManifest): Promise<void>;
|