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.

The unit tests cannot really hardcode the expected output as it will be
dependent on the operating system and environment.  We will need to
start work on integration tests.
  • Loading branch information
elliotgoodrich committed Feb 11, 2024
1 parent 78d1ae1 commit 4c1210e
Show file tree
Hide file tree
Showing 5 changed files with 63 additions and 83 deletions.
23 changes: 23 additions & 0 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
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
cache: 'npm'
- uses: seanmiddleditch/gha-setup-ninja@master
- run: npm ci
- run: node ./configure.mjs
- run: ninja
71 changes: 36 additions & 35 deletions package-lock.json

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

5 changes: 4 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,13 @@
"@ninjutsu-build/bun": "^0.1.0",
"@ninjutsu-build/core": "^0.8.1",
"@ninjutsu-build/node": "^0.8.0",
"@ninjutsu-build/tsc": "^0.10.0",
"@ninjutsu-build/tsc": "^0.10.1",
"@types/toposort": "^2.0.7",
"glob": "^10.3.10",
"swc": "^1.0.11",
"toposort": "^2.0.2"
},
"dependencies": {
"which": "^4.0.0"
}
}
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 4c1210e

Please sign in to comment.