概要
GitHub Actions を使ってると、手動で GitHub Actions を実行する必要がある場合があります。このブログポストでは、GitHub Actions を手動で実行する方法について説明します。
workflow_dispatch
GitHub Actions
を手動で実行するには、workflow_dispatch
を使う必要があります。
この場合、workflow_dispatch
の inputs
を使ってパラメータを渡すことができます。
workflow_dispatch
は次のように設定できます。
name: GITHUB ACTIONS NAME
on:
workflow_dispatch:
inputs タイプ
workflow_dispatch
の inputs
には次のような種類があります。
boolean
: true または falsechoice
: 事前に指定されたオプションの中から選択できる SelectBoxnumber
: 数字string
: 文字列environment
: GitHub に設定された環境変数を使用
公式ドキュメントでも使える inputs
タイプを確認することができます。
workflow_dispatch
の inputs
は次のように設定できます。
name: GITHUB ACTIONS NAME
on:
workflow_dispatch:
inputs:
input_boolean:
description: 'This is a boolean input'
required: true
default: false
type: boolean
inputs
は type
以外にも description
, required
, default
を設定することができます。type
以外はすべて任意です。
例題
それでは workflow_dispatch
を使って GitHub Actions を手動で実行する例を見ていきましょう。
boolean
手動で実行する GitHub Actions を作成するために .github/workflows/manual_test.yml
ファイルを作成し、次のように修正します。
name: GITHUB ACTIONS NAME
on:
workflow_dispatch:
inputs:
input_boolean:
description: 'This is a boolean input'
required: true
default: false
type: boolean
jobs:
deploy-to-staging:
runs-on: ubuntu-latest
steps:
- name: Print the input
run: echo $
このように作成したファイルを commit して push した後、GitHub
の Actions
タブに移動すると、次のような画面を確認できます。
data:image/s3,"s3://crabby-images/9e71c/9e71c6ff889f8775ab21cdeafe7f492575256b5d" alt="Execute GitHub Actions manually - Boolean input"
右側に表示された Run workflow
をクリックすると、設定した boolean
タイプの inputs
を確認できます。これを実行すると次のような結果を得ることができます。
data:image/s3,"s3://crabby-images/5691a/5691ab32c76fb42223606917d14a85f5e6812ad8" alt="Execute GitHub Actions manually - Boolean input result"
choice
手動で実行する GitHub Actions を作成するために .github/workflows/manual_test.yml
ファイルを作成し、次のように修正します。
name: GITHUB ACTIONS NAME
on:
workflow_dispatch:
inputs:
input_choice:
description: 'This is a choice input'
required: true
default: 'warning'
type: choice
options:
- info
- warning
- debug
jobs:
deploy-to-staging:
runs-on: ubuntu-latest
steps:
- name: Print the input
run: echo $
このように作成したファイルを commit して push した後、GitHub
の Actions
タブに移動すると、次のような画面を確認できます。
data:image/s3,"s3://crabby-images/8bac7/8bac7cde79957db07ea1d35685ab29b85f615cf7" alt="Execute GitHub Actions manually - Choice input"
右側に表示された Run workflow
をクリックすると、設定した choice
タイプの inputs
を確認できます。これを実行すると次のような結果を得ることができます。
data:image/s3,"s3://crabby-images/22c0e/22c0eb8c422dec5323617c440978998b657e9359" alt="Execute GitHub Actions manually - Choice input result"
number
手動で実行する GitHub Actions を作成するために .github/workflows/manual_test.yml
ファイルを作成し、次のように修正します。
name: GITHUB ACTIONS NAME
on:
workflow_dispatch:
inputs:
input_number:
description: 'This is a number input'
required: true
default: 20
type: number
jobs:
deploy-to-staging:
runs-on: ubuntu-latest
steps:
- name: Print the input
run: echo $
このように作成したファイルを commit して push した後、GitHub
の Actions
タブに移動すると、次のような画面を確認できます。
data:image/s3,"s3://crabby-images/45286/452865dca13591a47fca017a4aa2392bc7f85ea2" alt="Execute GitHub Actions manually - Number input"
右側に表示された Run workflow
をクリックすると、設定した number
タイプの inputs
を確認できます。これを実行すると次のような結果を得ることができます。
data:image/s3,"s3://crabby-images/2796d/2796d5a22c7d07d72d9e349bc035226732fdd93b" alt="Execute GitHub Actions manually - Number input result"
string
手動で実行する GitHub Actions を作成するために .github/workflows/manual_test.yml
ファイルを作成し、次のように修正します。
name: GITHUB ACTIONS NAME
on:
workflow_dispatch:
inputs:
input_string:
description: 'This is a string input'
required: true
default: 'Hello, World!'
type: string
jobs:
deploy-to-staging:
runs-on: ubuntu-latest
steps:
- name: Print the input
run: echo $
このように作成したファイルを commit して push した後、GitHub
の Actions
タブに移動すると、次のような画面を確認できます。
data:image/s3,"s3://crabby-images/e29b2/e29b2f07dffbc5539385b97a658fbf1b0ef3af9a" alt="Execute GitHub Actions manually - String input"
右側に表示された Run workflow
をクリックすると、設定した string
タイプの inputs
を確認できます。これを実行すると次のような結果を得ることができます。
data:image/s3,"s3://crabby-images/c9cdb/c9cdbbef08c85e1c0c49f6842f34374265c24a8d" alt="Execute GitHub Actions manually - String input result"
environment
workflow_dispatch
の environment
タイプを使用するには、GitHub
の Settings
で Environment
を設定する必要があります。
data:image/s3,"s3://crabby-images/5659d/5659dc9f094347bac75d5460a06edbcceeeaf9a4" alt="Execute GitHub Actions manually - Environments"
New environment
をクリックして、次のように Name
に dev
を入力してから、Configure environment
をクリックします。
data:image/s3,"s3://crabby-images/3bf01/3bf01852e8c7fcca7175f14a63eead93fb5cbc00" alt="Execute GitHub Actions manually - New Dev Environment"
その後、Environment variables
の Add environment variable
ボタンをクリックして、次のように Variable
を追加します。
data:image/s3,"s3://crabby-images/4ad8c/4ad8cd62bbcb933affbb157c0f92ede23b4ed673" alt="Execute GitHub Actions manually - Dev environment variable"
同じように prod
という環境にも同じ変数を追加します。
data:image/s3,"s3://crabby-images/0b97c/0b97c8f7a790ca0ef67f4d275cf3e628bddee9e5" alt="Execute GitHub Actions manually - Prod environment variable"
次は、手動で実行する GitHub Actions を作成するために .github/workflows/manual_test.yml
ファイルを作成し、次のように修正し
name: GITHUB ACTIONS NAME
on:
workflow_dispatch:
inputs:
input_environment:
description: 'This is a environment input'
required: true
type: environment
jobs:
deploy-to-staging:
runs-on: ubuntu-latest
environment: $
steps:
- name: Print the input
run: echo $
このように作成したファイルを commit して push した後、GitHub
の Actions
タブに移動すると、次のような画面を確認できます。
data:image/s3,"s3://crabby-images/0bdf2/0bdf2e58ea3729a226398b297628f79e52d32cdc" alt="Execute GitHub Actions manually - Environment input"
右側に表示された Run workflow
をクリックすると、GitHub
の Settings
で Environment
に設定した値が表示されることを確認できます。これを実行すると次のような結果を得ることができます。
- dev 環境
data:image/s3,"s3://crabby-images/1a5ad/1a5adf29b45f20f07556cf408914724caab986d8" alt="Execute GitHub Actions manually - Environment input result dev"
- prod 環境
data:image/s3,"s3://crabby-images/10b02/10b025990280ad35f1f4d09dd41175b47039c84b" alt="Execute GitHub Actions manually - Environment input result prod"
完了
これで GitHub Actions を手動で実行する方法について説明しました。また、設定可能な inputs
タイプについても説明しました。
皆さんも workflow_dispatch
とさまざまなタイプの inputs
を使って GitHub Actions を手動で実行してみてください。
私のブログが役に立ちましたか?下にコメントを残してください。それは私にとって大きな大きな力になります!
アプリ広報
Deku
が開発したアプリを使ってみてください。Deku
が開発したアプリはFlutterで開発されています。興味がある方はアプリをダウンロードしてアプリを使ってくれると本当に助かります。