-
Notifications
You must be signed in to change notification settings - Fork 266
154 lines (151 loc) · 6.07 KB
/
Copy pathpulumi-sdk-dotnet-docs.yml
File metadata and controls
154 lines (151 loc) · 6.07 KB
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
150
151
152
153
154
permissions: write-all # Equivalent to default permissions + id-token: write
env:
ESC_ACTION_OIDC_AUTH: true
ESC_ACTION_OIDC_ORGANIZATION: pulumi
ESC_ACTION_OIDC_REQUESTED_TOKEN_TYPE: urn:pulumi:token-type:access_token:organization
ESC_ACTION_ENVIRONMENT: github-secrets/pulumi-docs
ESC_ACTION_EXPORT_ENVIRONMENT_VARIABLES: GITHUB_TOKEN=PULUMI_BOT_TOKEN
name: Pulumi SDK docs - .NET
on:
repository_dispatch:
types:
- pulumi-dotnet-sdk
workflow_dispatch:
inputs:
version:
description: "pulumi-dotnet version (e.g. 3.0.0, with or without leading 'v')"
required: true
skip_auto_merge:
description: "Skip enabling auto-merge on the generated PR (for testing)"
type: boolean
default: false
jobs:
pull-request:
runs-on: ubuntu-latest
needs: build-pulumi-sdk-dotnet-docs
if: needs.build-pulumi-sdk-dotnet-docs.outputs.has_changes == 'true'
steps:
- name: Fetch secrets from ESC
id: esc-secrets
uses: pulumi/esc-action@v2
- name: checkout docs repo
uses: actions/checkout@v6
- name: set the pulumi-dotnet version
env:
RAW_VERSION: ${{ github.event.inputs.version || github.event.client_payload.ref }}
run: |
echo "DOTNET_SDK_VERSION=${RAW_VERSION#v}" >> $GITHUB_ENV
- name: pull-request
id: create-pr
uses: repo-sync/pull-request@v2
with:
source_branch: "pulumi-sdk-dotnet-docs/${{ github.run_id }}-${{ github.run_number }}"
destination_branch: "master"
pr_title: "Generate Pulumi SDK docs - .NET @v${{ env.DOTNET_SDK_VERSION }}"
pr_body: |
Automated PR generated by the [Pulumi SDK docs - .NET](https://github.com/${{ github.repository }}/blob/master/.github/workflows/pulumi-sdk-dotnet-docs.yml) workflow (`.github/workflows/pulumi-sdk-dotnet-docs.yml`).
Workflow run: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}
pr_label: "automation/pulumi-sdk-dotnet-docs,automation/merge"
github_token: ${{ steps.esc-secrets.outputs.PULUMI_BOT_TOKEN }}
- name: Enable auto-merge
if: steps.create-pr.outputs.pr_created == 'true' && github.event.inputs.skip_auto_merge != 'true'
run: gh pr merge ${{ steps.create-pr.outputs.pr_number }} --auto --squash
env:
GITHUB_TOKEN: ${{ steps.esc-secrets.outputs.PULUMI_BOT_TOKEN }}
build-pulumi-sdk-dotnet-docs:
runs-on: ubuntu-latest
outputs:
has_changes: ${{ steps.commit.outputs.has_changes }}
steps:
- name: Fetch secrets from ESC
id: esc-secrets
uses: pulumi/esc-action@v2
- name: set the pulumi-dotnet version
env:
RAW_VERSION: ${{ github.event.inputs.version || github.event.client_payload.ref }}
run: |
echo "DOTNET_SDK_VERSION=${RAW_VERSION#v}" >> $GITHUB_ENV
- name: checkout docs repo
uses: actions/checkout@v6
with:
path: docs
- name: checkout pulumi-dotnet repo
uses: actions/checkout@v6
with:
repository: pulumi/pulumi-dotnet
path: pulumi-dotnet
ref: v${{ env.DOTNET_SDK_VERSION }}
submodules: recursive
- name: Install dotnet
uses: actions/setup-dotnet@v5
with:
dotnet-version: "8.x"
- name: Install docfx
run: dotnet tool install -g docfx
- name: Install Hugo
uses: peaceiris/actions-hugo@v3
with:
hugo-version: '0.157.0'
extended: true
- name: Install node
uses: actions/setup-node@v6
with:
node-version: '24.x'
cache: 'yarn'
cache-dependency-path: |
docs/yarn.lock
docs/infrastructure/yarn.lock
docs/theme/yarn.lock
docs/theme/stencil/yarn.lock
- name: Install Vale (required by scripts/ensure.sh)
run: |
VALE_VERSION="3.14.1"
VALE_SHA256="ff2b49ffaa9dcd246fd5008f03ff67746d2790b75bf4d3657e2fb9530fb96db3"
curl -fsSL -o /tmp/vale.tar.gz "https://github.com/errata-ai/vale/releases/download/v${VALE_VERSION}/vale_${VALE_VERSION}_Linux_64-bit.tar.gz"
echo "${VALE_SHA256} /tmp/vale.tar.gz" | sha256sum -c -
sudo tar -xz -C /usr/local/bin vale -f /tmp/vale.tar.gz
rm /tmp/vale.tar.gz
- run: make ensure
working-directory: docs
- name: Generate .NET SDK docs
run: ./scripts/run_docfx.sh
working-directory: docs
env:
DOCFX_SDK_VERSION: ${{ env.DOTNET_SDK_VERSION }}
- name: git status
run: git status && git diff
working-directory: docs
- name: commit changes
id: commit
run: |
git config --local user.email "bot@pulumi.com"
git config --local user.name "pulumi-bot"
git checkout -b pulumi-sdk-dotnet-docs/${{ github.run_id }}-${{ github.run_number }}
git add static-prebuilt/
if git diff --cached --quiet; then
echo "No changes to commit"
echo "has_changes=false" >> $GITHUB_OUTPUT
else
git commit -m "Regenerating Pulumi SDK .NET docs for pulumi-dotnet@${{ env.DOTNET_SDK_VERSION }}"
git push origin pulumi-sdk-dotnet-docs/${{ github.run_id }}-${{ github.run_number }}
echo "has_changes=true" >> $GITHUB_OUTPUT
fi
working-directory: docs
notify:
if: failure()
name: Send slack notification
runs-on: ubuntu-latest
needs: [pull-request, build-pulumi-sdk-dotnet-docs]
steps:
- name: Fetch secrets from ESC
id: esc-secrets
uses: pulumi/esc-action@v2
- name: Slack Notification
uses: docker://sholung/action-slack-notify:v2.3.0
env:
SLACK_CHANNEL: docs-ops
SLACK_COLOR: "#F54242"
SLACK_MESSAGE: "Pulumi SDK docs - .NET build failure in pulumi/docs repo"
SLACK_USERNAME: docsbot
SLACK_WEBHOOK: ${{ steps.esc-secrets.outputs.SLACK_WEBHOOK_URL }}
SLACK_ICON: https://www.pulumi.com/logos/brand/avatar-on-white.png