centos7_continuous #10999
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: centos7_continuous | |
on: | |
schedule: | |
- cron: "10 3 * * *" | |
push: | |
branches: | |
- main | |
paths: | |
- "**/*.rs" | |
- "**/Cargo.lock" | |
- "**/Cargo.toml" | |
- ".github/workflows/gen_centos7_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: "quay.io/centos/centos:centos7" | |
env: | |
BUILD_REASON: "Schedule" | |
steps: | |
- name: "Install SCL" | |
shell: bash | |
run: "yum install -y centos-release-scl-rh" | |
- name: "Update compiler" | |
shell: bash | |
run: "yum install -y devtoolset-9-gcc devtoolset-9-gcc-c++" | |
- name: "Cache Git installation" | |
uses: actions/cache@v3 | |
with: | |
path: "/usr/local/git" | |
key: "centos7-git-2.26.2" | |
- name: "Install Git from source" | |
shell: bash | |
run: | | |
yum install -y wget curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc perl-ExtUtils-MakeMaker make | |
if test ! -x /usr/local/git/bin/git ; then | |
cd /tmp | |
wget https://github.com/git/git/archive/v2.26.2.tar.gz | |
tar xzf v2.26.2.tar.gz | |
cd git-2.26.2 | |
make prefix=/usr/local/git install | |
fi | |
ln -s /usr/local/git/bin/git /usr/local/bin/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 Rustup" | |
shell: bash | |
run: | | |
if ! command -v rustup &>/dev/null; then | |
curl --proto '=https' --tlsv1.2 --retry 10 -fsSL "https://sh.rustup.rs" | sh -s -- --default-toolchain none -y | |
echo "${CARGO_HOME:-$HOME/.cargo}/bin" >> $GITHUB_PATH | |
fi | |
- name: "Setup Toolchain" | |
shell: bash | |
run: | | |
rustup toolchain install stable --profile minimal --no-self-update | |
rustup default stable | |
- name: "Cache cargo" | |
uses: Swatinem/rust-cache@v2 | |
with: | |
key: "centos7-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: "source /opt/rh/devtoolset-9/enable && cargo build --all --release" | |
- name: "Install cargo-nextest from Cargo" | |
uses: baptiste0928/cargo-install@v2 | |
with: | |
crate: "cargo-nextest" | |
cache-key: "centos7" | |
- name: "Test (Release mode)" | |
shell: bash | |
run: | | |
source /opt/rh/devtoolset-9/enable | |
cargo nextest run --all --release --no-fail-fast | |
- name: "Package" | |
shell: bash | |
run: "bash ci/deploy.sh" | |
- name: "Move RPM" | |
shell: bash | |
run: "mv ~/rpmbuild/RPMS/*/*.rpm wezterm-nightly-centos7.rpm" | |
- name: "Upload artifact" | |
uses: actions/upload-artifact@v3 | |
with: | |
name: "centos7" | |
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: "centos7" | |
- 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" |