149 lines (141 loc) · 4.88 KB
/
release.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
name: release
on:
push:
branches:
- main
tags:
- "v*"
jobs:
build:
name: build release assets
runs-on: ${{ matrix.config.os }}
env: ${{ matrix.config.env }}
strategy:
matrix:
config:
- {
os: "ubuntu-latest",
arch: "amd64",
args: "--release",
targetDir: "target/release",
extension: "",
env: {},
}
- {
os: "ubuntu-latest",
arch: "aarch64",
args: "--release --target aarch64-unknown-linux-gnu",
targetDir: "target/aarch64-unknown-linux-gnu/release",
extension: "",
env: { OPENSSL_DIR: "/usr/local/openssl-aarch64" },
}
- {
os: "macos-latest",
arch: "amd64",
args: "--release",
targetDir: "target/release",
extension: "",
env: {},
}
- {
os: "windows-latest",
arch: "amd64",
args: "--release --no-default-features --features rustls-tls",
targetDir: "target/release",
extension: ".exe",
env: {},
}
steps:
- uses: actions/checkout@v2
- name: set the release version (tag)
if: startsWith(github.ref, 'refs/tags/v')
shell: bash
run: echo "RELEASE_VERSION=${GITHUB_REF/refs\/tags\//}" >> $GITHUB_ENV
- name: set the release version (main)
if: github.ref == 'refs/heads/main'
shell: bash
run: echo "RELEASE_VERSION=canary" >> $GITHUB_ENV
- name: lowercase the runner OS name
shell: bash
run: |
OS=$(echo "${{ runner.os }}" | tr '[:upper:]' '[:lower:]')
echo "RUNNER_OS=${OS}" >> $GITHUB_ENV
- name: Install latest Rust stable toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: stable
default: true
components: clippy, rustfmt
- name: setup for cross-compile builds
if: matrix.config.arch == 'aarch64'
run: |
sudo apt install gcc-aarch64-linux-gnu g++-aarch64-linux-gnu
cd /tmp
git clone https://github.com/openssl/openssl
cd openssl
git checkout OpenSSL_1_1_1l
sudo mkdir -p $OPENSSL_DIR
./Configure linux-aarch64 --prefix=$OPENSSL_DIR --openssldir=$OPENSSL_DIR shared
make CC=aarch64-linux-gnu-gcc
sudo make install
rustup target add aarch64-unknown-linux-gnu
- name: build release
uses: actions-rs/cargo@v1
with:
command: build
args: ${{ matrix.config.args }}
- name: package release assets
shell: bash
run: |
mkdir _dist
cp README.md LICENSE ${{ matrix.config.targetDir }}/krustlet-wasi${{ matrix.config.extension }} _dist/
cd _dist
tar czf krustlet-${{ env.RELEASE_VERSION }}-${{ env.RUNNER_OS }}-${{ matrix.config.arch }}.tar.gz README.md LICENSE krustlet-wasi${{ matrix.config.extension }}
- uses: actions/upload-artifact@v1
with:
name: krustlet
path: _dist/krustlet-${{ env.RELEASE_VERSION }}-${{ env.RUNNER_OS }}-${{ matrix.config.arch }}.tar.gz
publish:
name: publish release assets
runs-on: ubuntu-latest
needs: build
steps:
- name: set the release version
if: startsWith(github.ref, 'refs/tags/v')
run: echo "RELEASE_VERSION=${GITHUB_REF/refs\/tags\//}" >> $GITHUB_ENV
- name: set the release version
if: github.ref == 'refs/heads/main'
run: echo "RELEASE_VERSION=canary" >> $GITHUB_ENV
- name: download release assets
uses: actions/download-artifact@v1
with:
name: krustlet
- name: generate checksums
run: |
cd krustlet
sha256sum * > checksums-${{ env.RELEASE_VERSION }}.txt
- name: upload to azure
uses: bacongobbler/azure-blob-storage-upload@main
with:
source_dir: krustlet
container_name: releases
connection_string: ${{ secrets.AzureStorageConnectionString }}
sync: false
crates:
name: publish to crates.io
runs-on: ubuntu-latest
needs: publish
if: startsWith(github.ref, 'refs/tags/v')
steps:
- uses: actions/checkout@v2
# OCI distribution needs to go first because kubelet has a dependency on it
- name: publish oci-distribution to crates.io
working-directory: ./crates/oci-distribution
run: cargo publish --token ${{ secrets.CargoToken }}
continue-on-error: true
- name: wait for oci-distribution to be published
run: sleep 60
- name: publish kubelet to crates.io
working-directory: ./crates/kubelet
run: cargo publish --token ${{ secrets.CargoToken }}
continue-on-error: true