Add libimageflow.a to github release #34
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
# Before each logical part, we include comments describing reasoning and goals. | |
name: "Test/Release" | |
# ------------------------------------------------------------------------------ | |
# Reasoning: We combine the triggers from both test_ci (push, pull_request, | |
# workflow_dispatch) and release_ci (release published). This allows the same | |
# workflow to operate in "test mode" for normal PRs/commits and in "release | |
# mode" when a new release is published or created via workflow dispatch. | |
# ------------------------------------------------------------------------------ | |
on: | |
push: | |
branches: | |
- "*" | |
tags-ignore: | |
- "v*" | |
pull_request: | |
workflow_dispatch: | |
release: | |
types: | |
- published | |
jobs: | |
build: | |
env: | |
# From release_ci: | |
NUGET_UPLOAD_NUGET: ${{ secrets.NUGET_UPLOAD_NUGET }} | |
NUGET_UPLOAD_GITHUB: ${{ secrets.NUGET_UPLOAD_GITHUB }} | |
HTTPS_IMAGEFLOW_NIGHTLIES: "https://s3-us-west-1.amazonaws.com/imageflow-nightlies" | |
DOCKER_FETCH_COMMIT_SUFFIX: linux64 | |
PROFILE: release | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
- name: linux-x64 | |
suffix: ubuntu-x86_64 | |
os: ubuntu-20.04 | |
target-cpu: x86-64 | |
commit-suffix: linux64 | |
nuget-rid: linux-x64 | |
target: x86_64-unknown-linux-gnu | |
cross: 'true' | |
max-glibc: '2.29' | |
# skip-publish, for testing only. | |
- name: linux-x64-ubuntu-24 | |
suffix: ubuntu-x86_64-24 | |
os: ubuntu-24.04 | |
target-cpu: x86-64 | |
commit-suffix: linux64_24 | |
nuget-rid: linux-x64 | |
target: x86_64-unknown-linux-gnu | |
skip-publish: 'true' | |
- name: linux-arm64-ubuntu-22 | |
suffix: ubuntu-arm64 | |
os: ubuntu-22-arm-32gb | |
target-cpu: generic | |
commit-suffix: linux_arm64 | |
nuget-rid: linux-arm64 | |
target: aarch64-unknown-linux-gnu | |
features: neon | |
cross: 'true' | |
max-glibc: '2.39' | |
- name: osx-x64-13 | |
suffix: osx-x86_64 | |
os: macos-13 | |
target-cpu: haswell | |
commit-suffix: mac64 | |
nuget-rid: osx-x64 | |
target: x86_64-apple-darwin | |
- name: osx-arm64-14 | |
suffix: osx-arm64 | |
os: macos-14 | |
target-cpu: apple-m1 | |
commit-suffix: osx-arm64 | |
nuget-rid: osx-arm64 | |
target: aarch64-apple-darwin | |
- name: win-x64-2022 | |
suffix: win-x86_64 | |
os: windows-2022 | |
target-cpu: x86-64 | |
commit-suffix: win-x86_64 | |
nuget-rid: win-x64 | |
target: x86_64-pc-windows-msvc | |
- name: win-x86-2022 | |
suffix: win-x86 | |
os: windows-2022 | |
# target-cpu: generic # any target-cpu causes the build to fail | |
commit-suffix: win-x86 | |
nuget-rid: win-x86 | |
target: i686-pc-windows-msvc | |
- name: win-arm64-11 | |
suffix: win-arm64 | |
os: windows-11-arm-32gb | |
target-cpu: generic | |
commit-suffix: win-arm64 | |
nuget-rid: win-arm64 | |
target: aarch64-pc-windows-msvc | |
woa: 'true' | |
- name: linux-musl-x64 | |
suffix: linux-musl-x64 | |
commit-suffix: linux-musl-x64 | |
nuget-rid: linux-musl-x64 | |
os: ubuntu-24.04 | |
target-cpu: x86-64 | |
target: x86_64-unknown-linux-musl | |
features: mimalloc | |
cross: 'true' | |
skip-publish: 'true' | |
- name: linux-musl-arm64 | |
suffix: linux-musl-arm64 | |
commit-suffix: linux-musl-arm64 | |
nuget-rid: linux-musl-arm64 | |
os: ubuntu-22-arm-32gb | |
target-cpu: generic | |
target: aarch64-unknown-linux-musl | |
features: mimalloc | |
cross: 'true' | |
skip-publish: 'true' | |
runs-on: ${{ matrix.os }} | |
name: "${{ (matrix.cross == 'true') && 'cross ' || ''}}${{ matrix.name }}${{ matrix.target-cpu && format(' cpu: {0}', matrix.target-cpu) }}${{ matrix.target && format(' target: {0}', matrix.target) }}${{ matrix.features && format(' features: {0}', matrix.features) }} runs-on:${{ matrix.os }}" | |
steps: | |
- name: "Goal: ${{ matrix.skip-publish != 'true' && github.event_name == 'release' && 'publish' || 'test' }} Imageflow.NativeRuntime.${{ matrix.suffix }} & Imageflow.NativeTool.${{ matrix.suffix }} with RID ${{ matrix.nuget-rid }}" | |
run: echo "Hi" | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: "WOA: Setup Windows ARM64" | |
uses: ./.github/actions/setup-win-arm64 | |
if: matrix.woa == 'true' | |
- name: "WOA: Checkout code again with git, so git commands work." | |
uses: actions/checkout@v4 | |
if: matrix.woa == 'true' | |
# ---------------------------------------------------------------------------- | |
# cross and woa handle caching & rust toolchains separately | |
# ---------------------------------------------------------------------------- | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
key: ${{ matrix.name }} | |
if: matrix.cross != 'true' | |
- uses: dtolnay/rust-toolchain@stable | |
if: matrix.cross != 'true' && matrix.woa != 'true' | |
- run: rustup show | |
- name: Install NASM | |
uses: ./.github/actions/install-nasm | |
if: matrix.cross != 'true' && matrix.woa != 'true' | |
- name: Install i686 target | |
if: ${{ matrix.target == 'i686-pc-windows-msvc' && matrix.cross != 'true' }} | |
uses: dtolnay/rust-toolchain@stable | |
with: | |
target: i686-pc-windows-msvc | |
- run: rustup show | |
# ---------------------------------------------------------------------------- | |
# Provides GITHUB_SHA_SHORT and others | |
# ---------------------------------------------------------------------------- | |
- uses: FranzDiebold/[email protected] | |
# ---------------------------------------------------------------------------- | |
# Distinguish extension between .zip (Windows) and .tar.gz (other OS) | |
# ---------------------------------------------------------------------------- | |
- name: Set EXTENSION=zip if windows | |
if: contains(matrix.os, 'windows') | |
shell: bash | |
run: echo "EXTENSION=zip" >> $GITHUB_ENV | |
- name: Set EXTENSION=tar.gz if not windows | |
if: ${{ !contains(matrix.os, 'windows') }} | |
shell: bash | |
run: echo "EXTENSION=tar.gz" >> $GITHUB_ENV | |
# ---------------------------------------------------------------------------- | |
# Setup environment variables used by both test and release flows. | |
# We combine logic from both test_ci and release_ci for cross build/test setups. | |
# ---------------------------------------------------------------------------- | |
- name: Set ENV vars | |
shell: bash | |
run: | | |
# This is from release_ci | |
echo "TARGET_DIR=target/${{ matrix.target }}/" >> $GITHUB_ENV | |
echo "TAG_SHA_SUFFIX=${{ github.ref_name }}-${{ env.GITHUB_SHA_SHORT }}-${{ matrix.suffix }}" >> $GITHUB_ENV | |
echo "RUSTFLAGS=${{ matrix.target-cpu && format('-Ctarget-cpu={0}', matrix.target-cpu) }} ${{ matrix.target-feature && format('-Ctarget-feature={0}', matrix.target-feature) }}" >> $GITHUB_ENV | |
echo "CARGO_PROFILE_TARGET_FEATURES_ARGS=--${{ env.PROFILE }} ${{ matrix.target && format('--target={0}',matrix.target) }} ${{ matrix.features && format('--features={0}',matrix.features) }}" >> $GITHUB_ENV | |
echo "CROSS_ARGS=--locked --${{ env.PROFILE }} ${{ matrix.features && format('--features={0}',matrix.features) }}" >> $GITHUB_ENV | |
echo "REL_BINARIES_DIR=target/${{ matrix.target }}/${{ env.PROFILE }}/" >> $GITHUB_ENV | |
echo "BUILD_EXCLUDE=${{ matrix.build-exclude && format('--exclude={0}',matrix.build-exclude) }}" >> $GITHUB_ENV | |
echo "ALLOW_PUBLISH=${{ matrix.skip-publish != 'true' && github.event_name == 'release' && 'true' || 'false' }}" >> $GITHUB_ENV | |
echo "LIBIMAGEFLOW_DYNAMIC=${{ contains(matrix.target, 'win') && 'imageflow.dll' || contains(matrix.target, 'apple') && 'libimageflow.dylib' || 'libimageflow.so' }}" >> $GITHUB_ENV | |
echo "LIBIMAGEFLOW_STATIC=${{ contains(matrix.target, 'win') && 'imageflow.lib' || 'libimageflow.a' }}" >> $GITHUB_ENV | |
# ---------------------------------------------------------------------------- | |
# More environment variables that are used for artifact naming/publishing | |
# in release mode. In test mode, they are still set, but only relevant if we | |
# actually do the release steps (conditional on event type). | |
# ---------------------------------------------------------------------------- | |
- name: Set env vars for artifacts | |
shell: bash | |
run: | | |
echo "IMAGEFLOW_TAG_SHA_SUFFIX=imageflow-${{ env.TAG_SHA_SUFFIX }}" >> $GITHUB_ENV | |
echo "IMAGEFLOW_TOOL_PATH=${{ env.REL_BINARIES_DIR }}imageflow_tool${{ contains(matrix.os, 'windows') && '.exe' || '' }}" >> $GITHUB_ENV | |
echo "RELATIVE_GITHUB_ARCHIVE=./artifacts/github/imageflow-${{ env.TAG_SHA_SUFFIX }}.${{ env.EXTENSION }}" >> $GITHUB_ENV | |
echo "ESTIMATED_ARTIFACT_URL=${{ env.HTTPS_IMAGEFLOW_NIGHTLIES }}/releases/${{ github.ref_name }}/${{ env.IMAGEFLOW_TAG_SHA_SUFFIX }}.${{ env.EXTENSION }}" >> $GITHUB_ENV | |
echo "ESTIMATED_ARTIFACT_URL_COMMITS=${{ env.HTTPS_IMAGEFLOW_NIGHTLIES }}/commits/${{ github.sha }}/${{ matrix.commit-suffix }}.${{ env.EXTENSION }}" >> $GITHUB_ENV | |
echo "ESTIMATED_MUSL_VERSIONED_URL=${{ env.HTTPS_IMAGEFLOW_NIGHTLIES }}/static/${{ github.ref_name }}/${{ env.IMAGEFLOW_TAG_SHA_SUFFIX }}.${{ env.EXTENSION }}" >> $GITHUB_ENV | |
echo "ESTIMATED_MUSL_LATEST_URL=${{ env.HTTPS_IMAGEFLOW_NIGHTLIES }}/static/latest/${{ matrix.target }}.${{ env.EXTENSION }}" >> $GITHUB_ENV | |
echo "FETCH_COMMIT_SUFFIX=${{ matrix.commit-suffix }}" >> $GITHUB_ENV | |
echo "CI_TAG=${{ github.ref_name }}" >> $GITHUB_ENV | |
echo "CI=True" >> $GITHUB_ENV | |
echo "CI_REPO=${{ github.repository }}" >> $GITHUB_ENV | |
echo "CI_JOB_URL=https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}" >> $GITHUB_ENV | |
echo "CI_JOB_TITLE=GitHub ${{ github.job_id }} ${{ matrix.name }}" >> $GITHUB_ENV | |
echo "CI_STRING=GitHub actions" >> $GITHUB_ENV | |
echo "CI_PULL_REQUEST_INFO=${{ github.event_name!='release' }}" >> $GITHUB_ENV | |
echo "CI_BUILD_URL=https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}" >> $GITHUB_ENV | |
echo "ESTIMATED_DOCS_URL=${{ env.HTTPS_IMAGEFLOW_NIGHTLIES }}/doc" >> $GITHUB_ENV | |
echo "DEBUG=False" >> $GITHUB_ENV | |
echo "TARGET_CPU=${{ matrix.target-cpu }}" >> $GITHUB_ENV | |
- if: contains(matrix.target, 'musl') | |
name: "Edit imageflow_abi/Cargo.toml to build staticlib instead of cdylib and use strip and lto" | |
run: | | |
echo "Editing imageflow_abi/Cargo.toml to replace the string \"[\"cdylib\"]\" with \"[\"staticlib\"]\"" | |
sed -i 's/\["cdylib"\]/\["staticlib"\]/g' imageflow_abi/Cargo.toml | |
echo "Editing ./Cargo.toml to remove all instances of '# enable on musl: '" | |
sed -i '/# enable on musl:/d' ./Cargo.toml | |
echo "Finished editing imageflow_abi/Cargo.toml: " | |
cat imageflow_abi/Cargo.toml | |
# ---------------------------------------------------------------------------- | |
# Test steps (like in both test_ci and release_ci). | |
# For cross and WOA, special steps are used, otherwise normal cargo test. | |
# ---------------------------------------------------------------------------- | |
- name: "cargo test --all --locked ${{ env.CARGO_PROFILE_TARGET_FEATURES_ARGS }}" | |
run: cargo test --all --locked ${{ env.CARGO_PROFILE_TARGET_FEATURES_ARGS }} | |
shell: bash | |
if: matrix.cross != 'true' && matrix.woa != 'true' | |
- name: "& Launch-VsDevShell.ps1 | cargo test --all ${{ env.CARGO_PROFILE_TARGET_FEATURES_ARGS }}" | |
run: "& Launch-VsDevShell.ps1 | cargo test --all ${{ env.CARGO_PROFILE_TARGET_FEATURES_ARGS }}" | |
shell: powershell | |
if: matrix.woa == 'true' | |
- name: "cross cargo test --target ${{ matrix.target }} ${{ env.CROSS_ARGS }}" | |
uses: houseabsolute/[email protected] | |
with: | |
command: "test" | |
target: ${{ matrix.target }} | |
toolchain: stable | |
args: "${{ env.CROSS_ARGS }}" | |
if: matrix.cross == 'true' | |
# ---------------------------------------------------------------------------- | |
# Build steps. We incorporate test_ci's approach (cargo build + cargo test). | |
# For cross or WOA, we use cross or the special powershell step. | |
# ---------------------------------------------------------------------------- | |
- name: "cargo build --all ${{ env.BUILD_EXCLUDE }} ${{ env.CARGO_PROFILE_TARGET_FEATURES_ARGS }}" | |
if: matrix.cross != 'true' && matrix.woa != 'true' | |
run: cargo build --all ${{ env.BUILD_EXCLUDE }} ${{ env.CARGO_PROFILE_TARGET_FEATURES_ARGS }} | |
shell: bash | |
- name: "& Launch-VsDevShell.ps1 | cargo build --all ${{ env.BUILD_EXCLUDE }} ${{ env.CARGO_PROFILE_TARGET_FEATURES_ARGS }}" | |
if: matrix.woa == 'true' | |
run: "& Launch-VsDevShell.ps1 | cargo build --all ${{ env.BUILD_EXCLUDE }} ${{ env.CARGO_PROFILE_TARGET_FEATURES_ARGS }}" | |
shell: powershell | |
- name: "cross cargo build --target ${{ matrix.target }} ${{ env.CROSS_ARGS }}" | |
uses: houseabsolute/[email protected] | |
with: | |
command: "build" | |
target: ${{ matrix.target }} | |
toolchain: stable | |
args: "--all ${{ env.BUILD_EXCLUDE }} ${{ env.CROSS_ARGS }}" | |
if: matrix.cross == 'true' | |
# on check and extract exact glibc version of libimageflow.so | |
- name: Check glibc version of ${{ env.LIBIMAGEFLOW_DYNAMIC }} | |
if: matrix.max-glibc | |
run: | | |
# list all files in the target directory | |
ls -l "${{ env.REL_BINARIES_DIR }}" | |
# if libimageflow.so does not exist, fail | |
if [[ ! -f "${{ env.REL_BINARIES_DIR }}${{ env.LIBIMAGEFLOW_DYNAMIC }}" ]]; then | |
echo "Error: ${{ env.REL_BINARIES_DIR }}${{ env.LIBIMAGEFLOW_DYNAMIC }} does not exist" | |
exit 1 | |
fi | |
# Use objdump to find all GLIBC version requirements | |
echo "GLIBC version requirements:" | |
objdump -T "${{ env.REL_BINARIES_DIR }}${{ env.LIBIMAGEFLOW_DYNAMIC }}" | grep GLIBC_ | sed 's/.*GLIBC_\([0-9.]*\).*/\1/g' | sort -Vu | |
# Find the highest GLIBC version required | |
HIGHEST_GLIBC=$(objdump -T "${{ env.REL_BINARIES_DIR }}${{ env.LIBIMAGEFLOW_DYNAMIC }}" | grep GLIBC_ | sed 's/.*GLIBC_\([0-9.]*\).*/\1/g' | sort -V | tail -n1) | |
echo "Highest GLIBC version required: $HIGHEST_GLIBC" | |
# Fail if version is above ${{ matrix.max-glibc }} and this is not a skipped build | |
if [[ "${{ matrix.skip-publish }}" != "true" ]] && [[ $(echo -e "${{ matrix.max-glibc }}\n$HIGHEST_GLIBC" | sort -V | tail -n1) != "${{ matrix.max-glibc }}" ]]; then | |
echo "Error: GLIBC version $HIGHEST_GLIBC is higher than maximum allowed version ${{ matrix.max-glibc }}" | |
exit 1 | |
fi | |
shell: bash | |
# ---------------------------------------------------------------------------- | |
# Diagnose build results for debugging. | |
# ---------------------------------------------------------------------------- | |
- name: imageflow_tool diagnose --show-compilation-info | |
run: "${{ env.IMAGEFLOW_TOOL_PATH }} diagnose --show-compilation-info" | |
shell: bash | |
# This may fail if the tool doesn't exist for a certain platform, | |
# but in release_ci it was unconditional. We keep it consistent. | |
# ---------------------------------------------------------------------------- | |
# Build documentation (cargo doc) if cross isn't used. For cross, | |
# we can't do doc in the same straightforward way. | |
# ---------------------------------------------------------------------------- | |
- name: "Build ${{ env.PROFILE }} Docs" | |
run: cargo doc --all --no-deps ${{ env.CARGO_PROFILE_TARGET_FEATURES_ARGS }} | |
if: matrix.cross != 'true' | |
- name: "mkdir -p ./${{ env.TARGET_DIR }}doc" | |
run: | | |
mkdir -p ./${{ env.TARGET_DIR }}doc | |
touch ./${{ env.TARGET_DIR }}doc/not-available.txt | |
if: matrix.cross == 'true' | |
# ---------------------------------------------------------------------------- | |
# Conditionally create and upload artifacts only if this is a release. | |
# In "test mode," we skip. This keeps the workflow DRY but clarifies | |
# that packaging/publishing logic won't happen on pushes or PRs. | |
# ---------------------------------------------------------------------------- | |
- name: "Create zip/tar files like ${{ env.RELATIVE_GITHUB_ARCHIVE }} for upload" | |
if: ${{ github.event_name == 'release' }} | |
shell: bash | |
run: | | |
mkdir -p ./artifacts/staging/headers || true | |
mkdir -p "$(dirname "${{ env.TEMP_STATIC_LIB }}")" || true | |
( | |
cd ./${{ env.TARGET_DIR }}doc | |
tar czf "../docs.${{ env.EXTENSION }}" ./* | |
) | |
mv ./${{ env.TARGET_DIR }}docs.${{ env.EXTENSION }} ./artifacts/staging/ | |
cp -R ./${{ env.REL_BINARIES_DIR }}/{imageflow_,libimageflow}* ./artifacts/staging/ | |
cp bindings/headers/*.h ./artifacts/staging/headers/ | |
cp bindings/headers/imageflow_default.h ./artifacts/staging/imageflow.h | |
cp ./ci/packaging_extras/{install,uninstall}.sh ./artifacts/staging | |
rm ./artifacts/staging/*.{o,d,rlib} || true | |
mv ./artifacts/staging/${{ env.LIBIMAGEFLOW_STATIC }} ${{ env.TEMP_STATIC_LIB }} || true | |
rm ./artifacts/staging/*-* || true | |
ls -l ./artifacts/staging | |
( | |
cd ./artifacts/staging | |
tar czf "./archive.${{ env.EXTENSION }}" ./* | |
) | |
# Create release archives for upload | |
mkdir -p "$(dirname "${{ env.RELATIVE_GITHUB_ARCHIVE }}")" || true | |
mkdir -p ./artifacts/upload/releases/${{ github.ref_name }} | |
mkdir -p ./artifacts/upload/commits/${{ github.sha }} | |
cp "${TEMP_ARCHIVE_NAME}" "${{ env.RELATIVE_GITHUB_ARCHIVE }}" | |
cp "${TEMP_ARCHIVE_NAME}" "./artifacts/upload/releases/${{ github.ref_name }}/${{ env.IMAGEFLOW_TAG_SHA_SUFFIX }}.${{ env.EXTENSION }}" | |
cp "${TEMP_ARCHIVE_NAME}" "./artifacts/upload/commits/${{ github.sha }}/${{ matrix.commit-suffix }}.${{ env.EXTENSION }}" | |
# Create static archives for upload | |
echo "if ${{ env.TEMP_STATIC_LIB }} exists, make an archive of it" | |
if [[ -f ${{ env.TEMP_STATIC_LIB }} ]]; then | |
( | |
echo "${{ env.TEMP_STATIC_LIB }} exists" | |
tar czf "${{ env.TEMP_STATIC_ARCHIVE }}" "${{ env.TEMP_STATIC_LIB }}" | |
UPLOAD_DIR="./artifacts/upload | |
env STATIC_ARCHIVE_1 = "/static/${{ matrix.target }}/latest/${{ env.LIBIMAGEFLOW_STATIC }}.${{ env.EXTENSION }}" | |
env STATIC_ARCHIVE_2 = "/static/${{ matrix.target }}/releases/${{ github.ref_name }}/${{ env.LIBIMAGEFLOW_STATIC }}.${{ env.EXTENSION }}" | |
env STATIC_ARCHIVE_3 = "/static/${{ matrix.target }}/commits/${{ github.sha }}/${{ matrix.commit-suffix }}.${{ env.EXTENSION }}" | |
env STATIC_ARCHIVE_GITHUB = "./artifacts/github/lib${{ env.IMAGEFLOW_TAG_SHA_SUFFIX }}-${{ matrix.commit-suffix }}.${{ env.LIBIMAGEFLOW_STATIC }}.${{ env.EXTENSION }}" | |
mkdir -p $(dirname $STATIC_UPLOAD_DIR$STATIC_ARCHIVE_1) | |
mkdir -p $(dirname $STATIC_UPLOAD_DIR$STATIC_ARCHIVE_2) | |
mkdir -p $(dirname $STATIC_UPLOAD_DIR$STATIC_ARCHIVE_3) | |
cp $TEMP_STATIC_ARCHIVE $STATIC_UPLOAD_DIR$STATIC_ARCHIVE_1 | |
cp $TEMP_STATIC_ARCHIVE $STATIC_UPLOAD_DIR$STATIC_ARCHIVE_2 | |
cp $TEMP_STATIC_ARCHIVE $STATIC_UPLOAD_DIR$STATIC_ARCHIVE_3 | |
mv $TEMP_STATIC_ARCHIVE $STATIC_ARCHIVE_GITHUB | |
echo "Uploaded static archive to ${{ env.HTTPS_IMAGEFLOW_NIGHTLIES }}$STATIC_UPLOAD_DIR$STATIC_ARCHIVE_1" | |
echo "Uploaded static archive to ${{ env.HTTPS_IMAGEFLOW_NIGHTLIES }}$STATIC_UPLOAD_DIR$STATIC_ARCHIVE_2" | |
echo "Uploaded static archive to ${{ env.HTTPS_IMAGEFLOW_NIGHTLIES }}$STATIC_UPLOAD_DIR$STATIC_ARCHIVE_3" | |
echo "RELATIVE_GITHUB_ARCHIVE_STATIC=$STATIC_ARCHIVE_GITHUB" >> $GITHUB_ENV | |
) | |
else | |
echo "No static archive found at ${{ env.TEMP_STATIC_LIB }}" | |
fi | |
echo "github release artifacts" | |
ls -l -R ./artifacts/github | |
echo "upload artifacts recursively" | |
ls -l -R ./artifacts/upload | |
env: | |
TEMP_ARCHIVE_NAME: "./artifacts/staging/archive.${{ env.EXTENSION }}" | |
TEMP_STATIC_LIB: "./artifacts/static-staging/${{ env.LIBIMAGEFLOW_STATIC }}" | |
TEMP_STATIC_ARCHIVE: "./artifacts/static-staging/${{ env.LIBIMAGEFLOW_STATIC }}.${{ env.EXTENSION }}" | |
- name: "Upload to Github Release: ${{ env.RELATIVE_GITHUB_ARCHIVE }}" | |
if: ${{ env.ALLOW_PUBLISH == 'true' }} | |
uses: xresloader/upload-to-github-release@v1 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
file: "${{ env.RELATIVE_GITHUB_ARCHIVE }}${{ env.RELATIVE_GITHUB_ARCHIVE_STATIC && format(';{0}', env.RELATIVE_GITHUB_ARCHIVE_STATIC) }}" | |
tags: true | |
overwrite: true | |
verbose: true | |
- name: "Create NuGet Package Imageflow.NativeTool.${{ matrix.nuget-rid }}" | |
shell: bash | |
run: ./ci/pack_nuget/pack.sh tool | |
env: | |
CI_TAG: ${{ github.ref_name || 'vTEST' }} | |
PACKAGE_SUFFIX: ${{ matrix.suffix }} | |
NUGET_RUNTIME: ${{ matrix.nuget-rid }} | |
REPO_NAME: ${{ env.GITHUB_REPOSITORY_OWNER }}\/${{ env.GITHUB_REPOSITORY_NAME }} | |
BINARIES_DIR: "${{ env.REL_BINARIES_DIR }}" | |
- name: "Create NuGet Package Imageflow.NativeRuntime.${{ matrix.nuget-rid }}" | |
if: ${{ matrix.build-exclude != 'imageflow_abi' }} | |
shell: bash | |
run: ./ci/pack_nuget/pack.sh | |
env: | |
CI_TAG: ${{ github.ref_name || 'vTEST' }} | |
PACKAGE_SUFFIX: ${{ matrix.suffix }} | |
NUGET_RUNTIME: ${{ matrix.nuget-rid }} | |
REPO_NAME: ${{ env.GITHUB_REPOSITORY_OWNER }}\/${{ env.GITHUB_REPOSITORY_NAME }} | |
BINARIES_DIR: "${{ env.REL_BINARIES_DIR }}" | |
- name: Upload ./artifacts/upload to S3 | |
if: ${{ env.ALLOW_PUBLISH == 'true' }} | |
uses: shallwefootball/s3-upload-action@master | |
with: | |
aws_key_id: ${{ secrets.AWS_KEY_ID }} | |
aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY}} | |
aws_bucket: ${{ secrets.AWS_BUCKET }} | |
source_dir: ./artifacts/upload | |
destination_dir: '' | |
- name: Publish to nuget.pkg.github.com | |
if: ${{ env.ALLOW_PUBLISH == 'true' && env.NUGET_UPLOAD_GITHUB == 'true' }} | |
run: | | |
for f in ./artifacts/nuget/*.nupkg | |
do | |
curl -vX PUT -u "${{github.repository_owner}}:${{ secrets.GITHUB_TOKEN }}" -F package=@$f https://nuget.pkg.github.com/${{github.repository_owner}}/ | |
done | |
shell: bash | |
- name: Publish to nuget.org | |
if: ${{ env.ALLOW_PUBLISH == 'true' && env.NUGET_UPLOAD_NUGET == 'true' }} | |
run: | | |
for f in ./artifacts/nuget/*.nupkg | |
do | |
curl -L "https://www.nuget.org/api/v2/package" -H "X-NuGet-ApiKey: ${{ secrets.NUGET_API_KEY }}" -H "X-NuGet-Client-Version: 4.1.0" -A "NuGet Command Line/3.4.4.1321 (Unix 4.4.0.92)" --upload-file "$f" --fail | |
done | |
shell: bash | |
- name: "Verify artifacts are now on S3, and public. Use curl to check, then delete" | |
if: ${{ env.ALLOW_PUBLISH == 'true' }} | |
shell: bash | |
run: | | |
mkdir -p ./artifacts/verify | |
cd ./artifacts/verify | |
curl -s ${{ env.ESTIMATED_ARTIFACT_URL }} | |
curl -s ${{ env.ESTIMATED_ARTIFACT_URL_COMMITS }} | |
# if musl | |
if [[ ${{ matrix.target }} == *"musl"* ]]; then | |
curl -s ${{ env.ESTIMATED_MUSL_VERSIONED_URL }} | |
curl -s ${{ env.ESTIMATED_MUSL_LATEST_URL }} | |
fi | |
cd ${{ github.workspace }} | |
rm -rf ./artifacts/verify | |
# ---------------------------------------------------------------------------- | |
# Reasoning: The existing release_ci.yml had a second job "publish" that | |
# published to Docker. We replicate that here. It only runs if the event | |
# is a release. This job depends on "build" so that artifacts are built first. | |
# ---------------------------------------------------------------------------- | |
publish: | |
runs-on: ubuntu-latest | |
needs: [build] | |
if: ${{ github.event_name == 'release' }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- uses: FranzDiebold/[email protected] | |
- name: Publish To Docker | |
run: | | |
docker login -u "$DOCKER_USERNAME" -p "$DOCKER_PASSWORD" | |
./ci/travis_publish_docker_images.sh docker/imageflow_tool imazen/imageflow_tool | |
env: | |
PUBLISH_DOCKER: True | |
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} | |
DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} | |
PUBLISH_DOCKER_TAG: ${{ github.ref_name }} | |
IMAGEFLOW_DOWNLOAD_URL_TAR_GZ: ${{ env.HTTPS_IMAGEFLOW_NIGHTLIES }}/commits/${{ github.sha }}/${{ env.DOCKER_FETCH_COMMIT_SUFFIX }}.tar.gz |