Update for 2024.1.1-beta-3 (#369) #747
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
name: CI | |
on: [ push, pull_request, workflow_dispatch ] | |
jobs: | |
build: | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
- os: ubuntu-22.04 | |
artifact-name: Linux | |
build-options: "-PlinuxBuild" | |
- os: macos-latest | |
artifact-name: macOS | |
build-options: "-PmacBuild" | |
- os: macos-latest | |
artifact-name: macOSArm | |
build-options: "-PmacBuildArm" | |
- os: windows-latest | |
artifact-name: Win64 | |
build-options: "" | |
name: "Build - ${{ matrix.artifact-name }}" | |
runs-on: ${{ matrix.os }} | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-dotnet@v3 | |
with: | |
dotnet-version: 8.x | |
- uses: actions/setup-java@v3 | |
with: | |
java-version: 11 | |
distribution: temurin | |
- name: Import Developer ID Certificate | |
uses: wpilibsuite/import-signing-certificate@v1 | |
with: | |
certificate-data: ${{ secrets.APPLE_CERTIFICATE_DATA }} | |
certificate-passphrase: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} | |
keychain-password: ${{ secrets.APPLE_KEYCHAIN_PASSWORD }} | |
if: | | |
(matrix.artifact-name == 'macOS' || matrix.artifact-name == 'macOSArm') && | |
github.repository_owner == 'wpilibsuite' && | |
(github.event_name == 'push' || github.event_name == 'workflow_dispatch') | |
- name: Set Keychain Lock Timeout | |
run: security set-keychain-settings -lut 2700 | |
if: | | |
(matrix.artifact-name == 'macOS' || matrix.artifact-name == 'macOSArm') && | |
github.repository_owner == 'wpilibsuite' && | |
(github.event_name == 'push' || github.event_name == 'workflow_dispatch') | |
- name: Install roboRIO Toolchain | |
shell: bash | |
run: ./gradlew installRoboRioToolchain | |
- name: Build Installer (PR) | |
shell: bash | |
run: ./gradlew generateInstallers -PjenkinsBuild ${{ matrix.build-options }} | |
if: | | |
github.repository_owner != 'wpilibsuite' || | |
(github.event_name != 'push' && github.event_name != 'workflow_dispatch') | |
- name: Build Installer (Main) | |
shell: bash | |
run: | | |
./gradlew generateInstallers -PjenkinsBuild ${{ matrix.build-options }} \ | |
-PdeveloperID=${{ secrets.APPLE_DEVELOPER_ID }} \ | |
-Pnotarization-username=${{ secrets.APPLE_NOTARIZATION_USERNAME }} \ | |
-Pnotarization-teamid=${{ secrets.APPLE_NOTARIZATION_TEAMID }} \ | |
-Pnotarization-password=${{ secrets.APPLE_NOTARIZATION_PASSWORD }} | |
if: | | |
github.repository_owner == 'wpilibsuite' && | |
(github.event_name == 'push' || github.event_name == 'workflow_dispatch') | |
- uses: actions/upload-artifact@v3 | |
with: | |
name: ${{ matrix.artifact-name }} | |
path: build/pubOutputs/ | |
release: | |
name: "Release" | |
needs: build | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/download-artifact@v3 | |
- name: Print Checksums | |
run: | | |
md5sum **/* | |
sha256sum **/* | |
- uses: jfrog/setup-jfrog-cli@v2 | |
if: | | |
github.repository_owner == 'wpilibsuite' && | |
startsWith(github.ref, 'refs/tags/v') | |
env: | |
JF_ARTIFACTORY_1: ${{ secrets.ARTIFACTORY_CLI_SECRET }} | |
- name: Upload to Artifactory | |
if: | | |
github.repository_owner == 'wpilibsuite' && | |
startsWith(github.ref, 'refs/tags/v') | |
run: jfrog rt u "**/*" "installer/${GITHUB_REF#refs/tags/}/" | |
- name: Upload to Cloudflare | |
if: | | |
github.repository_owner == 'wpilibsuite' && | |
startsWith(github.ref, 'refs/tags/v') | |
uses: andreiio/rclone-action@v1 | |
with: | |
args: copy "." "s3:wpilib1-enam/installer/${GITHUB_REF#refs/tags/}/" | |
env: | |
RCLONE_CONFIG_S3_TYPE: s3 | |
RCLONE_CONFIG_S3_PROVIDER: Cloudflare | |
RCLONE_CONFIG_S3_ENDPOINT: ${{ secrets.CLOUDFLARE_ENDPOINT }} | |
RCLONE_CONFIG_S3_ACCESS_KEY_ID: ${{ secrets.CLOUDFLARE_ACCESS_KEY_ID }} | |
RCLONE_CONFIG_S3_SECRET_ACCESS_KEY: ${{ secrets.CLOUDFLARE_SECRET_ACCESS_KEY }} | |
- name: Zip and split for GitHub | |
if: | | |
github.repository_owner == 'wpilibsuite' && | |
startsWith(github.ref, 'refs/tags/v') | |
run: | | |
mkdir zipfiles | |
zip -0 -s 1500m -j "zipfiles/WPILib_Linux-${GITHUB_REF#refs/tags/v}.zip" Linux/* | |
zip -0 -s 1500m -j "zipfiles/WPILib_Windows-${GITHUB_REF#refs/tags/v}.zip" Win64/* | |
zip -0 -s 1500m -j "zipfiles/WPILib_macOS-Intel-${GITHUB_REF#refs/tags/v}.zip" macOS/* | |
zip -0 -s 1500m -j "zipfiles/WPILib_macOS-Arm64-${GITHUB_REF#refs/tags/v}.zip" macOSArm/* | |
- name: Print Zip Checksums | |
if: | | |
github.repository_owner == 'wpilibsuite' && | |
startsWith(github.ref, 'refs/tags/v') | |
run: | | |
md5sum zipfiles/* | |
sha256sum zipfiles/* | |
- name: Upload to GitHub wpilibsuite/allwpilib | |
if: | | |
github.repository_owner == 'wpilibsuite' && | |
startsWith(github.ref, 'refs/tags/v') | |
run: | | |
if ( gh -R wpilibsuite/allwpilib release view "${GITHUB_REF#refs/tags/}" 1> /dev/null ) ; then | |
gh -R wpilibsuite/allwpilib release upload --clobber "${GITHUB_REF#refs/tags/}" zipfiles/* | |
else | |
gh -R wpilibsuite/allwpilib release create -d "${GITHUB_REF#refs/tags/}" zipfiles/* | |
fi | |
env: | |
GITHUB_TOKEN: ${{secrets.GH_ADMIN_TOKEN}} | |
format: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-dotnet@v3 | |
with: | |
dotnet-version: 8.x | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: 3.8 | |
- name: Install black | |
run: pip3 install black | |
- name: Run dotnet format | |
run: dotnet format | |
- name: Run black | |
run: black . | |
- name: Verify formatters made no changes | |
run: git --no-pager diff --exit-code HEAD |