개요
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로 개발되었습니다.관심있으신 분들은 앱을 다운로드하여 사용해 주시면 정말 감사하겠습니다.