@crabnebula/test-runner-backend 0.0.0

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/Cargo.toml ADDED
@@ -0,0 +1,25 @@
1
+ [package]
2
+ edition = "2021"
3
+ name = "crabnebula_test-runner-backend"
4
+ version = "0.0.0"
5
+
6
+ [lib]
7
+ crate-type = ["cdylib"]
8
+
9
+ [dependencies]
10
+ test-runner-backend = { path = "../../test-runner-backend/" }
11
+ # Default enable napi4 feature, see https://nodejs.org/api/n-api.html#node-api-version-matrix
12
+ napi = { version = "2.12.2", default-features = false, features = [
13
+ "napi4",
14
+ "async",
15
+ ] }
16
+ napi-derive = "2.12.2"
17
+
18
+ [build-dependencies]
19
+ napi-build = "2.0.1"
20
+
21
+ [features]
22
+ default = ["test-runner-backend/default"]
23
+ native-tls = ["test-runner-backend/native-tls"]
24
+ native-tls-vendored = ["test-runner-backend/native-tls-vendored"]
25
+ rustls-tls = ["test-runner-backend/rustls-tls"]
package/build.rs ADDED
@@ -0,0 +1,5 @@
1
+ extern crate napi_build;
2
+
3
+ fn main() {
4
+ napi_build::setup();
5
+ }
package/cli.js ADDED
@@ -0,0 +1,53 @@
1
+ #!/usr/bin/env node
2
+
3
+ const cli = require(".");
4
+ const path = require("path");
5
+
6
+ const [bin, script, ...args] = process.argv;
7
+ const binStem = path.parse(bin).name.toLowerCase();
8
+
9
+ // We want to make a helpful binary name for the underlying CLI helper, if we
10
+ // can successfully detect what command likely started the execution.
11
+ let binName;
12
+
13
+ // deno run -A --unstable --node-modules-dir npm:@crabnebula/test-runner-backend
14
+ if (bin === "@crabnebula/test-runner-backend") {
15
+ binName = "@crabnebula/test-runner-backend";
16
+ }
17
+ // Even if started by a package manager, the binary will be NodeJS.
18
+ // Some distribution still use "nodejs" as the binary name.
19
+ else if (binStem.match(/(nodejs|node|bun)\-?([0-9]*)*$/g)) {
20
+ const managerStem = process.env.npm_execpath
21
+ ? path.parse(process.env.npm_execpath).name.toLowerCase()
22
+ : null;
23
+ if (managerStem) {
24
+ let manager;
25
+ switch (managerStem) {
26
+ // Only supported package manager that has a different filename is npm.
27
+ case "npm-cli":
28
+ manager = "npm";
29
+ break;
30
+
31
+ // Yarn, pnpm, and bun have the same stem name as their bin.
32
+ // We assume all unknown package managers do as well.
33
+ default:
34
+ manager = managerStem;
35
+ break;
36
+ }
37
+
38
+ binName = `${manager} run ${process.env.npm_lifecycle_event}`;
39
+ } else {
40
+ // Assume running NodeJS if we didn't detect a manager from the env.
41
+ // We normalize the path to prevent the script's absolute path being used.
42
+ const scriptNormal = path.normalize(path.relative(process.cwd(), script));
43
+ binName = `${binStem} ${scriptNormal}`;
44
+ }
45
+ } else {
46
+ // We don't know what started it, assume it's already stripped.
47
+ args.unshift(bin);
48
+ }
49
+
50
+ cli.run(args, binName).catch((err) => {
51
+ console.error(err.message);
52
+ process.exit(1);
53
+ });
package/index.d.ts ADDED
@@ -0,0 +1,6 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+
4
+ /* auto-generated by NAPI-RS */
5
+
6
+ export declare function run(args: Array<string>, binName?: string | undefined | null): Promise<void>
package/index.js ADDED
@@ -0,0 +1,315 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+ /* prettier-ignore */
4
+
5
+ /* auto-generated by NAPI-RS */
6
+
7
+ const { existsSync, readFileSync } = require('fs')
8
+ const { join } = require('path')
9
+
10
+ const { platform, arch } = process
11
+
12
+ let nativeBinding = null
13
+ let localFileExisted = false
14
+ let loadError = null
15
+
16
+ function isMusl() {
17
+ // For Node 10
18
+ if (!process.report || typeof process.report.getReport !== 'function') {
19
+ try {
20
+ const lddPath = require('child_process').execSync('which ldd').toString().trim()
21
+ return readFileSync(lddPath, 'utf8').includes('musl')
22
+ } catch (e) {
23
+ return true
24
+ }
25
+ } else {
26
+ const { glibcVersionRuntime } = process.report.getReport().header
27
+ return !glibcVersionRuntime
28
+ }
29
+ }
30
+
31
+ switch (platform) {
32
+ case 'android':
33
+ switch (arch) {
34
+ case 'arm64':
35
+ localFileExisted = existsSync(join(__dirname, 'test-runner-backend.android-arm64.node'))
36
+ try {
37
+ if (localFileExisted) {
38
+ nativeBinding = require('./test-runner-backend.android-arm64.node')
39
+ } else {
40
+ nativeBinding = require('@crabnebula/test-runner-backend-android-arm64')
41
+ }
42
+ } catch (e) {
43
+ loadError = e
44
+ }
45
+ break
46
+ case 'arm':
47
+ localFileExisted = existsSync(join(__dirname, 'test-runner-backend.android-arm-eabi.node'))
48
+ try {
49
+ if (localFileExisted) {
50
+ nativeBinding = require('./test-runner-backend.android-arm-eabi.node')
51
+ } else {
52
+ nativeBinding = require('@crabnebula/test-runner-backend-android-arm-eabi')
53
+ }
54
+ } catch (e) {
55
+ loadError = e
56
+ }
57
+ break
58
+ default:
59
+ throw new Error(`Unsupported architecture on Android ${arch}`)
60
+ }
61
+ break
62
+ case 'win32':
63
+ switch (arch) {
64
+ case 'x64':
65
+ localFileExisted = existsSync(
66
+ join(__dirname, 'test-runner-backend.win32-x64-msvc.node')
67
+ )
68
+ try {
69
+ if (localFileExisted) {
70
+ nativeBinding = require('./test-runner-backend.win32-x64-msvc.node')
71
+ } else {
72
+ nativeBinding = require('@crabnebula/test-runner-backend-win32-x64-msvc')
73
+ }
74
+ } catch (e) {
75
+ loadError = e
76
+ }
77
+ break
78
+ case 'ia32':
79
+ localFileExisted = existsSync(
80
+ join(__dirname, 'test-runner-backend.win32-ia32-msvc.node')
81
+ )
82
+ try {
83
+ if (localFileExisted) {
84
+ nativeBinding = require('./test-runner-backend.win32-ia32-msvc.node')
85
+ } else {
86
+ nativeBinding = require('@crabnebula/test-runner-backend-win32-ia32-msvc')
87
+ }
88
+ } catch (e) {
89
+ loadError = e
90
+ }
91
+ break
92
+ case 'arm64':
93
+ localFileExisted = existsSync(
94
+ join(__dirname, 'test-runner-backend.win32-arm64-msvc.node')
95
+ )
96
+ try {
97
+ if (localFileExisted) {
98
+ nativeBinding = require('./test-runner-backend.win32-arm64-msvc.node')
99
+ } else {
100
+ nativeBinding = require('@crabnebula/test-runner-backend-win32-arm64-msvc')
101
+ }
102
+ } catch (e) {
103
+ loadError = e
104
+ }
105
+ break
106
+ default:
107
+ throw new Error(`Unsupported architecture on Windows: ${arch}`)
108
+ }
109
+ break
110
+ case 'darwin':
111
+ localFileExisted = existsSync(join(__dirname, 'test-runner-backend.darwin-universal.node'))
112
+ try {
113
+ if (localFileExisted) {
114
+ nativeBinding = require('./test-runner-backend.darwin-universal.node')
115
+ } else {
116
+ nativeBinding = require('@crabnebula/test-runner-backend-darwin-universal')
117
+ }
118
+ break
119
+ } catch {}
120
+ switch (arch) {
121
+ case 'x64':
122
+ localFileExisted = existsSync(join(__dirname, 'test-runner-backend.darwin-x64.node'))
123
+ try {
124
+ if (localFileExisted) {
125
+ nativeBinding = require('./test-runner-backend.darwin-x64.node')
126
+ } else {
127
+ nativeBinding = require('@crabnebula/test-runner-backend-darwin-x64')
128
+ }
129
+ } catch (e) {
130
+ loadError = e
131
+ }
132
+ break
133
+ case 'arm64':
134
+ localFileExisted = existsSync(
135
+ join(__dirname, 'test-runner-backend.darwin-arm64.node')
136
+ )
137
+ try {
138
+ if (localFileExisted) {
139
+ nativeBinding = require('./test-runner-backend.darwin-arm64.node')
140
+ } else {
141
+ nativeBinding = require('@crabnebula/test-runner-backend-darwin-arm64')
142
+ }
143
+ } catch (e) {
144
+ loadError = e
145
+ }
146
+ break
147
+ default:
148
+ throw new Error(`Unsupported architecture on macOS: ${arch}`)
149
+ }
150
+ break
151
+ case 'freebsd':
152
+ if (arch !== 'x64') {
153
+ throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
154
+ }
155
+ localFileExisted = existsSync(join(__dirname, 'test-runner-backend.freebsd-x64.node'))
156
+ try {
157
+ if (localFileExisted) {
158
+ nativeBinding = require('./test-runner-backend.freebsd-x64.node')
159
+ } else {
160
+ nativeBinding = require('@crabnebula/test-runner-backend-freebsd-x64')
161
+ }
162
+ } catch (e) {
163
+ loadError = e
164
+ }
165
+ break
166
+ case 'linux':
167
+ switch (arch) {
168
+ case 'x64':
169
+ if (isMusl()) {
170
+ localFileExisted = existsSync(
171
+ join(__dirname, 'test-runner-backend.linux-x64-musl.node')
172
+ )
173
+ try {
174
+ if (localFileExisted) {
175
+ nativeBinding = require('./test-runner-backend.linux-x64-musl.node')
176
+ } else {
177
+ nativeBinding = require('@crabnebula/test-runner-backend-linux-x64-musl')
178
+ }
179
+ } catch (e) {
180
+ loadError = e
181
+ }
182
+ } else {
183
+ localFileExisted = existsSync(
184
+ join(__dirname, 'test-runner-backend.linux-x64-gnu.node')
185
+ )
186
+ try {
187
+ if (localFileExisted) {
188
+ nativeBinding = require('./test-runner-backend.linux-x64-gnu.node')
189
+ } else {
190
+ nativeBinding = require('@crabnebula/test-runner-backend-linux-x64-gnu')
191
+ }
192
+ } catch (e) {
193
+ loadError = e
194
+ }
195
+ }
196
+ break
197
+ case 'arm64':
198
+ if (isMusl()) {
199
+ localFileExisted = existsSync(
200
+ join(__dirname, 'test-runner-backend.linux-arm64-musl.node')
201
+ )
202
+ try {
203
+ if (localFileExisted) {
204
+ nativeBinding = require('./test-runner-backend.linux-arm64-musl.node')
205
+ } else {
206
+ nativeBinding = require('@crabnebula/test-runner-backend-linux-arm64-musl')
207
+ }
208
+ } catch (e) {
209
+ loadError = e
210
+ }
211
+ } else {
212
+ localFileExisted = existsSync(
213
+ join(__dirname, 'test-runner-backend.linux-arm64-gnu.node')
214
+ )
215
+ try {
216
+ if (localFileExisted) {
217
+ nativeBinding = require('./test-runner-backend.linux-arm64-gnu.node')
218
+ } else {
219
+ nativeBinding = require('@crabnebula/test-runner-backend-linux-arm64-gnu')
220
+ }
221
+ } catch (e) {
222
+ loadError = e
223
+ }
224
+ }
225
+ break
226
+ case 'arm':
227
+ if (isMusl()) {
228
+ localFileExisted = existsSync(
229
+ join(__dirname, 'test-runner-backend.linux-arm-musleabihf.node')
230
+ )
231
+ try {
232
+ if (localFileExisted) {
233
+ nativeBinding = require('./test-runner-backend.linux-arm-musleabihf.node')
234
+ } else {
235
+ nativeBinding = require('@crabnebula/test-runner-backend-linux-arm-musleabihf')
236
+ }
237
+ } catch (e) {
238
+ loadError = e
239
+ }
240
+ } else {
241
+ localFileExisted = existsSync(
242
+ join(__dirname, 'test-runner-backend.linux-arm-gnueabihf.node')
243
+ )
244
+ try {
245
+ if (localFileExisted) {
246
+ nativeBinding = require('./test-runner-backend.linux-arm-gnueabihf.node')
247
+ } else {
248
+ nativeBinding = require('@crabnebula/test-runner-backend-linux-arm-gnueabihf')
249
+ }
250
+ } catch (e) {
251
+ loadError = e
252
+ }
253
+ }
254
+ break
255
+ case 'riscv64':
256
+ if (isMusl()) {
257
+ localFileExisted = existsSync(
258
+ join(__dirname, 'test-runner-backend.linux-riscv64-musl.node')
259
+ )
260
+ try {
261
+ if (localFileExisted) {
262
+ nativeBinding = require('./test-runner-backend.linux-riscv64-musl.node')
263
+ } else {
264
+ nativeBinding = require('@crabnebula/test-runner-backend-linux-riscv64-musl')
265
+ }
266
+ } catch (e) {
267
+ loadError = e
268
+ }
269
+ } else {
270
+ localFileExisted = existsSync(
271
+ join(__dirname, 'test-runner-backend.linux-riscv64-gnu.node')
272
+ )
273
+ try {
274
+ if (localFileExisted) {
275
+ nativeBinding = require('./test-runner-backend.linux-riscv64-gnu.node')
276
+ } else {
277
+ nativeBinding = require('@crabnebula/test-runner-backend-linux-riscv64-gnu')
278
+ }
279
+ } catch (e) {
280
+ loadError = e
281
+ }
282
+ }
283
+ break
284
+ case 's390x':
285
+ localFileExisted = existsSync(
286
+ join(__dirname, 'test-runner-backend.linux-s390x-gnu.node')
287
+ )
288
+ try {
289
+ if (localFileExisted) {
290
+ nativeBinding = require('./test-runner-backend.linux-s390x-gnu.node')
291
+ } else {
292
+ nativeBinding = require('@crabnebula/test-runner-backend-linux-s390x-gnu')
293
+ }
294
+ } catch (e) {
295
+ loadError = e
296
+ }
297
+ break
298
+ default:
299
+ throw new Error(`Unsupported architecture on Linux: ${arch}`)
300
+ }
301
+ break
302
+ default:
303
+ throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
304
+ }
305
+
306
+ if (!nativeBinding) {
307
+ if (loadError) {
308
+ throw loadError
309
+ }
310
+ throw new Error(`Failed to load native binding`)
311
+ }
312
+
313
+ const { run } = nativeBinding
314
+
315
+ module.exports.run = run
package/package.json ADDED
@@ -0,0 +1,39 @@
1
+ {
2
+ "name": "@crabnebula/test-runner-backend",
3
+ "version": "0.0.0",
4
+ "main": "index.js",
5
+ "types": "index.d.ts",
6
+ "bin": {
7
+ "test-runner-backend": "./cli.js"
8
+ },
9
+ "napi": {
10
+ "name": "test-runner-backend",
11
+ "triples": {
12
+ "additional": [
13
+ "aarch64-apple-darwin"
14
+ ]
15
+ }
16
+ },
17
+ "license": "MIT",
18
+ "devDependencies": {
19
+ "@napi-rs/cli": "^2.18.4"
20
+ },
21
+ "engines": {
22
+ "node": ">= 10"
23
+ },
24
+ "scripts": {
25
+ "artifacts": "napi artifacts",
26
+ "build:deps": "cargo build --manifest-path ../../webdriver/Cargo.toml",
27
+ "build": "napi build --platform --release",
28
+ "build:debug": "napi build --platform",
29
+ "prepublishOnly": "napi prepublish -t npm",
30
+ "universal": "napi universal",
31
+ "version": "napi version"
32
+ },
33
+ "optionalDependencies": {
34
+ "@crabnebula/test-runner-backend-win32-x64-msvc": "0.0.0",
35
+ "@crabnebula/test-runner-backend-darwin-x64": "0.0.0",
36
+ "@crabnebula/test-runner-backend-linux-x64-gnu": "0.0.0",
37
+ "@crabnebula/test-runner-backend-darwin-arm64": "0.0.0"
38
+ }
39
+ }
package/src/lib.rs ADDED
@@ -0,0 +1,8 @@
1
+ use napi::Result;
2
+
3
+ #[napi_derive::napi]
4
+ pub async fn run(args: Vec<String>, bin_name: Option<String>) -> Result<()> {
5
+ test_runner_backend::try_run(args, bin_name)
6
+ .await
7
+ .map_err(|e| napi::Error::new(napi::Status::GenericFailure, e.to_string()))
8
+ }