このページでは、Secure Source Manager でトリガーの YAML ファイルを作成する手順について説明します。トリガー ファイルを使用すると、Secure Source Manager リポジトリの push イベントと pull リクエスト イベントに基づいてビルドを自動化できます。
トリガー ファイルに含めることができるフィールドについては、トリガー ファイルのスキーマをご覧ください。
始める前に
- Secure Source Manager インスタンスを作成します。
- Secure Source Manager リポジトリを作成する。
- トリガー ファイルのスキーマを読んで、トリガー ファイルに含めることができるフィールドについて確認してください。
必要なロール
トリガー ファイルの作成に必要な権限を取得するには、次の IAM ロールを付与するよう管理者に依頼してください。
-
インスタンスに対する Secure Source Manager インスタンス アクセサー (
roles/securesourcemanager.instanceAccessor
) -
リポジトリに対する Secure Source Manager リポジトリ書き込み (
roles/securesourcemanager.repoWriter
)
ロールの付与については、プロジェクト、フォルダ、組織へのアクセス権の管理をご覧ください。
必要な権限は、カスタムロールや他の事前定義ロールから取得することもできます。
Cloud Build 構成ファイルを作成する
Secure Source Manager トリガー ファイルでは、トリガーごとにビルド構成ファイルを指定する必要があります。
ビルド構成ファイルには、Cloud Build が指定に基づいてタスクを実行するための指示が記述されています。たとえば、ビルド構成ファイルには、Docker イメージのビルド、パッケージ化、push を行う手順を設定できます。
ビルドするブランチにビルド構成ファイルを作成します。ビルド構成ファイルを作成するには、ビルド構成ファイルを作成するの手順に沿って操作します。
トリガー ファイルを作成する
トリガー構成ファイルは、リポジトリのデフォルト ブランチに作成する必要があります。
トリガー構成ファイルを作成するには:
- ローカル リポジトリまたは Secure Source Manager ウェブ インターフェースで、デフォルト ブランチに切り替えます。
.cloudbuild/triggers.yaml
という名前のファイルを作成します。.cloudbuild/triggers.yaml
ファイルでトリガーを構成します。triggers: - name: TRIGGER_NAME project: PROJECT_ID configFilePath: CLOUD_BUILD_CONFIG_PATH eventType: EVENT_TYPE ignoredGitRefs: IGNORED_GIT_REFS includedGitRefs: INCLUDED_GIT_REFS serviceAccount: SERVICE_ACCOUNT includedFiles: INCLUDED_FILES ignoredFiles: IGNORED_FILES disabled: DISABLED_BOOL substitutions: _VARIABLE_NAME: VARIABLE_VALUE OVERRIDE_VARIABLE_NAME: OVERRIDE_VARIABLE_VALUE
次のように置き換えます。
TRIGGER_NAME
は、トリガーの名前に置き換えます。トリガー名に使用できるのは英数字とダッシュのみです。先頭または末尾にダッシュは使用できません。トリガー名は 64 文字未満で指定してください。PROJECT_ID
は、Cloud Build を有効にした Google Cloud プロジェクト ID に置き換えます。このフィールドは省略可能です。デフォルトは Secure Source Manager プロジェクトです。CLOUD_BUILD_CONFIG_PATH
: このトリガーに使用する Cloud Build 構成ファイルへのパス。このフィールドは省略可能です。デフォルト値は.cloudbuild/cloudbuild.yaml
です。EVENT_TYPE
: ビルドをトリガーするイベントタイプ。オプションは次のとおりです。push
: 指定されたブランチへの push でトリガーするpull_request
: 指定されたブランチへの pull リクエストでトリガーする
このフィールドは省略可能です。デフォルト値は
push
です。ビルドをトリガーする Git 参照に一致する、オプションの RE2 正規表現形式を含む
INCLUDED_GIT_REFS
。デフォルト値は空です。値が空の場合は、制限がないことを示します。ビルドをトリガーしない Git 参照に一致する RE2 正規表現形式を使用する正規表現(省略可)を含む
IGNORED_GIT_REFS
。デフォルト値は空です。値が空の場合は、制限がないことを示します。ignoredGitRefs
フィールドはincludedGitRefs
フィールドの前にチェックされます。これらのフィールドの詳細については、トリガー ファイルのスキーマをご覧ください。SERVICE_ACCOUNT
(Cloud Build サービス アカウント): ビルドに使用するアカウント。形式はprojects/PROJECT_ID/serviceAccounts/ACCOUNT
です。ACCOUNT は、サービス アカウントのメールアドレスまたは一意の ID に置き換えます。ベスト プラクティスとして、ユーザー指定のサービス アカウントを構成します。以前の Cloud Build サービス アカウントは、制限事項があるため使用できません。INCLUDED_FILES
: ビルドをトリガーするファイルに一致する RE2 形式の正規表現(省略可)。変更されたファイルのいずれかが
ignoredFiles
フィルタ フィールドと一致せず、変更されたファイルがincludedFiles
フィルタ フィールドと一致する場合、ビルドがトリガーされます。デフォルト値は空です。値が空の場合は、制限がないことを示します。IGNORED_FILES
。ビルドをトリガーしないファイルに一致する RE2 形式の正規表現(省略可)。commit 内の変更されたすべてのファイルがこのフィルタ フィールドと一致する場合、ビルドはトリガーされません。デフォルト値は空です。値が空の場合、制限がないことを示します。
DISABLED_BOOL
: トリガーを無効にする場合はtrue
、トリガーを有効にする場合はfalse
。このフィールドは省略可能です。デフォルト値はfalse
です。VARIABLE_NAME
は、トリガー ファイルに導入する変数の名前に置き換えます。VARIABLE_VALUE
は、変数の値。OVERRIDE_VARIABLE_NAME
は、Secure Source Manager のデフォルトの置換変数名に置き換えます。使用可能なデフォルトの置換変数については、トリガー ファイル スキーマの置換セクションをご覧ください。OVERRIDE_VARIABLE_VALUE
は、デフォルトの置換変数のデフォルト値をオーバーライドする値に置き換えます。
トリガー構成ファイルをデフォルト ブランチに commit します。
トリガー ファイルが commit されると、Secure Source Manager はトリガー ファイルの構成に基づいてビルドをトリガーします。
Secure Source Manager は、次のタイプのイベントの構成ファイルと、関連付けられた commit SHA または Git ref を読み取ります。
push
イベントの場合、プッシュが完了すると、Secure Source Manager は commit SHA または Git ref を読み取ります。pull_request
イベントの場合、Secure Source Manager は、pull リクエストの変更が pull されるときに commit SHA または Git 参照を読み取ります。
ビルドのステータスを表示する
push イベントまたは pull リクエスト イベントによってビルドがトリガーされると、コミットとビルドのステータスが Secure Source Manager ウェブ インターフェースに表示されます。
ビルド ステータスに指定できる値は次のとおりです。
SUCCESS: ビルドが正常に完了しました。
警告: ビルドしようとしたときに問題が発生しました。
FAILURE: 実行中にビルドが失敗しました。
トリガー ファイルで構成されたトリガーからのステータス チェックが成功することを必須とするブランチ保護ルールを構成すると、ビルドが失敗したコミットが重要なブランチにマージされるのを防ぐことができます。ブランチ保護の詳細については、ブランチ保護の概要をご覧ください。
プッシュ イベントのビルド ステータスを表示するには:
Secure Source Manager ウェブ インターフェースで、リポジトリに移動します。
最新の push イベントでビルドがトリガーされた場合、ステータスは commit SHA の横に表示されます。ステータスの詳細を表示するには、ステータスをクリックします。
以前のコミットのビルド ステータスを表示するには、[コミット] を選択してコミット履歴を表示し、詳細を表示するステータスをクリックします。
pull リクエスト イベントのビルド ステータスを表示するには:
- Secure Source Manager ウェブ インターフェースで、[Pull リクエスト] をクリックします。
表示する pull リクエストをクリックします。
ビルドが pull リクエストによってトリガーされた場合は、[すべてのチェックが成功しました] または [一部のチェックで警告が報告されました] というセクションが表示されます。
次のステップ
- トリガー ファイルを使用して Cloud Build に接続します。