Skip to content

Commit

Permalink
chore: pr github workflow (#1)
Browse files Browse the repository at this point in the history
  • Loading branch information
sun0day committed Dec 14, 2023
1 parent 6b1eb23 commit 9da1265
Show file tree
Hide file tree
Showing 6 changed files with 333 additions and 14 deletions.
318 changes: 318 additions & 0 deletions .github/workflows/CI.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,318 @@
name: CI
env:
DEBUG: napi:*
BUILD_CRATE_BIN: ./*packages/**/*.node
BUILD_CRATE_JS: ./*packages/**/core.*
MACOSX_DEPLOYMENT_TARGET: '10.13'
permissions:
contents: write
id-token: write
'on':
push:
branches:
- main
tags-ignore:
- '**'
paths-ignore:
- '**/*.md'
- LICENSE
- '**/*.gitignore'
- .editorconfig
- docs/**
pull_request: null
jobs:
build:
strategy:
fail-fast: false
matrix:
settings:
- host: macos-latest
target: x86_64-apple-darwin
build: |
pnpm repos
pnpm build
strip -x packages/**/*.node
pnpm test && pnpm test:git
- host: windows-latest
build: |
pnpm i -g npm
npm -v
pnpm repos
pnpm build
pnpm test && pnpm test:git
target: x86_64-pc-windows-msvc
- host: windows-latest
build: |
pnpm i -g npm
npm -v
pnpm repos
pnpm build:crate --target i686-pc-windows-msvc
pnpm build:npm
pnpm test && pnpm test:git
target: i686-pc-windows-msvc
- host: ubuntu-latest
target: x86_64-unknown-linux-gnu
docker: ghcr.io/napi-rs/napi-rs/nodejs-rust:lts-debian
build: |-
set -e && unset CC_x86_64_unknown_linux_gnu && unset CC &&
pnpm build:crate --target x86_64-unknown-linux-gnu &&
strip -x packages/**/*.node &&
pnpm build:npm &&
pnpm test
- host: ubuntu-latest
target: x86_64-unknown-linux-musl
docker: ghcr.io/napi-rs/napi-rs/nodejs-rust:lts-alpine
build: set -e && pnpm build && strip -x packages/**/*.node && pnpm test
- host: macos-latest
target: aarch64-apple-darwin
build: |
pnpm build:crate --target aarch64-apple-darwin
strip -x packages/**/*.node
- host: ubuntu-latest
target: aarch64-unknown-linux-gnu
docker: ghcr.io/napi-rs/napi-rs/nodejs-rust:lts-debian-aarch64
build: |-
set -e &&
export JEMALLOC_SYS_WITH_LG_PAGE=16 &&
rustup target add aarch64-unknown-linux-gnu &&
export CC_aarch64_unknown_linux_gnu=/usr/aarch64-unknown-linux-gnu/bin/aarch64-unknown-linux-gnu-gcc
pnpm build:crate --target aarch64-unknown-linux-gnu &&
aarch64-unknown-linux-gnu-strip packages/**/*.node
- host: ubuntu-latest
target: armv7-unknown-linux-gnueabihf
setup: |
sudo apt-get update
sudo apt-get install gcc-arm-linux-gnueabihf -y
build: |
pnpm build:crate --target armv7-unknown-linux-gnueabihf
arm-linux-gnueabihf-strip packages/**/*.node
- host: ubuntu-latest
target: aarch64-linux-android
build: |
pnpm build:crate --target aarch64-linux-android
${ANDROID_NDK_LATEST_HOME}/toolchains/llvm/prebuilt/linux-x86_64/bin/llvm-strip packages/**/*.node
- host: ubuntu-latest
target: armv7-linux-androideabi
build: |
pnpm build:crate --target armv7-linux-androideabi
${ANDROID_NDK_LATEST_HOME}/toolchains/llvm/prebuilt/linux-x86_64/bin/llvm-strip packages/**/*.node
- host: ubuntu-latest
target: aarch64-unknown-linux-musl
docker: ghcr.io/napi-rs/napi-rs/nodejs-rust:lts-alpine
build: |-
set -e &&
rustup target add aarch64-unknown-linux-musl &&
pnpm build:crate --target aarch64-unknown-linux-musl &&
/aarch64-linux-musl-cross/bin/aarch64-linux-musl-strip packages/**/*.node
- host: windows-latest
target: aarch64-pc-windows-msvc
build: |
pnpm build:crate --target aarch64-pc-windows-msvc
node:
- '18'
- '20'
name: stable - ${{ matrix.settings.target }} - node@${{ matrix.node }}
runs-on: ${{ matrix.settings.host }}
steps:
- uses: actions/checkout@v3
- uses: pnpm/action-setup@v2
with:
version: latest
- name: Setup node
uses: actions/setup-node@v3
if: ${{ !matrix.settings.docker }}
with:
node-version: ${{ matrix.node }}
check-latest: true
cache: pnpm
- name: Install
uses: dtolnay/rust-toolchain@stable
if: ${{ !matrix.settings.docker }}
with:
toolchain: stable
targets: ${{ matrix.settings.target }}
- name: Cache cargo
uses: actions/cache@v3
with:
path: |
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
.cargo-cache
target/
key: ${{ matrix.settings.target }}-cargo-${{ matrix.settings.host }}
- uses: goto-bus-stop/setup-zig@v2
if: ${{ matrix.settings.target == 'armv7-unknown-linux-gnueabihf' }}
with:
version: 0.10.1
- name: Setup toolchain
run: ${{ matrix.settings.setup }}
if: ${{ matrix.settings.setup }}
shell: bash
- name: Setup node x86
if: matrix.settings.target == 'i686-pc-windows-msvc'
run: pnpm config set supportedArchitectures.cpu "ia32"
shell: bash
- name: Install dependencies
run: pnpm i -g npm && pnpm install
- name: Setup node x86
uses: actions/setup-node@v3
if: matrix.settings.target == 'i686-pc-windows-msvc'
with:
node-version: ${{ matrix.node }}
check-latest: true
cache: pnpm
architecture: x86
- name: Build in docker
uses: addnab/docker-run-action@v3
if: ${{ matrix.settings.docker }}
with:
image: ${{ matrix.settings.docker }}
options: '--user 0:0 -v ${{ github.workspace }}/.cargo-cache/git/db:/usr/local/cargo/git/db -v ${{ github.workspace }}/.cargo/registry/cache:/usr/local/cargo/registry/cache -v ${{ github.workspace }}/.cargo/registry/index:/usr/local/cargo/registry/index -v ${{ github.workspace }}:/build -w /build'
run: ${{ matrix.settings.build }}
- name: Build
run: ${{ matrix.settings.build }}
if: ${{ !matrix.settings.docker }}
shell: bash
- name: Upload artifact
uses: actions/upload-artifact@v3
with:
name: bindings-${{ matrix.settings.target }}
path: |
${{ env.BUILD_CRATE_BIN }}
${{ env.BUILD_CRATE_JS }}
if-no-files-found: error
build-freebsd:
runs-on: ubuntu-latest
name: Build FreeBSD
steps:
- uses: actions/checkout@v3
- name: Build
id: build
uses: vmactions/freebsd-vm@v1
env:
DEBUG: napi:*
RUSTUP_HOME: /usr/local/rustup
CARGO_HOME: /usr/local/cargo
RUSTUP_IO_THREADS: 1
with:
envs: DEBUG RUSTUP_HOME CARGO_HOME RUSTUP_IO_THREADS
usesh: true
mem: 3000
prepare: |
pkg install -y -f curl node libnghttp2 npm
curl https://sh.rustup.rs -sSf --output rustup.sh
sh rustup.sh -y --profile minimal --default-toolchain beta
export PATH="/usr/local/cargo/bin:$PATH"
npm i -g pnpm
echo "~~~~ rustc --version ~~~~"
rustc --version
echo "~~~~ node -v ~~~~"
node -v
echo "~~~~ pnpm --version ~~~~"
pnpm --version
run: |
export PATH="/usr/local/cargo/bin:$PATH"
pwd
ls -lah
whoami
env
freebsd-version
GITHUB_EVENT_PATH= pnpm install
GITHUB_EVENT_PATH= pnpm build
strip -x packages/**/*.node
GITHUB_EVENT_PATH= pnpm test
rm -rf ./**/node_modules
rm -rf ./**/target
echo "~~~~ wait to upload ~~~~"
- name: Upload artifact
uses: actions/upload-artifact@v3
with:
name: bindings-freebsd
path: |
${{ env.BUILD_CRATE_BIN }}
${{ env.BUILD_CRATE_JS }}
if-no-files-found: error
universal-macOS:
name: Build universal macOS binary
needs:
- build
runs-on: macos-latest
steps:
- uses: actions/checkout@v3
- uses: pnpm/action-setup@v2
with:
version: latest
- name: Setup node
uses: actions/setup-node@v3
with:
node-version: 18
check-latest: true
cache: pnpm
- name: Install dependencies
run: pnpm i -g npm && pnpm install
- name: Download macOS x64 artifact
uses: actions/download-artifact@v3
with:
name: bindings-x86_64-apple-darwin
path: artifacts
- name: Download macOS arm64 artifact
uses: actions/download-artifact@v3
with:
name: bindings-aarch64-apple-darwin
path: artifacts
- name: Combine binaries
run: pnpm universal
- name: Upload artifact
uses: actions/upload-artifact@v3
with:
name: bindings-universal-apple-darwin
path: |
${{ env.BUILD_CRATE_BIN }}
${{ env.BUILD_CRATE_JS }}
if-no-files-found: error
publish:
name: Publish
runs-on: ubuntu-latest
needs:
- build-freebsd
- universal-macOS
steps:
- uses: actions/checkout@v3
- uses: pnpm/action-setup@v2
with:
version: latest
- name: Setup node
uses: actions/setup-node@v3
with:
node-version: 18
check-latest: true
cache: pnpm
- name: Install dependencies
run: pnpm i -g npm && pnpm install
- name: Download all artifacts
uses: actions/download-artifact@v3
with:
path: artifacts
- 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 "^[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 "^[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 }}
2 changes: 0 additions & 2 deletions crates/napi/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
#![deny(clippy::all)]

use std::str::Split;

use easy_ast_resolver::{Alias, AliasValue, ModuleResolver};
use napi::bindgen_prelude::Buffer;

Expand Down
11 changes: 7 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,15 @@
"main": "index.js",
"scripts": {
"bench": "pnpm --filter \"*bench*\" run bench",
"build:npm": "pnpm --filter \"{packages/**}\" run build",
"install:test": "cd packages/import/__test__/fixture/code && npm i",
"build": "pnpm build:crate && pnpm build:npm",
"build:crate": "pnpm --filter \"{packages/**}\" run build:crate",
"build:npm": "pnpm --filter \"{packages/**}\" run build:npm",
"install:test": "cd packages/graph/__test__/fixture/code && npm i",
"parse": "it",
"postinstall": "pnpm repos && pnpm install:test",
"postinstall": "pnpm install:test",
"repos": "node scripts/git-repo.mjs",
"test": "pnpm --filter \"{packages/**}\" run test"
"test": "pnpm --filter \"{packages/**}\" run test",
"test:git": "pnpm --filter \"{packages/**}\" run test:git"
},
"keywords": [],
"author": "",
Expand Down
4 changes: 2 additions & 2 deletions packages/graph/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,9 @@ napi-build = "2.0.1"

[profile.release]
# This removes more dead code
#codegen-units = 1
codegen-units = 1
lto = true
# Optimize for size
opt-level = "s"
# Strip debug symbols
#strip = "symbols"
strip = "symbols"
6 changes: 3 additions & 3 deletions packages/graph/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -50,12 +50,12 @@
},
"scripts": {
"artifacts": "napi artifacts",
"build": "napi build --platform --release --dts core.d.ts --js core.js && tsc",
"build:crate": "napi build --platform --release --dts core.d.ts --js core.js",
"build:npm": "tsc",
"build:debug": "napi build --platform",
"prepublishOnly": "napi prepublish -t npm",
"test:mock": "ava --config ./ava.config.mjs",
"test": "ava --config ./ava.config.mjs",
"test:git": "ava --config ./ava.config.git.mjs",
"test": "npm run test:mock && npm run test:git",
"universal": "napi universal",
"version": "napi version"
}
Expand Down
Loading

0 comments on commit 9da1265

Please sign in to comment.