Skip to content

Commit

Permalink
Make workflow reusable
Browse files Browse the repository at this point in the history
  • Loading branch information
michalinacienciala committed Mar 9, 2023
1 parent 682b018 commit 6b89685
Show file tree
Hide file tree
Showing 3 changed files with 293 additions and 1 deletion.
2 changes: 1 addition & 1 deletion .github/workflows/docs.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
name: Solidity docs

on:
pull_request:
# pull_request:
push:
branches:
- releases/mainnet/solidity/**
Expand Down
199 changes: 199 additions & 0 deletions .github/workflows/reusable-solidity-docs.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,199 @@
name: Generate and publish contracts documentation

on:
workflow_call:
inputs:
projectSubfolder:
description: A root's subfolder containing `contracts` folder and
Yarn / Hardhat configuration. Leave empty ('') if project config
resides in the root. If config resides in subfolder, provide the
subfolder name/path, without leading `.` and ending `/`. For example,
type `/v2/solidity` if path to the `contracts` folder
is `./v2/solidity/contracts`.
required: false
default: ''
type: string
preProcessingCommand:
description: An optional additional bash command to be executed before
transforming the Solidity files to an HTML file.
required: false
type: string
docName:
description: A name (without extension) of the generated file (for
example, 'tbtc-v2-contracts'); will be used in the final URL.
required: true
type: string
publish:
description: True if you want to publish the generated HTML file to the
GCR bucket (main or preview).
required: false
default: true
type: boolean
gcpProject:
description: A name of the GCP project hosting the bucket where the
generated HTML file will land. Required if publish=true.
required: false
type: string
gcpBucketName:
description: A name of the the bucket where the generated HTML file will
land. Required if publish=true.
required: false
type: string
gcpBucketPath:
description: A bucket's subfolder where the generated HTML file will
land. If no subfolder is to be used, please type `.`. For publishing
previews of the documentation we suggest using a path with the ref
name at the end of the path (`/dollar{{ github.ref_name }}`,
where `dollar` is `$`).
required: false
default: '.'
type: string
commentPR:
description: True if you want to add a comment with the path to the
generated file in the PR invoking the workflow. If workflow is not
triggered by the PR, having this input set to `true` will not brake
the execution.
required: false
default: true
type: boolean
debug:
description: True if you want to see the generated artifacts in GH run
details.
required: false
default: false
type: boolean
secrets:
gcpServiceKeyBase64:
description: GCP service key encoded as base64. The account associated
with the key should have permissions to make changes in the storage
bucket.
required: false

jobs:
docs-generate-html-and-publish:
runs-on: ubuntu-latest
defaults:
run:
working-directory: .${{ inputs.projectSubfolder }}
steps:
- uses: actions/checkout@v3

# In this step we modify the format of the comments in the Solidity
# contracts files. We do that because our original formatting is not
# processed by Docgen in the way we would like.
# To nicely display lists (like the list of requirements) we need to
# remove multiple space chars after the `///` comment. We do that by
# executing `sed 's_///[[:blank:]]*_///_'` on all contracts files, which
# substitutes `///` + 0 or more spaces/tabs with just `///`.

- name: Prepare contract files for further processing
shell: bash
run: |
find ./contracts \
-name "*.sol" \
-type f \
-exec sed -i 's_///[[:blank:]]*_///_' {} \;
- name: Execute additional command
if: inputs.preProcessingCommand != null
shell: bash
run: ${{ inputs.preProcessingCommand }}

- name: Export artifacts
if: inputs.debug == true
uses: actions/upload-artifact@master
with:
name: modified-contracts
path: .${{ inputs.projectSubfolder }}/contracts

# We need this step because the `@keep-network/tbtc` which we update in
# next steps has a dependency to `@summa-tx/[email protected]` package, which
# downloads one of its sub-dependencies via unathenticated `git://`
# protocol. That protocol is no longer supported. Thanks to this step
# `https://` is used instead of `git://`. This step also prevents the
# error during `yarn install --frozen-lockfile` step in case `git://` gets
# introduced to tbtc-v2's `yarn.lock`.
- name: Configure git to don't use unauthenticated protocol
shell: bash
run: git config --global url."https://".insteadOf git://

- name: Install dependencies
shell: bash
run: yarn install --frozen-lockfile

- name: Build Markdown docs # Outputs file to `.${{ inputs.projectSubfolder }}/generated-docs/index.md`
run: yarn run hardhat docgen

- name: Export artifacts
if: inputs.debug == true
uses: actions/upload-artifact@master
with:
name: md
path: .${{ inputs.projectSubfolder }}/generated-docs

# We need Ruby to install Kramdown AsciiDoc
- name: Setup Ruby
uses: ruby/[email protected]
with:
ruby-version: '3.2'
bundler-cache: true

- name: Install Kramdown AsciiDoc
shell: bash
run: gem install kramdown-asciidoc

- name: Convert Markdown to Asciidoc
shell: bash
run: kramdoc --output=./generated-docs/${{ inputs.docName }}.adoc ./generated-docs/index.md

- name: Add Table of Contents
shell: bash
run: |
sed -i '1s/^/:toclevels: 1 \n/' ./generated-docs/${{ inputs.docName }}.adoc
sed -i '1s/^/:toc: left \n/' ./generated-docs/${{ inputs.docName }}.adoc
- name: Export artifacts
if: inputs.debug == true
uses: actions/upload-artifact@master
with:
name: adoc
path: .${{ inputs.projectSubfolder }}/generated-docs

- name: Build HTML docs
id: html
uses: thesis/[email protected]
with:
files: '.${{ inputs.projectSubfolder }}/generated-docs/${{ inputs.docName }}.adoc'
args: '-a revdate=`date +%Y-%m-%d` --failure-level=ERROR'

- name: Export artifacts
if: inputs.debug == true
uses: actions/upload-artifact@master
with:
name: asciidoc-out
path: ./asciidoc-out

- name: Upload asciidocs preview
if: inputs.publish == true
uses: thesis/[email protected]
with:
service-key: ${{ secrets.gcpServiceKeyBase64 }}
project: ${{ inputs.gcpProject }}
bucket-name: ${{ inputs.gcpBucketName }}
bucket-path: ${{ inputs.gcpBucketPath }}
build-folder: ${{ steps.html.outputs.asciidoctor-artifacts }}${{ inputs.projectSubfolder }}/generated-docs

- name: Post preview URL to PR
if: |
inputs.publish == true
&& inputs.commentPR == true
&& startsWith(github.ref, 'refs/pull')
uses: actions/github-script@v5
with:
script: |
github.rest.issues.createComment({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
body: 'Documentation preview uploaded to https://${{ inputs.gcpBucketName }}/${{ inputs.gcpBucketPath }}/${{ inputs.docName }}.html.'
})
93 changes: 93 additions & 0 deletions .github/workflows/solidity-docs.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
name: Solidity docs (WIP) # TODO: Change name

on:
pull_request:
push:
branches:
- releases/mainnet/solidity/**
release:
types:
- "published"
workflow_dispatch:

jobs:
docs-detect-changes:
runs-on: ubuntu-latest
outputs:
path-filter: ${{ steps.filter.outputs.path-filter }}
steps:
- uses: actions/checkout@v3
if: github.event_name == 'pull_request'
- uses: dorny/paths-filter@v2
if: github.event_name == 'pull_request'
id: filter
with:
filters: |
path-filter:
- './solidity/contracts/**'
- './.github/workflows/solidity-docs.yml'
contracts-docs-build:
name: Build contracts documentation
needs: docs-detect-changes
if: github.event_name == 'workflow_dispatch'
uses: keep-network/tbtc-v2/.github/workflows/reusable-solidity-docs.yml@document-contracts #TODO: replace `@document-contracts` with `@main`
with:
projectSubfolder: /solidity
# We need to remove unnecessary `//` comment used in the `@dev`
# section of `BitcoinTx` documentation, which was causing problem with
# rendering of the `.md` file. We do that by executing
# `sed -i ':a;N;$!ba;s_///\n//\n_///\n_g'` on the problematic file. The
# command substitutes `///` + newline + `//` + newline with just `///` +
# newline and does this in a loop.
preProcessingCommand: sed -i ':a;N;$!ba;s_///\n//\n_///\n_g' ./contracts/bridge/BitcoinTx.sol
docName: tbtc-v2-contracts
publish: false
debug: true
secrets:
gcpServiceKeyBase64: ${{ secrets.THRESHOLD_API_DOCS_UPLOADER_SERVICE_KEY_BASE64 }}

contracts-docs-publish-preview:
name: Publish preview of contracts documentation
needs: docs-detect-changes
if: github.event_name == 'pull_request' || github.event_name == 'push'
uses: keep-network/tbtc-v2/.github/workflows/reusable-solidity-docs.yml@document-contracts #TODO: replace `@document-contracts` with `@main`
with:
projectSubfolder: /solidity
# We need to remove unnecessary `//` comment used in the `@dev`
# section of `BitcoinTx` documentation, which was causing problem with
# rendering of the `.md` file. We do that by executing
# `sed -i ':a;N;$!ba;s_///\n//\n_///\n_g'` on the problematic file. The
# command substitutes `///` + newline + `//` + newline with just `///` +
# newline and does this in a loop.
preProcessingCommand: sed -i ':a;N;$!ba;s_///\n//\n_///\n_g' ./contracts/bridge/BitcoinTx.sol
docName: tbtc-v2-contracts
publish: true
gcpProject: keep-prd
gcpBucketName: api-docs.threshold.network
gcpBucketPath: solidity/${{ github.ref_name }}
commentPR: true
secrets:
gcpServiceKeyBase64: ${{ secrets.THRESHOLD_API_DOCS_UPLOADER_SERVICE_KEY_BASE64 }}

contracts-docs-publish:
name: Publish contracts documentation
needs: docs-detect-changes
if: github.event_name == 'release' && startsWith(github.ref, 'refs/tags/solidity/')
uses: keep-network/tbtc-v2/.github/workflows/reusable-solidity-docs.yml@document-contracts #TODO: replace `@document-contracts` with `@main`
with:
projectSubfolder: /solidity
# We need to remove unnecessary `//` comment used in the `@dev`
# section of `BitcoinTx` documentation, which was causing problem with
# rendering of the `.md` file. We do that by executing
# `sed -i ':a;N;$!ba;s_///\n//\n_///\n_g'` on the problematic file. The
# command substitutes `///` + newline + `//` + newline with just `///` +
# newline and does this in a loop.
preProcessingCommand: sed -i ':a;N;$!ba;s_///\n//\n_///\n_g' ./contracts/bridge/BitcoinTx.sol
docName: tbtc-v2-contracts
publish: true
gcpProject: keep-prd
gcpBucketName: api-docs.threshold.network
gcpBucketPath: solidity
secrets:
gcpServiceKeyBase64: ${{ secrets.THRESHOLD_API_DOCS_UPLOADER_SERVICE_KEY_BASE64 }}

0 comments on commit 6b89685

Please sign in to comment.