-
Notifications
You must be signed in to change notification settings - Fork 45
145 lines (123 loc) · 4.21 KB
/
docs.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
name: Deploy Docs
on:
push:
branches:
- main
paths:
- "docs/**"
- "mkdocs.yml"
tags:
- v**
pull_request:
branches:
- main
paths:
- "docs/**"
- ".github/workflows/docs.yml"
- "mkdocs.yml"
- "pixi.*"
workflow_dispatch:
inputs:
tag:
description: "Tag to deploy"
required: true
default: "v0.0.0"
# Allow one concurrent deployment
concurrency:
group: "pages"
cancel-in-progress: true
jobs:
# Generate CLI docs by building the `generate-cli-docs` binary and commiting the result to the PR.
generate-cli-docs:
if: github.event_name == 'pull_request' && github.repository == 'prefix-dev/rattler-build'
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
repository: ${{ github.event.pull_request.head.repo.full_name }}
ref: ${{ github.event.pull_request.head.ref }}
- uses: prefix-dev/setup-pixi@v0.8.1
- name: Build docs for PR
run: |
pixi run generate-cli-docs
- name: Check for changes
id: git_diff
run: |
git diff --exit-code || echo "has_changes=true" >> $GITHUB_ENV
- name: Output instructions if there are changes
if: env.has_changes == 'true'
run: |
echo "There are changes in the CLI docs."
echo "Please run the following commands to commit and push the changes:"
echo ""
echo "pixi run generate-cli-docs"
echo "git commit -am 'docs: update CLI docs'"
echo "git push"
echo ""
exit 1
- name: Output message if there are no changes
if: env.has_changes != 'true'
run: echo "No changes detected."
build-docs:
needs: generate-cli-docs
if: github.ref != 'refs/heads/main' && !startsWith(github.ref, 'refs/tags/v')
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
submodules: recursive
- uses: prefix-dev/setup-pixi@v0.8.1
- name: Build docs for test
run: |
pixi run build-docs
docs-release:
# Don't run on forks
if: github.repository == 'prefix-dev/rattler-build' && (startsWith(github.event.ref, 'refs/tags/v') || github.event_name == 'workflow_dispatch' && startsWith(github.event.inputs.tag, 'v'))
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
# fetch everything so we can checkout the tag
fetch-depth: 0
submodules: recursive
# check out tag if workflow_dispatch
- name: Checkout tag
if: github.event_name == 'workflow_dispatch'
run: |
git checkout tags/${{ github.event.inputs.tag }}
- uses: prefix-dev/setup-pixi@v0.8.1
- name: Configure Git user
run: |
git config --local user.email "github-actions[bot]@users.noreply.github.com"
git config --local user.name "github-actions[bot]"
- name: Extract tag name
if: github.event_name != 'workflow_dispatch'
run: echo "RELEASE_VERSION=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV
- name: Tag from workflow_dispatch
if: github.event_name == 'workflow_dispatch'
run: echo "RELEASE_VERSION=${{ github.event.inputs.tag }}" >> $GITHUB_ENV
- name: Deploy with mike 🚀
run: |
pixi run deploy-latest
docs-dev:
# Don't run on forks
if: github.repository == 'prefix-dev/rattler-build' && (github.ref == 'refs/heads/main' || github.event_name == 'workflow_dispatch' && !startsWith(github.event.inputs.tag, 'v'))
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
# fetch everything so we can checkout the tag
fetch-depth: 0
submodules: recursive
- uses: prefix-dev/setup-pixi@v0.8.1
- name: Configure Git user
run: |
git config --local user.email "github-actions[bot]@users.noreply.github.com"
git config --local user.name "github-actions[bot]"
- name: Deploy with mike 🚀
run: |
pixi run deploy-dev