-
Notifications
You must be signed in to change notification settings - Fork 111
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
3 changed files
with
200 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
name: Build crates individually | ||
|
||
# We need to keep the `matrix` job in this workflow as-is, as we need the results | ||
# to actually match the same `build` job names from the original file. | ||
on: | ||
pull_request: | ||
paths-ignore: | ||
# production code and test code | ||
- '**/*.rs' | ||
# dependencies | ||
- '**/Cargo.toml' | ||
- '**/Cargo.lock' | ||
# workflow definitions | ||
- '.github/workflows/build-crates-individually.yml' | ||
|
||
jobs: | ||
matrix: | ||
name: Crates matrix | ||
runs-on: ubuntu-latest | ||
outputs: | ||
matrix: ${{ steps.set-matrix.outputs.matrix }} | ||
steps: | ||
- uses: actions/[email protected] | ||
|
||
- uses: actions-rs/toolchain@v1 | ||
with: | ||
toolchain: stable | ||
profile: minimal | ||
override: true | ||
|
||
- uses: actions-rs/[email protected] | ||
# This step is meant to dynamically create a JSON containing the values of each crate | ||
# available in this repo in the root directory. We use `cargo tree` to accomplish this task. | ||
# | ||
# The result from `cargo tree` is then transform to JSON values between double quotes, | ||
# and separated by commas, then added to a `crates.txt` and assigned to a $JSON_CRATES variable. | ||
# | ||
# A JSON object is created and assigned to a $MATRIX variable, which is use to create an output | ||
# named `matrix`, which is then used as the input in following steps, | ||
# using ` ${{ fromJson(needs.matrix.outputs.matrix) }}` | ||
- id: set-matrix | ||
name: Dynamically build crates JSON | ||
run: | | ||
TEMP_DIR=$(mktemp -d) | ||
echo "$(cargo tree --depth 0 --edges no-normal,no-dev,no-build,no-proc-macro --prefix none | cut -d ' ' -f1 | sed '/^$/d' | awk '{ printf "\"%s\",\n", $0 }' | sed '$ s/.$//')" > $TEMP_DIR/crates.txt | ||
MATRIX=$( ( | ||
echo '{ "crate" : [' | ||
echo "$(cat $TEMP_DIR/crates.txt)" | ||
echo " ]}" | ||
) | jq -c .) | ||
echo $MATRIX | ||
echo $MATRIX | jq . | ||
echo "::set-output name=matrix::$MATRIX" | ||
check-matrix: | ||
runs-on: ubuntu-latest | ||
needs: [ matrix ] | ||
steps: | ||
- run: 'echo "No job required"' | ||
|
||
build: | ||
name: Build ${{ matrix.crate }} crate | ||
needs: [ matrix, check-matrix ] | ||
runs-on: ubuntu-latest | ||
strategy: | ||
matrix: ${{ fromJson(needs.matrix.outputs.matrix) }} | ||
|
||
steps: | ||
- run: 'echo "No job required"' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,125 @@ | ||
name: Build crates individually | ||
|
||
on: | ||
workflow_dispatch: | ||
push: | ||
branches: | ||
- main | ||
paths: | ||
# production code and test code | ||
- '**/*.rs' | ||
# dependencies | ||
- '**/Cargo.toml' | ||
- '**/Cargo.lock' | ||
# workflow definitions | ||
- '.github/workflows/build-crates-individually.yml' | ||
pull_request: | ||
paths: | ||
# production code and test code | ||
- '**/*.rs' | ||
# dependencies | ||
- '**/Cargo.toml' | ||
- '**/Cargo.lock' | ||
# workflow definitions | ||
- '.github/workflows/build-crates-individually.yml' | ||
|
||
env: | ||
CARGO_INCREMENTAL: 0 | ||
RUST_BACKTRACE: full | ||
RUST_LIB_BACKTRACE: full | ||
COLORBT_SHOW_HIDDEN: '1' | ||
|
||
jobs: | ||
matrix: | ||
name: Crates matrix | ||
runs-on: ubuntu-latest | ||
outputs: | ||
matrix: ${{ steps.set-matrix.outputs.matrix }} | ||
steps: | ||
- uses: actions/[email protected] | ||
|
||
- uses: actions-rs/toolchain@v1 | ||
with: | ||
toolchain: stable | ||
profile: minimal | ||
override: true | ||
|
||
- uses: actions-rs/[email protected] | ||
# This step is meant to dynamically create a JSON containing the values of each crate | ||
# available in this repo in the root directory. We use `cargo tree` to accomplish this task. | ||
# | ||
# The result from `cargo tree` is then transform to JSON values between double quotes, | ||
# and separated by commas, then added to a `crates.txt` and assigned to a $JSON_CRATES variable. | ||
# | ||
# A JSON object is created and assigned to a $MATRIX variable, which is use to create an output | ||
# named `matrix`, which is then used as the input in following steps, | ||
# using ` ${{ fromJson(needs.matrix.outputs.matrix) }}` | ||
- id: set-matrix | ||
name: Dynamically build crates JSON | ||
run: | | ||
TEMP_DIR=$(mktemp -d) | ||
echo "$(cargo tree --depth 0 --edges no-normal,no-dev,no-build,no-proc-macro --prefix none | cut -d ' ' -f1 | sed '/^$/d' | awk '{ printf "\"%s\",\n", $0 }' | sed '$ s/.$//')" > $TEMP_DIR/crates.txt | ||
MATRIX=$( ( | ||
echo '{ "crate" : [' | ||
echo "$(cat $TEMP_DIR/crates.txt)" | ||
echo " ]}" | ||
) | jq -c .) | ||
echo $MATRIX | ||
echo $MATRIX | jq . | ||
echo "::set-output name=matrix::$MATRIX" | ||
check-matrix: | ||
runs-on: ubuntu-latest | ||
needs: [ matrix ] | ||
steps: | ||
- name: Install json2yaml | ||
run: | | ||
sudo npm install -g json2yaml | ||
- name: Check matrix definition | ||
run: | | ||
matrix='${{ needs.matrix.outputs.matrix }}' | ||
echo $matrix | ||
echo $matrix | jq . | ||
echo $matrix | json2yaml | ||
build: | ||
name: Build ${{ matrix.crate }} crate | ||
needs: [ matrix, check-matrix ] | ||
runs-on: ubuntu-latest | ||
strategy: | ||
fail-fast: true | ||
matrix: ${{ fromJson(needs.matrix.outputs.matrix) }} | ||
|
||
steps: | ||
- uses: actions/[email protected] | ||
with: | ||
persist-credentials: false | ||
|
||
- uses: actions-rs/toolchain@v1 | ||
with: | ||
toolchain: stable | ||
profile: minimal | ||
override: true | ||
|
||
# We could use `features: ['', '--all-features', '--no-default-features']` as a matrix argument, | ||
# but it's faster to run these commands sequentially, so they can re-use the local cargo cache. | ||
# | ||
# Some Zebra crates do not have any features, and most don't have any default features. | ||
- name: Build ${{ matrix.crate }} crate with no default features | ||
uses: actions-rs/[email protected] | ||
with: | ||
command: build | ||
args: --package ${{ matrix.crate }} --no-default-features | ||
|
||
- name: Build ${{ matrix.crate }} crate normally | ||
uses: actions-rs/[email protected] | ||
with: | ||
command: build | ||
args: --package ${{ matrix.crate }} | ||
|
||
- name: Build ${{ matrix.crate }} crate with all features | ||
uses: actions-rs/[email protected] | ||
with: | ||
command: build | ||
args: --package ${{ matrix.crate }} --all-features |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters