mirror of
https://github.com/wez/wezterm.git
synced 2024-12-29 00:21:57 +03:00
1c0298c54d
This should make it possible to write a script to grab artifacts and stick them into the appropriate release if something flakes out.
113 lines
3.5 KiB
YAML
113 lines
3.5 KiB
YAML
name: ubuntu20.04
|
|
|
|
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/ISSUE_TEMPLATE/*"
|
|
- "**/*.md"
|
|
|
|
jobs:
|
|
build:
|
|
runs-on: "ubuntu-latest"
|
|
container: "ubuntu:20.04"
|
|
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: "Install https support for apt"
|
|
shell: bash
|
|
run: "apt-get install -y apt-transport-https ca-certificates"
|
|
- name: "Install GitHub keyring"
|
|
shell: bash
|
|
run: "curl -fsSL https://cli.github.com/packages/githubcli-archive-keyring.gpg | dd of=/usr/share/keyrings/githubcli-archive-keyring.gpg"
|
|
- name: "Add GitHub package list"
|
|
shell: bash
|
|
run: 'echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/githubcli-archive-keyring.gpg] https://cli.github.com/packages stable main" | tee /etc/apt/sources.list.d/github-cli.list > /dev/null'
|
|
- name: "Show GitHub package list"
|
|
shell: bash
|
|
run: "cat /etc/apt/sources.list.d/*"
|
|
- name: "Update APT again"
|
|
shell: bash
|
|
run: "apt update"
|
|
- name: "Install GH CLI"
|
|
shell: bash
|
|
run: "apt install -y gh"
|
|
- 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: "checkout repo"
|
|
uses: actions/checkout@v2
|
|
with:
|
|
submodules: "recursive"
|
|
- name: "Fetch tags"
|
|
shell: bash
|
|
run: "git fetch --depth=1 origin +refs/tags/*:refs/tags/*"
|
|
- name: "Fetch tag/branch history"
|
|
shell: bash
|
|
run: "git fetch --prune --unshallow"
|
|
- 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@v2.1.7
|
|
with:
|
|
path: |
|
|
~/.cargo/registry
|
|
~/.cargo/git
|
|
target
|
|
key: "ubuntu20.04-None-2-${{ runner.os }}-${{ hashFiles('**/Cargo.lock') }}-cargo"
|
|
- name: "Install System Deps"
|
|
shell: bash
|
|
run: "env PATH=$PATH ./get-deps"
|
|
- name: "Check formatting"
|
|
shell: bash
|
|
run: "cargo fmt --all -- --check"
|
|
- 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 Package for artifact upload"
|
|
shell: bash
|
|
run: |
|
|
mkdir pkg_
|
|
mv *.deb *.xz pkg_
|
|
- name: "Upload artifact"
|
|
uses: actions/upload-artifact@v2
|
|
with:
|
|
name: "ubuntu20.04"
|
|
path: "pkg_"
|