mirror of
https://github.com/wez/wezterm.git
synced 2024-12-21 12:21:32 +03:00
1535d88290
* fix(generate-workflows): Do not use actions-rs [actions-rs/toolchain](https://github.com/actions-rs/toolchain) is unsupported: - Has not recieved updates since November 2020 (~2.5 years) - It uses Node.js 12 and GitHub will stop supporting it Summer this year(?) see this [article](https://github.blog/changelog/2022-09-22-github-actions-all-actions-will-begin-running-on-node16-instead-of-node12/). [dtolnay/rust-toolchain](https://github.com/dtolnay/rust-toolchain) is actively supported and its mostly a 1-1 replacement, the differences are: - Uses the minimal profile always, so no need to specify it. - There is no need to override the toolchain. I also removed some things: - None of the generated actions use `rustfmt` so I removed the component - The toolchain is always stable, so I specified it in the action itself instead of in the action parameters. * ci: Regenerate workflows * fix: Remove ALLOW_UNSECURE_COMMANDS from action * fix(CentOS7): Manually install rustup as CentOS7 uses a very old curl * fix: Restart shell so that the rustup command is available * feat: Add exeption to the CentOS workflow to download rustup * fix: Remove actions-rs/toolchain from remaining workflows * fix: Address review comment
111 lines
3.1 KiB
YAML
111 lines
3.1 KiB
YAML
name: fedora35_continuous
|
|
|
|
on:
|
|
schedule:
|
|
- cron: "10 3 * * *"
|
|
push:
|
|
branches:
|
|
- main
|
|
paths:
|
|
- "**/*.rs"
|
|
- "**/Cargo.lock"
|
|
- "**/Cargo.toml"
|
|
- ".github/workflows/gen_fedora35_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: "fedora:35"
|
|
env:
|
|
BUILD_REASON: "Schedule"
|
|
|
|
steps:
|
|
- name: "Install config manager"
|
|
shell: bash
|
|
run: "dnf install -y 'dnf-command(config-manager)'"
|
|
- name: "Install git"
|
|
shell: bash
|
|
run: "yum install -y git"
|
|
- name: "Install curl"
|
|
shell: bash
|
|
run: "yum install -y curl"
|
|
- name: "Ensure /run/sshd exists"
|
|
shell: bash
|
|
run: "mkdir -p /run/sshd"
|
|
- name: "Install openssh-server"
|
|
shell: bash
|
|
run: "yum 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@v3
|
|
with:
|
|
submodules: "recursive"
|
|
- name: "Install Rust"
|
|
uses: dtolnay/rust-toolchain@stable
|
|
- name: "Cache cargo"
|
|
uses: actions/cache@v3
|
|
with:
|
|
path: |
|
|
~/.cargo/registry
|
|
~/.cargo/git
|
|
target
|
|
key: "fedora35-None-2-${{ runner.os }}-${{ hashFiles('**/Cargo.lock') }}-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: "Test (Release mode)"
|
|
shell: bash
|
|
run: "cargo test --all --release"
|
|
- name: "Package"
|
|
shell: bash
|
|
run: "bash ci/deploy.sh"
|
|
- name: "Move RPM"
|
|
shell: bash
|
|
run: "mv ~/rpmbuild/RPMS/*/*.rpm wezterm-nightly-fedora35.rpm"
|
|
- name: "Upload artifact"
|
|
uses: actions/upload-artifact@v3
|
|
with:
|
|
name: "fedora35"
|
|
path: "wezterm-*.rpm"
|
|
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: "fedora35"
|
|
- name: "Checksum"
|
|
shell: bash
|
|
run: "for f in wezterm-*.rpm ; 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-*.rpm *.sha256"
|