Skip to content

Commit

Permalink
WIP: ci support
Browse files Browse the repository at this point in the history
  • Loading branch information
Michael Thomas committed Oct 8, 2024
1 parent bf4f1f3 commit c1a88e3
Show file tree
Hide file tree
Showing 6 changed files with 537 additions and 6 deletions.
247 changes: 247 additions & 0 deletions .github/workflows/CI.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,247 @@
name: CI
env:
DEBUG: napi:*
APP_NAME: package-template
MACOSX_DEPLOYMENT_TARGET: '10.13'
CARGO_INCREMENTAL: '1'
permissions:
contents: write
id-token: write
'on':
push:
branches:
- main
tags-ignore:
- '**'
paths-ignore:
- '**/*.md'
- LICENSE
- '**/*.gitignore'
- .editorconfig
- docs/**
pull_request: null
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
build:
strategy:
fail-fast: false
matrix:
settings:
# x86_64
- host: macos-latest
target: x86_64-apple-darwin
build: pnpm build:napi --target x86_64-apple-darwin
- host: windows-latest
build: pnpm build:napi --target x86_64-pc-windows-msvc
target: x86_64-pc-windows-msvc
- host: ubuntu-latest
target: x86_64-unknown-linux-gnu
build: pnpm build:napi --target x86_64-unknown-linux-gnu --use-napi-cross
# ARM
- host: macos-latest
target: aarch64-apple-darwin
build: pnpm build:napi --target aarch64-apple-darwin
- host: ubuntu-latest
target: aarch64-unknown-linux-gnu
build: pnpm build:napi --target aarch64-unknown-linux-gnu --use-napi-cross
- host: windows-latest
target: aarch64-pc-windows-msvc
build: pnpm build:napi --target aarch64-pc-windows-msvc
name: stable - ${{ matrix.settings.target }} - node@20
runs-on: ${{ matrix.settings.host }}
steps:
- uses: actions/checkout@v4
- name: Setup pnpm
uses: pnpm/action-setup@v4
- name: Setup node
uses: actions/setup-node@v4
with:
node-version: 20
cache: pnpm
- name: Setup Rust Toolchain
uses: dtolnay/rust-toolchain@stable
with:
toolchain: stable
targets: ${{ matrix.settings.target }}
- name: Cache cargo
uses: actions/cache@v4
with:
path: |
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
~/.napi-rs
.cargo-cache
target/
key: ${{ matrix.settings.target }}-cargo-${{ matrix.settings.host }}
- name: Install dependencies
run: pnpm install
- name: Build
run: ${{ matrix.settings.build }}
shell: bash
- name: Upload artifact
uses: actions/upload-artifact@v4
with:
name: bindings-${{ matrix.settings.target }}
path: '*.node'
if-no-files-found: error
test-macOS-windows-binding:
name: Test bindings on ${{ matrix.settings.target }} - node@${{ matrix.node }}
needs:
- build
strategy:
fail-fast: false
matrix:
settings:
- host: windows-latest
target: x86_64-pc-windows-msvc
architecture: x64
- host: macos-latest
target: x86_64-apple-darwin
architecture: x64
- host: macos-latest
target: aarch64-apple-darwin
architecture: arm64
node:
- '18'
- '20'
runs-on: ${{ matrix.settings.host }}
steps:
- uses: actions/checkout@v4
- name: setup pnpm
uses: pnpm/action-setup@v4
- name: Setup node
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node }}
cache: pnpm
architecture: ${{ matrix.settings.architecture }}
- name: Install dependencies
run: pnpm install
- name: Download artifacts
uses: actions/download-artifact@v4
with:
name: bindings-${{ matrix.settings.target }}
path: ./packages/critters
- name: List packages
run: ls -R .
shell: bash
- name: Test bindings
run: pnpm test
env:
NAPI_TEST: true
# test-linux-binding:
# name: Test ${{ matrix.target }} - node@${{ matrix.node }}
# needs:
# - build
# strategy:
# fail-fast: false
# matrix:
# target:
# - x86_64-unknown-linux-gnu
# - x86_64-unknown-linux-musl
# - aarch64-unknown-linux-gnu
# - aarch64-unknown-linux-musl
# - armv7-unknown-linux-gnueabihf
# node:
# - '18'
# - '20'
# runs-on: ubuntu-latest
# steps:
# - uses: actions/checkout@v4
# - name: setup pnpm
# uses: pnpm/action-setup@v4
# - name: Setup node
# uses: actions/setup-node@v4
# with:
# node-version: ${{ matrix.node }}
# cache: pnpm
# - name: Output docker params
# id: docker
# run: |
# node -e "
# if ('${{ matrix.target }}'.startsWith('aarch64')) {
# console.log('PLATFORM=linux/arm64')
# } else if ('${{ matrix.target }}'.startsWith('armv7')) {
# console.log('PLATFORM=linux/arm/v7')
# } else {
# console.log('PLATFORM=linux/amd64')
# }
# " >> $GITHUB_OUTPUT
# node -e "
# if ('${{ matrix.target }}'.endsWith('-musl')) {
# console.log('IMAGE=node:${{ matrix.node }}-alpine')
# } else {
# console.log('IMAGE=node:${{ matrix.node }}-slim')
# }
# " >> $GITHUB_OUTPUT
# echo "PNPM_STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_OUTPUT
# # use --force to download the all platform/arch dependencies
# - name: Install dependencies
# run: pnpm install --force
# - name: Download artifacts
# uses: actions/download-artifact@v4
# with:
# name: bindings-${{ matrix.target }}
# path: .
# - name: List packages
# run: ls -R .
# shell: bash
# - name: Set up QEMU
# uses: docker/setup-qemu-action@v3
# with:
# platforms: all
# - run: docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
# - name: Test bindings
# uses: addnab/docker-run-action@v3
# with:
# image: ${{ steps.docker.outputs.IMAGE }}
# options: -v ${{ steps.docker.outputs.PNPM_STORE_PATH }}:${{ steps.docker.outputs.PNPM_STORE_PATH }} -v ${{ github.workspace }}:${{ github.workspace }} -w ${{ github.workspace }} --platform ${{ steps.docker.outputs.PLATFORM }}
# run: npm run test
publish:
name: Publish
runs-on: ubuntu-latest
needs:
- test-macOS-windows-binding
# - test-linux-binding
steps:
- uses: actions/checkout@v4
- name: Setup pnpm
uses: pnpm/action-setup@v4
- name: Setup node
uses: actions/setup-node@v4
with:
node-version: 20
cache: pnpm
- name: Install dependencies
run: pnpm install
- name: Download all artifacts
uses: actions/download-artifact@v4
with:
path: artifacts
- name: Create npm dirs
run: pnpm napi create-npm-dirs
- name: Move artifacts
run: pnpm artifacts
- name: List packages
run: ls -R ./npm
shell: bash
- name: Publish
run: |
npm config set provenance true
if git log -1 --pretty=%B | grep "^v\?[0-9]\+\.[0-9]\+\.[0-9]\+$";
then
echo "//registry.npmjs.org/:_authToken=$NPM_TOKEN" >> ~/.npmrc
npm publish --access public
elif git log -1 --pretty=%B | grep "^v\?[0-9]\+\.[0-9]\+\.[0-9]\+";
then
echo "//registry.npmjs.org/:_authToken=$NPM_TOKEN" >> ~/.npmrc
npm publish --tag next --access public
else
echo "Not a release, skipping publish"
fi
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
6 changes: 5 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@
"version": "0.1.0",
"description": "Quickly inline your website's critical CSS.",
"scripts": {
"build": "moon run :build",
"build:napi": "napi build --package-json-path ./packages/critters/package.json --platform --release --no-js",
"test": "moon run :test",
"lint": "biome lint",
"format": "biome format --write",
"check": "biome check"
Expand All @@ -17,6 +20,7 @@
"packageManager": "[email protected]+sha512.4abf725084d7bcbafbd728bfc7bee61f2f791f977fd87542b3579dcb23504d170d46337945e4c66485cd12d588a0c0e570ed9c477e7ccdd8507cf05f3f92eaca",
"devDependencies": {
"@biomejs/biome": "^1.9.2",
"@moonrepo/cli": "^1.28.3"
"@moonrepo/cli": "^1.28.3",
"@napi-rs/cli": "3.0.0-alpha.63"
}
}
13 changes: 12 additions & 1 deletion packages/critters/build.ts
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,18 @@ const output = await rollup({
plugins: [
pluginCjs({ defaultIsModuleExports: false }),
pluginEsmShim(),
pluginCopy({ targets: [{ src: "pkg/*.{node,ts}", dest: "dist" }] }),
pluginCopy({
targets:
// if the NAPI_TEST environment variable is set, we use the .node file
// from the project directory (usually generated using pipelines),
// instead of using the one created while generating the bindings.
process.env.NAPI_TEST === "true"
? [
{ src: "pkg/*.ts", dest: "dist" },
{ src: "./*.node", dest: "dist" },
]
: [{ src: "pkg/*.{node,ts}", dest: "dist" }],
}),
],
});

Expand Down
1 change: 1 addition & 0 deletions packages/critters/moon.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ tasks:
inputs:
- '@group(crate)'
- '@group(build)'
- '$NAPI_*'
outputs:
- 'dist'
test:
Expand Down
10 changes: 6 additions & 4 deletions packages/critters/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,16 +8,18 @@
"files": [
"dist"
],
"scripts": {
"prepublishOnly": "napi pre-publish -t npm --cwd ../.. --package-json-path ./packages/critters/package.json"
},
"napi": {
"binaryName": "critters-rs",
"targets": [
"x86_64-pc-windows-msvc",
"aarch64-pc-windows-msvc",
"x86_64-apple-darwin",
"aarch64-apple-darwin",
"x86_64-pc-windows-msvc",
"x86_64-unknown-linux-gnu",
"aarch64-apple-darwin",
"aarch64-unknown-linux-gnu",
"aarch64-pc-windows-msvc"
"aarch64-unknown-linux-gnu"
]
},
"devDependencies": {
Expand Down
Loading

0 comments on commit c1a88e3

Please sign in to comment.