Skip to content

Commit

Permalink
Merge pull request #49 from canonical/add-generic-publish-on-click
Browse files Browse the repository at this point in the history
feat: Add generic, clickable publish.yaml
  • Loading branch information
ca-scribner authored Aug 16, 2022
2 parents 561653a + 81bf2dd commit 908ab82
Show file tree
Hide file tree
Showing 4 changed files with 95 additions and 19 deletions.
30 changes: 30 additions & 0 deletions .github/workflows/get-charm-paths.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
#!/bin/bash -x

# Finds the charms in this repo, outputing them as JSON
# Will return one of:
# * the relative paths of the directories listed in `./charms`, if that directory exists
# * "./", if the root directory has a "metadata.yaml" file
# * otherwise, error
#
# Modifed from: https://stackoverflow.com/questions/63517732/github-actions-build-matrix-for-lambda-functions/63736071#63736071
CHARMS_DIR="./charms"
if [ -d "$CHARMS_DIR" ];
then
CHARM_PATHS=$(find $CHARMS_DIR -maxdepth 1 -type d -not -path '*/\.*' -not -path "$CHARMS_DIR")
else
if [ -f "./metadata.yaml" ]
then
CHARM_PATHS="./"
else
echo "Cannot find valid charm directories - aborting"
exit 1
fi
fi

# Convert output to JSON string format
# { charm_paths: [...] }
CHARM_PATHS_LIST=$(echo "$CHARM_PATHS" | jq -c --slurp --raw-input 'split("\n")[:-1]')

echo "Found CHARM_PATHS_LIST: $CHARM_PATHS_LIST"

echo "::set-output name=CHARM_PATHS_LIST::$CHARM_PATHS_LIST"
6 changes: 3 additions & 3 deletions .github/workflows/on_pull_request.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Test and publish to branch
name: On Pull Request

# On pull_request, we:
# * always publish to charmhub at latest/edge/branchname
Expand All @@ -13,11 +13,11 @@ jobs:
name: Run Tests
uses: ./.github/workflows/integrate.yaml
secrets:
charmcraft-credentials: "${{ secrets.CHARMCRAFT_CREDENTIALS }}"
charmcraft-credentials: ${{ secrets.CHARMCRAFT_CREDENTIALS }}

# publish runs in parallel with tests, as we always publish in this situation
publish-charm:
name: Publish Charm
uses: ./.github/workflows/publish.yaml
secrets:
charmcraft-credentials: "${{ secrets.CHARMCRAFT_CREDENTIALS }}"
CHARMCRAFT_CREDENTIALS: ${{ secrets.CHARMCRAFT_CREDENTIALS }}
12 changes: 6 additions & 6 deletions .github/workflows/on_push.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Publish to edge if tests passed
name: On Push

# On push to a "special" branch, we:
# * always publish to charmhub at latest/edge/branchname
Expand All @@ -10,22 +10,22 @@ name: Publish to edge if tests passed
on:
push:
branches:
- master
- main
- track/**
- master
- main
- track/**

jobs:

tests:
name: Run Tests
uses: ./.github/workflows/integrate.yaml
secrets:
charmcraft-credentials: "${{ secrets.CHARMCRAFT_CREDENTIALS }}"
charmcraft-credentials: ${{ secrets.CHARMCRAFT_CREDENTIALS }}

# publish runs in series with tests, and only publishes if tests passes
publish-charm:
name: Publish Charm
needs: tests
uses: ./.github/workflows/publish.yaml
secrets:
charmcraft-credentials: "${{ secrets.CHARMCRAFT_CREDENTIALS }}"
CHARMCRAFT_CREDENTIALS: ${{ secrets.CHARMCRAFT_CREDENTIALS }}
66 changes: 56 additions & 10 deletions .github/workflows/publish.yaml
Original file line number Diff line number Diff line change
@@ -1,36 +1,82 @@
# reusable workflow triggered by other actions
# reusable workflow for publishing all charms in this repo
name: Publish

on:
workflow_call:
secrets:
charmcraft-credentials:
CHARMCRAFT_CREDENTIALS:
required: true
workflow_dispatch:
inputs:
# TODO: Implement this
# source_github_branch:
# description: Source branch to publish
# required: false
# default: 'main'
destination_channel:
description: CharmHub channel to publish to
required: false
default: 'latest/edge'

jobs:
get-charm-paths:
name: Generate the Charm Matrix
runs-on: ubuntu-latest
outputs:
charm_paths_list: ${{ steps.get-charm-paths.outputs.CHARM_PATHS_LIST }}
steps:
- uses: actions/checkout@v2
- name: Get paths for all charms in repo
id: get-charm-paths
run: bash .github/workflows/get-charm-paths.sh


publish-charm:
name: Publish Charm
runs-on: ubuntu-latest
needs: get-charm-paths
strategy:
fail-fast: false
matrix:
charm:
- jupyter-controller
- jupyter-ui
charm-path: ${{ fromJson(needs.get-charm-paths.outputs.charm_paths_list) }}

steps:
- name: Checkout
uses: actions/checkout@v2
with:
fetch-depth: 0

- name: Select charmhub channel
uses: canonical/charming-actions/[email protected]
id: channel
id: select-channel
if: ${{ inputs.destination_channel == '' }}

# Combine inputs from different sources to a single canonical value so later steps don't
# need logic for picking the right one
- name: Parse and combine inputs
id: parse-inputs
run: |
# destination_channel
destination_channel="${{ inputs.destination_channel || steps.select-channel.outputs.name }}"
echo "setting output of destination_channel=$destination_channel"
echo "::set-output name=destination_channel::$destination_channel"
# tag_prefix
# if charm_path = ./ --> tag_prefix = '' (null)
# if charm_path != ./some-charm (eg: a charm in a ./charms dir) --> tag_prefix = 'some-charm'
if [ ${{ matrix.charm-path }} == './' ]; then
tag_prefix=''
else
tag_prefix=$(basename ${{ matrix.charm-path }} )
fi
echo "setting output of tag_prefix=$tag_prefix"
echo "::set-output name=tag_prefix::$tag_prefix"
- name: Upload charm to charmhub
uses: canonical/charming-actions/[email protected]
with:
credentials: ${{ secrets.charmcraft-credentials }}
credentials: ${{ secrets.CHARMCRAFT_CREDENTIALS }}
github-token: ${{ secrets.GITHUB_TOKEN }}
charm-path: charms/${{ matrix.charm }}
channel: ${{ steps.channel.outputs.name }}
tag-prefix: ${{ matrix.charm }}
charm-path: ${{ matrix.charm-path }}
channel: ${{ steps.parse-inputs.outputs.destination_channel }}
tag-prefix: ${{ steps.parse-inputs.outputs.tag_prefix }}

0 comments on commit 908ab82

Please sign in to comment.