debian11_continuous #2707
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: debian11_continuous | |
on: | |
schedule: | |
- cron: "10 3 * * *" | |
push: | |
branches: | |
- main | |
paths: | |
- "**/*.rs" | |
- "**/Cargo.lock" | |
- "**/Cargo.toml" | |
- ".github/workflows/gen_debian11_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" | |
- "ci/tag-name.sh" | |
- "get-deps" | |
- "termwiz/data/wezterm.terminfo" | |
jobs: | |
build: | |
runs-on: "ubuntu-latest" | |
container: "debian:11" | |
env: | |
BUILD_REASON: "Schedule" | |
steps: | |
- name: "set APT to non-interactive" | |
shell: bash | |
run: "echo 'debconf debconf/frontend select Noninteractive' | debconf-set-selections" | |
- name: "Update APT" | |
shell: bash | |
run: "apt update" | |
- name: "Install git" | |
shell: bash | |
run: "apt-get install -y git" | |
- name: "Install curl" | |
shell: bash | |
run: "apt-get install -y curl" | |
- name: "Update APT" | |
shell: bash | |
run: "apt update" | |
- name: "Ensure /run/sshd exists" | |
shell: bash | |
run: "mkdir -p /run/sshd" | |
- name: "Install openssh-server" | |
shell: bash | |
run: "apt-get install -y openssh-server" | |
- name: "Workaround git permissions issue" | |
shell: bash | |
run: "git config --global --add safe.directory /__w/wezterm/wezterm" | |
- name: "checkout repo" | |
uses: actions/checkout@v4 | |
with: | |
submodules: "recursive" | |
- name: "Install Rust" | |
uses: dtolnay/rust-toolchain@stable | |
- name: "Cache cargo" | |
uses: Swatinem/rust-cache@v2 | |
with: | |
key: "debian11-None-2-${{ runner.os }}-cargo" | |
- name: "Install System Deps" | |
shell: bash | |
run: "env CI=yes PATH=$PATH ./get-deps" | |
- name: "Build (Release mode)" | |
shell: bash | |
run: "cargo build --all --release" | |
- name: "Install cargo-nextest from Cargo" | |
uses: baptiste0928/cargo-install@v2 | |
with: | |
crate: "cargo-nextest" | |
cache-key: "debian11" | |
- name: "Test (Release mode)" | |
shell: bash | |
run: "cargo nextest run --all --release --no-fail-fast" | |
- name: "Package" | |
shell: bash | |
run: "bash ci/deploy.sh" | |
- name: "Upload artifact" | |
uses: actions/upload-artifact@v3 | |
with: | |
name: "debian11" | |
path: | | |
wezterm-*.deb | |
wezterm-*.xz | |
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@v4 | |
- name: "Download artifact" | |
uses: actions/download-artifact@v3 | |
with: | |
name: "debian11" | |
- name: "Checksum" | |
shell: bash | |
run: "for f in wezterm-*.deb wezterm-*.xz ; 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-*.deb wezterm-*.xz *.sha256" |