fedora39_continuous #126
This file contains hidden or 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: fedora39_continuous | |
| permissions: | |
| contents: read | |
| on: | |
| schedule: | |
| - cron: "10 3 * * *" | |
| push: | |
| branches: | |
| - main | |
| paths: | |
| - "**/*.rs" | |
| - "**/Cargo.lock" | |
| - "**/Cargo.toml" | |
| - ".cargo/config.toml" | |
| - ".github/workflows/gen_fedora39_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:39" | |
| env: | |
| BUILD_REASON: "Schedule" | |
| CARGO_INCREMENTAL: "0" | |
| SCCACHE_GHA_ENABLED: "true" | |
| HOME: "/root" | |
| RUSTC_WRAPPER: "sccache" | |
| 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/cx-core/cx-core" | |
| - name: "checkout repo" | |
| uses: actions/checkout@v4 | |
| - name: "Checkout submodules with retry" | |
| shell: bash | |
| run: | | |
| for i in 1 2 3; do | |
| echo "Attempt $i: Updating submodules..." | |
| git submodule update --init --recursive && break | |
| echo "Attempt $i failed, retrying in 10 seconds..." | |
| sleep 10 | |
| done | |
| - name: "Install Rust" | |
| uses: dtolnay/rust-toolchain@stable | |
| - name: "Compile with sccache" | |
| uses: mozilla-actions/sccache-action@v0.0.9 | |
| - name: "Cache Rust Dependencies" | |
| uses: actions/cache@v4 | |
| id: cache-cargo-vendor | |
| with: | |
| path: | | |
| vendor | |
| .cargo/config | |
| key: "cargo-deps-${{ hashFiles('**/Cargo.lock') }}" | |
| - name: "Vendor dependecies" | |
| if: steps.cache-cargo-vendor.outputs.cache-hit != 'true' | |
| shell: bash | |
| run: "cargo vendor --locked --versioned-dirs >> .cargo/config" | |
| - name: "Install System Deps" | |
| shell: bash | |
| run: "env CI=yes PATH=$PATH ./get-deps" | |
| - name: "Build cx-terminal (Release mode)" | |
| shell: bash | |
| run: "cargo build -p cx-terminal --release" | |
| - name: "Build cx-terminal-gui (Release mode)" | |
| shell: bash | |
| run: "cargo build -p cx-terminal-gui --release" | |
| - name: "Build cx-mux-server (Release mode)" | |
| shell: bash | |
| run: "cargo build -p wezterm-mux-server --release" | |
| - name: "Build strip-ansi-escapes (Release mode)" | |
| shell: bash | |
| run: "cargo build -p strip-ansi-escapes --release" | |
| - name: "Install cargo-nextest from Cargo" | |
| uses: baptiste0928/cargo-install@v3 | |
| with: | |
| crate: "cargo-nextest" | |
| cache-key: "fedora39" | |
| - name: "Test" | |
| shell: bash | |
| run: "cargo nextest run --all --no-fail-fast" | |
| - name: "Package" | |
| shell: bash | |
| run: "bash ci/deploy.sh" | |
| - name: "Move RPM" | |
| shell: bash | |
| run: | | |
| mv ~/rpmbuild/RPMS/*/cx-terminal-common-*.rpm cx-terminal-common-nightly-fedora39.rpm | |
| mv ~/rpmbuild/RPMS/*/cx-terminal-gui-*.rpm cx-terminal-gui-nightly-fedora39.rpm | |
| mv ~/rpmbuild/RPMS/*/cx-mux-server-*.rpm cx-mux-server-nightly-fedora39.rpm | |
| mv ~/rpmbuild/RPMS/*/cx-terminal-*.rpm cx-terminal-nightly-fedora39.rpm | |
| - name: "Upload artifact" | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: "fedora39" | |
| path: "cx-terminal-*.rpm" | |
| retention-days: 5 | |
| upload: | |
| runs-on: ubuntu-latest | |
| needs: build | |
| if: github.repository == 'cxlinux-ai/cx-core' | |
| permissions: | |
| contents: write | |
| pages: write | |
| id-token: write | |
| steps: | |
| - name: "Workaround git permissions issue" | |
| shell: bash | |
| run: "git config --global --add safe.directory /__w/cx-core/cx-core" | |
| - name: "checkout repo" | |
| uses: actions/checkout@v4 | |
| - name: "Download artifact" | |
| uses: actions/download-artifact@v7 | |
| with: | |
| name: "fedora39" | |
| - name: "Checksum" | |
| shell: bash | |
| run: "for f in cx-terminal-*.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 cx-terminal-*.rpm *.sha256" |