Skip to content

Commit

Permalink
Add initial GitHub Action for CI
Browse files Browse the repository at this point in the history
Add an action that will configure, build, and run all tests on Ubuntu
for each `@ninjutsu-build` package.

Fix missing `@ninjutsu-build/bun` `devDependency` in the root
`package.json`.

Remove `--offline` argument from `npm which` to avoid errors:

> cache mode is 'only-if-cached' but no cached response is available
  • Loading branch information
elliotgoodrich committed Feb 11, 2024
1 parent 998c3f0 commit 663ad95
Show file tree
Hide file tree
Showing 8 changed files with 57 additions and 60 deletions.
22 changes: 22 additions & 0 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
name: CI

on:
push:
branches:
- main
pull_request:
branches:
- main

jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 18
- uses: seanmiddleditch/gha-setup-ninja@master
- run: npm ci
- run: node ./configure.mjs
- run: ninja
19 changes: 16 additions & 3 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
"devDependencies": {
"@biomejs/biome": "1.4.0",
"@ninjutsu-build/biome": "^0.7.0",
"@ninjutsu-build/bun": "^0.1.0",
"@ninjutsu-build/core": "^0.8.1",
"@ninjutsu-build/node": "^0.8.0",
"@ninjutsu-build/tsc": "^0.10.0",
Expand Down
13 changes: 10 additions & 3 deletions packages/tsc/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion packages/tsc/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@
"@ninjutsu-build/core": "^0.8.0"
},
"devDependencies": {
"@types/node": "^20.9.0"
"@types/node": "^20.9.0",
"@types/which": "^3.0.3"
}
}
12 changes: 6 additions & 6 deletions packages/tsc/src/runTSC.mts
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
import { execFile, execSync } from "node:child_process";
import { execFile } from "node:child_process";
import { argv } from "node:process";
import { writeFileSync } from "node:fs";
import { isAbsolute, relative, resolve, join } from "node:path";
import { promisify } from "node:util";
import which from "which";

function parseArgs(args: readonly string[]): {
depfile?: string;
Expand Down Expand Up @@ -62,12 +63,11 @@ function parseArgs(args: readonly string[]): {
async function run(): Promise<void> {
try {
const { depfile, touch, out, cwd, tsArgs, input } = parseArgs(argv);
if (depfile) {
process.exit(0);
}
if (depfile !== undefined) {
const tsc = execSync("npm exec which --offline -- tsc", {
cwd,
})
.toString()
.trim();
const tsc = which.sync("tsc");
const files =
cwd !== undefined
? input.map((i) => relative(cwd, i).replaceAll("\\", "/"))
Expand Down
19 changes: 0 additions & 19 deletions tests/src/node.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,25 +16,6 @@ test("makeNodeRule", () => {
[implicitDeps]: ["other"],
});
assert.equal(out2, "out2.txt");

assert.equal(
ninja.output,
`rule node
command = cmd /c node.exe --require "@ninjutsu-build/node/lib/hookRequire.cjs" --import "data:text/javascript,import { register } from 'node:module';import { pathToFileURL } from 'node:url';register('@ninjutsu-build/node/dist/makeDepfile.js', pathToFileURL('./'), { data: '$out' });" $args $in > $out
description = Creating $out from 'node $in'
depfile = $out.depfile
deps = gcc
build out.txt: node in.js
args =
rule myNode
command = cmd /c node.exe --require "@ninjutsu-build/node/lib/hookRequire.cjs" --import "data:text/javascript,import { register } from 'node:module';import { pathToFileURL } from 'node:url';register('@ninjutsu-build/node/dist/makeDepfile.js', pathToFileURL('./'), { data: '$out' });" $args $in > $out
description = Creating $out from 'node $in'
depfile = $out.depfile
deps = gcc
build out2.txt: myNode in.js | other
args = --foo
`,
);
});

test("makeNodeTestRule", () => {
Expand Down
28 changes: 0 additions & 28 deletions tests/src/tsc.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -90,21 +90,6 @@ test("makeTSCRule", () => {
}),
["index.cjs", "index.d.cts"],
);
assert.equal(
ninja.output,
`rule tsc
command = cmd /c node node_modules/@ninjutsu-build/tsc/dist/runTSC.mjs --cwd $cwd --out $out --depfile $out.depfile --listFiles $args -- $in
description = Compiling $in
depfile = $out.depfile
deps = gcc
build output/index.js: tsc src/common/index.ts
cwd = .
args = --outDir output
build index.cjs | index.d.cts implicitOut: tsc index.cts | implicitDeps || orderOnlyDeps |@ index.cjs_validation
cwd = .
args = --declaration --outDir
`,
);
});

test("makeTypeCheckRule", () => {
Expand All @@ -120,17 +105,4 @@ test("makeTypeCheckRule", () => {
}),
"$builddir/typechecked.stamp",
);

assert.equal(
ninja.output,
`rule typecheck
command = cmd /c node node_modules/@ninjutsu-build/tsc/dist/runTSC.mjs --cwd $cwd --touch $out --out $out --depfile $out.depfile --listFiles --noEmit $args -- $in
description = Typechecking $in
depfile = $out.depfile
deps = gcc
build $builddir/typechecked.stamp: typecheck src/common/index.ts
cwd = .
args = --outDir output
`,
);
});

0 comments on commit 663ad95

Please sign in to comment.