-
Notifications
You must be signed in to change notification settings - Fork 12
63 lines (56 loc) · 1.8 KB
/
build.yaml
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
name: release
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
jobs:
build-and-release:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Assign variable
id: secret
run: echo '::set-output name=secret::${{secrets.GHACTIONS_SECRET}}'
- name: Login to GitHub Container Registry
uses: docker/login-action@v2
if: ${{ steps.secret.outputs.secret }}
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GHACTIONS_SECRET }}
- name: Run Checks, Tests and Build
uses: devcontainers/ci@v0.2
env:
GITHUB_TOKEN: ${{ secrets.GHACTIONS_SECRET }}
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }}
SNAPCRAFT_STORE_CREDENTIALS: ${{ secrets.SNAPCRAFT_STORE_CREDENTIALS }}
BUILD_NUMBER: ${{ github.run_number }}
IS_PR: ${{ github.head_ref }}
BRANCH: ${{ github.ref }}
IS_CI: "true"
with:
imageName: ghcr.io/lawrencegripper/azbrowse/devcontainer
cacheFrom: ghcr.io/lawrencegripper/azbrowse/devcontainer
push: filter
refFilterForPush: refs/heads/main
runCmd: ruby scripts/release.rb
# Map through the envs from above into the devcontain
# empty items mean it takes value from the `env` on stage
env: |
GITHUB_TOKEN
DOCKER_USERNAME
DOCKER_PASSWORD
SNAPCRAFT_STORE_CREDENTIALS
BUILD_NUMBER
IS_CI
IS_PR
BRANCH
- name: Upload azbrowse build as artifact
uses: actions/upload-artifact@v4
with:
name: azbrowse-test-assets
path: dist/all_*/*