name: fedora37 on: pull_request: branches: - main paths-ignore: - ".cirrus.yml" - "docs/*" - "ci/build-docs.sh" - "ci/generate-docs.py" - "ci/subst-release-info.py" - ".github/workflows/pages.yml" - ".github/workflows/verify-pages.yml" - ".github/workflows/no-response.yml" - ".github/ISSUE_TEMPLATE/*" - "**/*.md" - "**/*.markdown" jobs: build: runs-on: "ubuntu-latest" container: "fedora:37" 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: 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: "fedora37-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 RPM" shell: bash run: "mv ~/rpmbuild/RPMS/*/*.rpm ." - name: "Upload artifact" uses: actions/upload-artifact@v3 with: name: "fedora37" path: "wezterm-*.rpm"