Skip to content

Commit

Permalink
.github: added github actions
Browse files Browse the repository at this point in the history
  • Loading branch information
thom-nic committed Oct 27, 2023
1 parent 0da2a15 commit 6ccf62d
Show file tree
Hide file tree
Showing 9 changed files with 161 additions and 84 deletions.
101 changes: 101 additions & 0 deletions .github/workflows/build-pack-publish.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
name: Prebuildify, package, publish

on:
push:
branches: [ master ]
pull_request:
branches: [ master ]
release:
types: [ prereleased, released ]

jobs:

build:
runs-on: ubuntu-latest
strategy:
matrix:
arch: [x64, arm, arm64]
steps:
- uses: actions/checkout@v2
- uses: docker/setup-qemu-action@v1
with:
image: tonistiigi/binfmt:latest
platforms: arm,arm64 #all
- run: docker build . -f ./Dockerfile-${{ matrix.arch }}
--tag node-bcrypt-builder-${{ matrix.arch }}
- run: docker create --name node-bcryptjs-builder node-bcrypt-builder-${{ matrix.arch }}
- run: docker cp "node-bcryptjs-builder:/usr/local/opt/bcrypt-js/prebuilds" .
- run: find prebuilds
- uses: actions/upload-artifact@v2
with:
name: prebuild-${{ matrix.arch }}
path: ./prebuilds

pack:
needs: build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions/setup-node@v2
with:
node-version: 20
registry-url: 'https://registry.npmjs.org'
- run: npm ci
- uses: actions/download-artifact@v2
with:
path: /tmp/prebuilds/
- name: Coalesce prebuilds from build matrix
run: |
mkdir prebuilds
for d in /tmp/prebuilds/*; do
mv $d/* prebuilds/
done
- run: chmod a+x prebuilds/*/*.node && find prebuilds -executable -type f
- run: echo "PACK_FILE=$(npm pack)" >> $GITHUB_ENV
- uses: actions/upload-artifact@v2
with:
name: package-tgz
path: ${{ env.PACK_FILE }}

publish-npm:
needs: pack
if: github.event_name == 'release'
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions/setup-node@v2
with:
node-version: 20
registry-url: 'https://registry.npmjs.org'
- uses: actions/download-artifact@v2
with:
name: package-tgz
path: /tmp/package/
- run: npm publish /tmp/package/bcrypt*.tgz
env:
NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}}

publish-gpr:
needs: pack
if: github.event_name == 'release'
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- uses: actions/checkout@v2
- uses: actions/setup-node@v2
with:
node-version: 20
registry-url: https://npm.pkg.github.com/
- uses: actions/download-artifact@v2
with:
name: package-tgz
path: /tmp/package/
- run: npm publish /tmp/package/bcrypt*.tgz
env:
NODE_AUTH_TOKEN: ${{secrets.GITHUB_TOKEN}}




9 changes: 3 additions & 6 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -13,24 +13,21 @@ jobs:
runs-on: ubuntu-22.04
strategy:
matrix:
node-version: [14.x, 16.x, 18.x]
node-version: [14, 16, 18, 20]
steps:
- uses: actions/checkout@v2
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v1
uses: actions/setup-node@v2
with:
node-version: ${{ matrix.node-version }}
- name: Install dependencies
run: |
sudo apt-get install -y python3 make g++
- name: Test
run: npm test

build-alpine:
runs-on: ubuntu-22.04
strategy:
matrix:
node-version: [14, 16, 18]
node-version: [14, 16, 18, 20]
container:
image: node:${{ matrix.node-version }}-alpine
steps:
Expand Down
1 change: 1 addition & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ node_js:
- '16'
- '17'
- '18'
- '18'

addons:
apt:
Expand Down
67 changes: 0 additions & 67 deletions Dockerfile

This file was deleted.

4 changes: 2 additions & 2 deletions Dockerfile-arm
Original file line number Diff line number Diff line change
Expand Up @@ -20,15 +20,15 @@ RUN echo "#log: ${project}: Setup system" \
python3 \
&& apt-get clean \
&& update-alternatives --install /usr/local/bin/python python /usr/bin/python3 20 \
&& npm i -g prebuildify node-gyp \
&& npm i -g prebuildify node-gyp nodeunit \
&& sync

ADD . /usr/local/opt/${project}
WORKDIR /usr/local/opt/${project}

RUN echo "#log: ${project}: Running build" \
&& set -x \
&& npm i \
&& npm ci \
&& npm run build

ARG RUN_TESTS=true
Expand Down
4 changes: 2 additions & 2 deletions Dockerfile-arm64
Original file line number Diff line number Diff line change
Expand Up @@ -20,15 +20,15 @@ RUN echo "#log: ${project}: Setup system" \
python3 \
&& apt-get clean \
&& update-alternatives --install /usr/local/bin/python python /usr/bin/python3 20 \
&& npm i -g prebuildify node-gyp \
&& npm i -g prebuildify node-gyp nodeunit \
&& sync

ADD . /usr/local/opt/${project}
WORKDIR /usr/local/opt/${project}

RUN echo "#log: ${project}: Running build" \
&& set -x \
&& npm i \
&& npm ci \
&& npm run build

ARG RUN_TESTS=true
Expand Down
43 changes: 43 additions & 0 deletions Dockerfile-x64
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
# Usage:
#
# docker build -t bcryptjs-linux-x64-builder .
# docker create --name donut bcryptjs-linux-x64-builder
# # Then copy the artifact to your host:
# docker cp donut:/usr/local/opt/bcrypt-js/prebuilds .

FROM node:14-bullseye

ENV project bcrypt-js
ENV DEBIAN_FRONTEND noninteractive
ENV LC_ALL en_US.UTF-8
ENV LANG ${LC_ALL}

RUN echo "#log: ${project}: Setup system" \
&& set -x \
&& apt-get update -y \
&& apt-get install -y \
build-essential \
python3 \
&& apt-get clean \
&& update-alternatives --install /usr/local/bin/python python /usr/bin/python3 20 \
&& npm i -g prebuildify node-gyp nodeunit \
&& sync

ADD . /usr/local/opt/${project}
WORKDIR /usr/local/opt/${project}

RUN echo "#log: ${project}: Running build" \
&& set -x \
&& npm ci \
&& npm run build

ARG RUN_TESTS=true

RUN if "${RUN_TESTS}"; then \
echo "#log ${project}: Running tests" \
&& npm test; \
else \
echo "#log ${project}: Tests were skipped!"; \
fi

CMD /bin/bash -l
2 changes: 2 additions & 0 deletions appveyor.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ environment:
platform: x86
- nodejs_version: "18"
platform: x64
- nodejs_version: "20"
platform: x64

install:
- where npm
Expand Down
14 changes: 7 additions & 7 deletions build-all.sh
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
#!/bin/bash -ue

CLEAN=${CLEAN:-""}
RUN_TESTS=${RUN_TESTS:-false} # tests presently fail on arm :(
RUN_TESTS=${RUN_TESTS:-true}

if [ -n "$CLEAN" ]; then
rm -rf build build-tmp*
Expand All @@ -14,24 +14,24 @@ npm run build

# build for linux/x64:
if [ ! -d prebuilds/linux-x64 ]; then
docker build -t voltserver/bcryptjs-linux-x64-builder .
CONTAINER=$(docker create voltserver/bcryptjs-linux-x64-builder)
docker build -t bcryptjs-linux-x64-builder -f Dockerfile-x64 --build-arg RUN_TESTS="$RUN_TESTS" .
CONTAINER=$(docker create bcryptjs-linux-x64-builder)
docker cp "$CONTAINER:/usr/local/opt/bcrypt-js/prebuilds" .
docker rm "$CONTAINER"
fi

# build for linux/arm32:
if [ ! -d prebuilds/linux-arm ]; then
docker build -t voltserver/bcryptjs-linux-arm-builder -f Dockerfile-arm --build-arg RUN_TESTS="$RUN_TESTS" .
CONTAINER=$(docker create --platform linux/arm/v7 voltserver/bcryptjs-linux-arm-builder)
docker build -t bcryptjs-linux-arm-builder -f Dockerfile-arm --build-arg RUN_TESTS="$RUN_TESTS" .
CONTAINER=$(docker create --platform linux/arm/v7 bcryptjs-linux-arm-builder)
docker cp "$CONTAINER:/usr/local/opt/bcrypt-js/prebuilds" .
docker rm "$CONTAINER"
fi

# build for linux/arm64:
if [ ! -d prebuilds/linux-arm64 ]; then
docker build -t voltserver/bcryptjs-linux-arm64-builder -f Dockerfile-arm64 --build-arg RUN_TESTS="$RUN_TESTS" .
CONTAINER=$(docker create --platform linux/arm64/v8 voltserver/bcryptjs-linux-arm64-builder)
docker build -t bcryptjs-linux-arm64-builder -f Dockerfile-arm64 --build-arg RUN_TESTS="$RUN_TESTS" .
CONTAINER=$(docker create --platform linux/arm64/v8 bcryptjs-linux-arm64-builder)
docker cp "$CONTAINER:/usr/local/opt/bcrypt-js/prebuilds" .
docker rm "$CONTAINER"
fi
Expand Down

0 comments on commit 6ccf62d

Please sign in to comment.