name: alpine3.14_continuous on: schedule: - cron: "10 3 * * *" push: branches: - main paths: - "**/*.rs" - "**/Cargo.lock" - "**/Cargo.toml" - ".github/workflows/gen_alpine3.14_continuous.yml" - "assets/fonts/**/*" - "assets/icon/*" - "assets/open-wezterm-here" - "assets/shell-completion/**/*" - "assets/shell-integration/**/*" - "assets/wezterm-nautilus.py" - "assets/wezterm.appdata.xml" - "assets/wezterm.desktop" - "ci/deploy.sh" - "get-deps" - "tag-name.sh" - "termwiz/data/wezterm.terminfo" jobs: build: runs-on: "ubuntu-latest" container: "alpine:3.14" env: BUILD_REASON: "Schedule" RUSTFLAGS: "-C target-feature=-crt-static" steps: - name: "Upgrade system" shell: sh run: "apk upgrade --update-cache" - name: "Install CI dependencies" shell: sh run: "apk add nodejs zstd wget bash coreutils tar findutils" - name: "Allow root login" shell: bash run: "sed 's/root:!/root:*/g' -i /etc/shadow" - name: "Install git" shell: bash run: "apk add git" - name: "Install curl" shell: bash run: "apk add curl" - name: "Install openssh" shell: bash run: "apk add openssh" - name: "Workaround git permissions issue" shell: bash run: "git config --global --add safe.directory /__w/wezterm/wezterm" - name: "checkout repo" uses: actions/checkout@v3 with: submodules: "recursive" - name: "Install Rust" uses: actions-rs/toolchain@v1 with: profile: "minimal" toolchain: "stable" override: true components: "rustfmt" env: ACTIONS_ALLOW_UNSECURE_COMMANDS: "true" - name: "Cache cargo" uses: actions/cache@v3 with: path: | ~/.cargo/registry ~/.cargo/git target key: "alpine3.14-None-2-${{ runner.os }}-${{ hashFiles('**/Cargo.lock') }}-cargo" - name: "Install System Deps" shell: bash run: "env PATH=$PATH ./get-deps" - name: "Build (Release mode)" shell: bash run: "cargo build --all --release" - name: "Test (Release mode)" shell: bash run: "cargo test --all --release" - name: "Package" shell: bash run: "bash ci/deploy.sh" - name: "Move APKs" shell: bash run: "mv ~/packages/wezterm/x86_64/*.apk wezterm-nightly-alpine3.14.apk" - name: "Upload artifact" uses: actions/upload-artifact@v3 with: name: "alpine3.14" path: "wezterm-*.apk" retention-days: 5 upload: runs-on: ubuntu-latest needs: build steps: - name: "Workaround git permissions issue" shell: bash run: "git config --global --add safe.directory /__w/wezterm/wezterm" - name: "checkout repo" uses: actions/checkout@v3 - name: "Download artifact" uses: actions/download-artifact@v3 with: name: "alpine3.14" - name: "Checksum" shell: bash run: "for f in wezterm-*.apk ; do sha256sum $f > $f.sha256 ; done" - name: "Upload to Nightly Release" env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} shell: bash run: "bash ci/retry.sh gh release upload --clobber nightly wezterm-*.apk *.sha256"