{"meta":{"title":"GitHub Actions Importer を使用した CircleCI からの移行","intro":"GitHub Actions Importerを使用して、CircleCI パイプラインのGitHub Actionsへの移行を自動化する方法について説明します。","product":"GitHub Actions","breadcrumbs":[{"href":"/ja/actions","title":"GitHub Actions"},{"href":"/ja/actions/tutorials","title":"チュートリアル"},{"href":"/ja/actions/tutorials/migrate-to-github-actions","title":"GitHub Actions に移行する"},{"href":"/ja/actions/tutorials/migrate-to-github-actions/automated-migrations","title":"自動移行"},{"href":"/ja/actions/tutorials/migrate-to-github-actions/automated-migrations/circleci-migration","title":"CircleCI の移行"}],"documentType":"article"},"body":"# GitHub Actions Importer を使用した CircleCI からの移行\n\nGitHub Actions Importerを使用して、CircleCI パイプラインのGitHub Actionsへの移行を自動化する方法について説明します。\n\n## GitHub Actions Importer を使用した CircleCI からの移行について\n\n次の手順では、 GitHub Actions Importer を使用して CircleCI パイプラインを GitHub Actionsに移行するように環境を構成する手順について説明します。\n\n### 前提条件\n\n* GitHub Actionsワークフローに変換するプロジェクトとパイプラインを含む CircleCI アカウントまたは組織。\n* アカウントまたは Organization の CircleCI 個人用 API トークンを作成するためのアクセス。\n* Linux ベースのコンテナーを実行し、必要なツールをインストールできる環境。\n  * Docker が[インストールされていて](https://docs.docker.com/get-docker/)実行されていること。\n\n  * [GitHub CLI](https://cli.github.com) がインストールされていること。\n  > \\[!NOTE]\n  > GitHub Actions Importer コンテナーと CLI は、CI プラットフォームと同じサーバーにインストールする必要はありません。\n\n### 制限事項\n\n```\n          GitHub Actionsを使用して CircleCI からGitHub Actions Importerに移行する場合、いくつかの制限があります。\n```\n\n* 異なるワークフローのジョブ間での自動キャッシュはサポートされていません。\n* `audit` コマンドは、CircleCI 組織アカウントを使っている場合にのみサポートされます。\n  `dry-run` コマンドと `migrate` コマンドは、CircleCI 組織またはユーザー アカウントで使うことができます。\n\n#### 手動タスク\n\n特定の CircleCI 構成は手動で移行する必要があります。 これには以下が含まれます。\n\n* コンテキスト\n* プロジェクト レベルの環境変数\n* 不明なジョブ プロパティ\n* 不明な球体\n\n##\n\n```\n          GitHub Actions Importer CLI 拡張機能のインストール\n```\n\n1. GitHub Actions Importer CLI 拡張機能のインストール\n\n   ```bash copy\n   gh extension install github/gh-actions-importer\n   ```\n\n2. 拡張機能がインストールされていることを確認します。\n\n   ```bash\n   $ gh actions-importer -h\n   Options:\n     -?, -h, --help  Show help and usage information\n\n   Commands:\n     update     Update to the latest version of GitHub Actions Importer.\n     version    Display the version of GitHub Actions Importer.\n     configure  Start an interactive prompt to configure credentials used to authenticate with your CI server(s).\n     audit      Plan your CI/CD migration by analyzing your current CI/CD footprint.\n     forecast   Forecast GitHub Actions usage from historical pipeline utilization.\n     dry-run    Convert a pipeline to a GitHub Actions workflow and output its yaml file.\n     migrate    Convert a pipeline to a GitHub Actions workflow and open a pull request with the changes.\n   ```\n\n## 資格情報の構成\n\n```\n          `configure` CLI コマンドを使用して、CircleCI と GitHub Actions Importer を操作するときにGitHubに必要な資格情報とオプションを設定します。\n```\n\n1\\.\nGitHub\npersonal access token (classic)を作成します。 詳しくは、「[個人用アクセス トークンを管理する](/ja/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens#creating-a-personal-access-token-classic)」をご覧ください。\n\nトークンには、 `repo` スコープと `workflow` スコープが必要です。\n\nトークンは、作成後にコピーして、後で使用できるように安全な場所に保存します。\n\n1. CircleCI 個人用 API トークンを作成します。 詳しくは、CircleCI ドキュメントの「[API トークンの管理](https://circleci.com/docs/managing-api-tokens/#creating-a-personal-api-token)」を参照してください。\n\n   トークンは、作成後にコピーして、後で使用できるように安全な場所に保存します。\n\n2. ターミナルで、 GitHub Actions Importer`configure` CLI コマンドを実行します。\n\n   ```shell\n   gh actions-importer configure\n   ```\n\n   ```\n          `configure` コマンドでは、次の情報の入力が求められます。\n   ```\n\n   * \\[どの CI プロバイダーを構成していますか?] で、方向キーを使用して `CircleCI` を選択し、<kbd>Space</kbd> キーを押して選択し、<kbd>Enter</kbd> キーを押します。\n   * \\[Personal access token for GitHub] に、先ほど作成した personal access token (classic) の値を入力し、 <kbd>Enter キー</kbd>を押します。\n   * \\[GitHub インスタンスのベース URL] で、 キーを押します。<kbd>Enter</kbd> キーを押して既定値 (`https://github.com`) をそのまま使用します。\n   * \"CircleCI のPersonal access token \" には、先ほど作成した CircleCI 個人用 API トークンの値を入力し、 <kbd>Enter キー</kbd>を押します。\n   * \"CircleCI インスタンスのベース URL\" で、<kbd>Enter</kbd> キーを押して既定値 (`https://circleci.com`) を受け入れます。\n   * 「CircleCI 組織名」のフィールドに、あなたの CircleCI 組織の名前を入力し、<kbd>Enter</kbd>キーを押します。\n\n   以下に `configure` コマンドの例を示します。\n\n   ```shell\n   $ gh actions-importer configure\n   ✔ Which CI providers are you configuring?: CircleCI\n   Enter the following values (leave empty to omit):\n   ✔ Personal access token for GitHub: ***************\n   ✔ Base url of the GitHub instance: https://github.com\n   ✔ Personal access token for CircleCI: ********************\n   ✔ Base url of the CircleCI instance: https://circleci.com\n   ✔ CircleCI organization name: mycircleciorganization\n   Environment variables successfully updated.\n   ```\n\n3. ターミナルで、 GitHub Actions Importer`update` CLI コマンドを実行して GitHub PackagesContainer registry に接続し、コンテナー イメージが最新バージョンに更新されていることを確認します。\n\n   ```shell\n   gh actions-importer update\n   ```\n\n   コマンドの出力は次のようになります。\n\n   ```shell\n   Updating ghcr.io/actions-importer/cli:latest...\n   ghcr.io/actions-importer/cli:latest up-to-date\n   ```\n\n## CircleCI の監査を実行する\n\n```\n          `audit` コマンドを使って、CircleCI Organization 内のすべてのプロジェクトの概要ビューを取得できます。\n\n          `audit` コマンドによって、次のステップが実行されます。\n```\n\n1. CircleCI組織で定義されているすべてのプロジェクトを取得します。\n2. 各パイプラインを、同等の GitHub Actions ワークフローに変換します。\n3. ```\n          GitHub Actions Importerを使用して移行の完了と複雑さを要約したレポートを生成します。\n   ```\n\n### 監査コマンドの実行\n\nCircleCI Organization の監査を実行するには、ターミナルで次のコマンドを実行します。\n\n```shell\ngh actions-importer audit circle-ci --output-dir tmp/audit\n```\n\n### 監査結果の検査\n\n監査の結果は、指定した出力ディレクトリ内のファイルに含まれます。 監査結果の概要については、`audit_summary.md` ファイルを参照してください。\n\n監査の概要には、次のセクションがあります。\n\n#### Pipelines\n\n\"パイプライン\" セクションには、GitHub Actions Importer によって行われた変換率に関する統計情報の概要が含まれます。\n\n以下に、\"パイプライン\" セクションに表示される可能性がある主な用語を示します。\n\n* **成功**したパイプラインでは、100% のパイプライン構成と個々の項目が、同等の GitHub Actions に自動的に変換されました。\n* **部分的に成功**したパイプラインは、すべてのパイプライン構成が変換されましたが、同等の GitHub Actions に自動的に変換されなかった個別項目がいくつかあります。\n* **未サポート**のパイプラインは、GitHub Actions Importer でサポートされていない定義の種類です。\n* **失敗**したパイプラインは、変換中に致命的なエラーが発生しました。 これは、次の 3 つの理由のいずれかで発生する可能性があります。\n  * パイプラインの構成が元々正しくなかったため、有効でなかった。\n  * 変換時に GitHub Actions Importer で内部エラーが発生した。\n  * ネットワーク応答が失敗して、パイプラインにアクセスできなくなったが、これは多くの場合、無効な資格情報が原因である。\n\n#### ビルド ステップ\n\n\"ビルド ステップ\" セクションには、すべてのパイプラインで使われる個々のビルド ステップの概要と、GitHub Actions Importer によって自動的に変換された数が含まれます。\n\n以下に、\"ビルド ステップ\" セクションに表示される可能性がある主な用語を示します。\n\n* **既知**のビルド ステップは、同等のアクションに自動的に変換されたステップです。\n* **不明**なビルド ステップは、同等のアクションに自動的に変換されなかったステップです。\n* **未サポート**のビルド ステップは、次のいずれかのステップです。\n  * GitHub Actions で基本的にサポートされていない。\n  * GitHub Actions と互換性のない方法で構成されている。\n* **アクション**は、変換されたワークフローで使われたアクションのリストです。 これは、次の場合に重要である可能性があります。\n  * GitHub Enterprise Server を使う場合、インスタンスに同期するアクションのリストを収集する。\n  * 使われるアクションの組織レベルの許可リストを定義する。 このアクション リストは、セキュリティ チームまたはコンプライアンス チームの確認を必要とする可能性があるアクションの包括的なリストです。\n\n#### 手動タスク\n\n\"手動タスク\" セクションには、GitHub Actions Importer で自動的に完了できず、手動で完了する必要があるタスクの概要が含まれます。\n\n以下に、\"手動タスク\" セクションに表示される可能性がある主な用語を示します。\n\n* **シークレット**は、変換されたパイプラインで使われるリポジトリまたは組織レベルのシークレットです。 これらのパイプラインが正常に機能するためには、これらのシークレットを GitHub Actions で手動で作成する必要があります。 詳しくは、「[GitHub Actions でのシークレットの使用](/ja/actions/security-guides/using-secrets-in-github-actions)」をご覧ください。\n* **セルフホステッド ランナー**とは、変換されたパイプラインで参照されるランナーのラベルのうち、GitHub ホステッド ランナーではないものを指します。 これらのパイプラインを適切に機能させるには、これらのランナーを手動で定義する必要があります。\n\n#### ファイル\n\n監査レポートの最後のセクションには、監査中にディスクに書き込まれたすべてのファイルのマニフェストが表示されます。\n\n各パイプライン ファイルには、次のようなさまざまなファイルが監査に含まれます。\n\n* GitHub で定義された元のパイプライン。\n* パイプラインの変換に使われたネットワーク応答のすべて。\n* 変換されたワークフロー ファイル。\n* 失敗したパイプライン変換のトラブルシューティングに使用できるスタック トレース。\n\nさらに、`workflow_usage.csv` ファイルには、正常に変換された各パイプラインで使われるすべてのアクション、シークレット、ランナーのコンマ区切りのリストが含まれます。 これは、どのワークフローがどのアクション、シークレット、ランナーを使うかを判断するのに役立ち、セキュリティ レビューを実行するのに役立ちます。\n\n## 潜在的な GitHub Actions の使用状況を予測する\n\n```\n          `forecast` コマンドを使用すると、CircleCI で完了したパイプライン実行のメトリックを計算することで、潜在的なGitHub Actions使用状況を予測できます。\n```\n\n### forecast コマンドの実行\n\n潜在的な GitHub Actions 使用状況の予測を実行するには、ターミナルで次のコマンドを実行します。 既定では、 GitHub Actions Importer は予測レポートに過去 7 日間を含みます。\n\n```shell\ngh actions-importer forecast circle-ci --output-dir tmp/forecast_reports\n```\n\n### 予測レポートの検査\n\n予測の結果は、指定した出力ディレクトリ内の `forecast_report.md` ファイルに含まれます。\n\n以下に、予測レポートに表示される可能性がある主な用語を示します。\n\n* **ジョブ数**は、完了したジョブの合計数です。\n* **パイプライン数**は、使われた一意のパイプラインの数です。\n* **実行時間**は、ランナーがジョブに費やした時間を表します。 このメトリックは、 GitHubホストランナーのコストを計画するのに役立ちます。\n\n  このメトリックは、 GitHub Actionsでの支出が予想される量と関連付けられます。 これは、この時間 (分) に使われるハードウェアによって異なります。\n  [\n  GitHub Actions料金計算ツール](https://github.com/pricing/calculator)を使用して、コストを見積もることができます。\n* **キュー時間**メトリクスは、ランナーが実行できるようになるのを待機するためにジョブが費やした時間を表します。\n* **同時実行ジョブ** メトリックは、特定の時点で実行されるジョブの量を表します。 このメトリックを使って、構成する必要があるランナーの数を定義できます。\n\nさらに、これらのメトリックは、CircleCI のランナーの各キューに対して定義されます。 これはホステッド ランナーとセルフホステッド ランナー、またはハイ スペック マシンとロー スペック マシンが混在している場合に特に有用で、異なるタイプのランナーに固有のメトリックを確認できます。\n\n## CircleCI パイプラインの dry-run 移行を実行する\n\n```\n          `dry-run` コマンドを使用して、CircleCI パイプラインを同等のGitHub Actionsワークフローに変換できます。 dry-run を実行すると、指定したディレクトリに出力ファイルが作成されますが、パイプラインを移行するための pull request は開かれません。\n```\n\nCircleCI プロジェクトを GitHub Actionsに移行するドライ ランを実行するには、ターミナルで次のコマンドを実行し、 `my-circle-ci-project` を CircleCI プロジェクトの名前に置き換えます。\n\n```shell\ngh actions-importer dry-run circle-ci --output-dir tmp/dry-run --circle-ci-project my-circle-ci-project\n```\n\n指定した出力ディレクトリで、ドライ ランのログと変換されたワークフロー ファイルを表示できます。\n\n不明なビルド ステップや部分的に成功したパイプラインなど、GitHub Actions Importer で自動的に変換できなかったものがある場合は、カスタム トランスフォーマーを作成して変換プロセスをさらにカスタマイズできます。 詳しくは、「[カスタム トランスフォーマーを使用した GitHub Actions Importer の拡張](/ja/actions/migrating-to-github-actions/automated-migrations/extending-github-actions-importer-with-custom-transformers)」をご覧ください。\n\n## CircleCI パイプラインの運用移行を実行する\n\n```\n          `migrate` コマンドを使用すると、CircleCI パイプラインを変換し、同等のGitHub Actionsワークフローで pull request を開くことができます。\n```\n\n### migrate コマンドの実行\n\nCircleCI パイプラインを GitHub Actionsに移行するには、ターミナルで次のコマンドを実行し、 `target-url` の値を GitHub リポジトリの URL に置き換え、 `my-circle-ci-project` を CircleCI プロジェクトの名前に置き換えます。\n\n```shell\ngh actions-importer migrate circle-ci --target-url https://github.com/octo-org/octo-repo --output-dir tmp/migrate --circle-ci-project my-circle-ci-project\n```\n\nコマンドの出力には、変換されたワークフローをリポジトリに追加する pull request への URL が含まれます。 成功した出力の例は、次のようになります。\n\n```shell\n$ gh actions-importer migrate circle-ci --target-url https://github.com/octo-org/octo-repo --output-dir tmp/migrate --circle-ci-project my-circle-ci-project\n[2022-08-20 22:08:20] Logs: 'tmp/migrate/log/actions-importer-20220916-014033.log'\n[2022-08-20 22:08:20] Pull request: 'https://github.com/octo-org/octo-repo/pull/1'\n```\n\n### pull request の検査\n\n`migrate` コマンドが正常に実行された場合、出力には、変換されたワークフローをリポジトリに追加する新しい pull request へのリンクが含まれます。\n\npull request の重要な要素には、次のようなものがあります。\n\n* pull request の説明の「**手動ステップ**」というセクションには、パイプラインの GitHub Actions への移行を終了する前に手動で完了する必要があるステップが列挙されています。 たとえば、このセクションでは、ワークフローで使われるシークレットを作成するように指示する場合があります。\n* 変換されたワークフロー ファイル。 Pull request の **\\[Files changed]** タブを選んで、GitHub リポジトリに追加されるワークフロー ファイルを表示します。\n\nPull request の検査が終了したら、それをマージして、ワークフローを GitHub リポジトリに追加できます。\n\n## リファレンス\n\nこのセクションには、 GitHub Actions Importer を使用して CircleCI から移行する場合の環境変数、省略可能な引数、およびサポートされる構文に関する参照情報が含まれています。\n\n### 環境変数の使用\n\nGitHub Actions Importer では、認証構成に環境変数が使われます。 これらの変数は、`configure` コマンドを使って構成プロセスに従うことで設定します。 詳細については、[資格情報の構成](#configuring-credentials)に関するセクションを参照してください。\n\n```\n          GitHub Actions Importer では、次の環境変数を使用して CircleCI インスタンスに接続します。\n```\n\n* `GITHUB_ACCESS_TOKEN`: 変換されたワークフローを使用してプル要求を作成するために使用される personal access token (classic) ( `repo` スコープと `workflow` スコープが必要です)。\n* `GITHUB_INSTANCE_URL`: ターゲット GitHub インスタンスへの URL (たとえば、 `https://github.com`)。\n* `CIRCLE_CI_ACCESS_TOKEN`: CircleCI インスタンスで認証するために使われる CircleCI 個人用 API トークン。\n* `CIRCLE_CI_INSTANCE_URL`: CircleCI インスタンスの URL (例: `https://circleci.com`)。 変数が未設定のままの場合は、`https://circleci.com` が既定値として使われます。\n* `CIRCLE_CI_ORGANIZATION`: CircleCI インスタンスの Organization 名。\n* `CIRCLE_CI_PROVIDER`: パイプラインのソース ファイルが格納されている場所 (`github` など)。 現時点では、GitHub のみがサポートされています。\n* `CIRCLE_CI_SOURCE_GITHUB_ACCESS_TOKEN`(省略可能): ソースのpersonal access token (classic)インスタンスで認証するために使用されるGitHub（`repo`スコープが必要）。 指定しないと、代わりに `GITHUB_ACCESS_TOKEN` の値が使われます。\n* `CIRCLE_CI_SOURCE_GITHUB_INSTANCE_URL` (省略可能): ソース GitHub インスタンスへの URL。 指定しないと、代わりに `GITHUB_INSTANCE_URL` の値が使われます。\n\nこれらの環境変数は、実行時に`.env.local`によって読み込まれるGitHub Actions Importer ファイルで指定できます。\n\n### 省略可能な引数。\n\nGitHub Actions Importer サブコマンドと一緒に使って、移行をカスタマイズできる省略可能な引数があります。\n\n#### `--source-file-path`\n\n```\n          `--source-file-path` 引数は、`forecast`、`dry-run`、または `migrate` サブコマンドと一緒に使うことができます。\n```\n\n既定では、 GitHub Actions Importer はソース管理からパイプラインの内容をフェッチします。\n`--source-file-path`引数は、指定したソース ファイル パスを代わりに使用するようにGitHub Actions Importerに指示します。\n\n次に例を示します。\n\n```shell\ngh actions-importer dry-run circle-ci --output-dir ./output/ --source-file-path ./path/to/.circleci/config.yml\n```\n\n```\n          `forecast` サブコマンドの実行時に複数のソース ファイルを指定する場合は、ファイル パス値でパターン マッチングを使うことができます。 たとえば、`gh forecast --source-file-path ./tmp/previous_forecast/jobs/*.json`は、GitHub Actions Importer ファイル パスに一致するソース ファイルと`./tmp/previous_forecast/jobs/*.json`を提供します。\n```\n\n#### `--config-file-path`\n\n```\n          `--config-file-path` 引数は、`audit`、`dry-run`、および `migrate` サブコマンドと一緒に使うことができます。\n```\n\n既定では、 GitHub Actions Importer はソース管理からパイプラインの内容をフェッチします。\n`--config-file-path`引数は、指定したソース ファイルを代わりに使用するようにGitHub Actions Importerに指示します。\n\n```\n          `--config-file-path` 引数を使って、変換された複合アクションを移行するリポジトリを指定することもできます。\n```\n\n##### 監査の例\n\nこの例では、 GitHub Actions Importer は、指定した YAML 構成ファイルを使用して監査を実行します。\n\n```bash\ngh actions-importer audit circle-ci --output-dir ./output/ --config-file-path ./path/to/circle-ci/config.yml\n```\n\n構成ファイルを使って CircleCI インスタンスを監査するには、構成ファイルが次の形式である必要があり、`repository_slug` がそれぞれ一意である必要があります。\n\n```yaml\nsource_files:\n  - repository_slug: circle-org-name/circle-project-name\n    path: path/to/.circleci/config.yml\n  - repository_slug: circle-org-name/some-other-circle-project-name\n    path: path/to/.circleci/config.yml\n```\n\n##### ドライ ランの例\n\nこの例では、 GitHub Actions Importer は、指定した YAML 構成ファイルをソース ファイルとして使用してドライ ランを実行します。\n\n構成ファイルの `repository_slug` を `--circle-ci-organization` および `--circle-ci-project` オプションの値に一致させてパイプラインを選びます。 次に `path` を使って、指定したソース ファイルをプルします。\n\n```bash\ngh actions-importer dry-run circle-ci --circle-ci-project circle-org-name/circle-project-name --output-dir ./output/ --config-file-path ./path/to/circle-ci/config.yml\n```\n\n##### 変換された複合アクションのリポジトリを指定する\n\n```\n          GitHub Actions Importer では、 `--config-file-path` 引数に指定された YAML ファイルを使用して、変換された複合アクションが移行されるリポジトリが決定されます。\n```\n\nまず、`--config-file-path` 引数を指定せずに監査を実行する必要があります。\n\n```bash\ngh actions-importer audit circle-ci --output-dir ./output/\n```\n\nこのコマンドの出力には、`config.yml`によって変換されたすべての複合アクションの一覧を含む GitHub Actions Importer という名前のファイルが含まれます。 たとえば、`config.yml` ファイルの内容は次のようになります。\n\n```yaml\ncomposite_actions:\n  - name: my-composite-action.yml\n    target_url: https://github.com/octo-org/octo-repo\n    ref: main\n```\n\nこのファイルを使って、再利用可能なワークフローまたは複合アクションを追加するリポジトリと参照先を指定できます。 その後、`--config-file-path`引数を使用してファイル`config.yml`をGitHub Actions Importer に提供できます。 たとえば、`migrate` コマンドを実行するときにこのファイルを使って、構成ファイルで定義されている一意のリポジトリごとに pull request を開くことができます。\n\n```bash\ngh actions-importer migrate circle-ci --circle-ci-project my-project-name --output-dir output/ --config-file-path config.yml --target-url https://github.com/my-org/my-repo\n```\n\n#### `--include-from`\n\n```\n          `--include-from` 引数は、`audit` サブコマンドと一緒に使うことができます。\n\n          `--include-from` 引数には、CircleCI Organization の監査に含めるリポジトリの行区切りリストを含むファイルを指定します。 このファイルに含まれていないリポジトリはすべて、監査から除外されます。\n```\n\n次に例を示します。\n\n```bash\ngh actions-importer audit circle-ci --output-dir ./output/ --include-from repositories.txt\n```\n\nこのパラメーターに指定するファイルは、リポジトリの行区切りリストである必要があります。次に例を示します:\n\n```text\nrepository_one\nrepository_two\nrepository_three\n```\n\n### CircleCI パイプラインでサポートされている構文\n\n次の表に、現在変換できる GitHub Actions Importer プロパティの種類を示します。\n\n| CircleCI パイプライン | GitHub Actions                                                                        | ステータス       |\n| :-------------- | :------------------------------------------------------------------------------------ | :---------- |\n| cronトリガー        | <ul><li>`on.schedule`</li></ul>                                                       | サポートされています  |\n| 環境              | <ul><li>`env`</li><li>`jobs.<job_id>.env`</li><li>`jobs.<job_id>.steps.env`</li></ul> | サポートされています  |\n| 実行者             | <ul><li>`runs-on`</li></ul>                                                           | サポートされています  |\n| 仕事              | <ul><li>`jobs`</li></ul>                                                              | サポートされています  |\n| ジョブ             | <ul><li>`jobs.<job_id>`</li><li>`jobs.<job_id>.name`</li></ul>                        | サポートされています  |\n| マトリックス          | <ul><li>`jobs.<job_id>.strategy`</li><li>`jobs.<job_id>.strategy.matrix`</li></ul>    | サポートされています  |\n| パラメータ           | <ul><li>`env`</li><li>`workflow-dispatch.inputs`</li></ul>                            | サポートされています  |\n| 手順              | <ul><li>`jobs.<job_id>.steps`</li></ul>                                               | サポートされています  |\n| 該当する場合、除外       | <ul><li>`jobs.<job_id>.if`</li></ul>                                                  | サポートされています  |\n| トリガー            | <ul><li>`on`</li></ul>                                                                | サポートされています  |\n| 実行者             | <ul><li>`container`</li><li>`services`</li></ul>                                      | 部分的にサポートされる |\n| orb             | <ul><li>`actions`</li></ul>                                                           | 部分的にサポートされる |\n| 実行者             | <ul><li>`self hosted runners`</li></ul>                                               | サポートされていない  |\n| セットアップ          | 適用なし                                                                                  | サポートされていない  |\n| バージョン           | 適用なし                                                                                  | サポートされていない  |\n\nサポートされている CircleCI の概念と orb マッピングについて詳しくは、[`github/gh-actions-importer` リポジトリ](https://github.com/github/gh-actions-importer/blob/main/docs/circle_ci/index.md)を参照してください。\n\n### 環境変数のマッピング\n\n```\n          GitHub Actions Importer では、次の表のマッピングを使用して、既定の CircleCI 環境変数を、 GitHub Actionsで最も近い同等の環境変数に変換します。\n```\n\n| CircleCI                           | GitHub Actions                              |\n| :--------------------------------- | :------------------------------------------ |\n| `CI`                               | `$CI`                                       |\n| `CIRCLE_BRANCH`                    | `${{ github.ref }}`                         |\n| `CIRCLE_JOB`                       | `${{ github.job }}`                         |\n| `CIRCLE_PR_NUMBER`                 | `${{ github.event.number }}`                |\n| `CIRCLE_PR_REPONAME`               | `${{ github.repository }}`                  |\n| `CIRCLE_PROJECT_REPONAME`          | `${{ github.repository }}`                  |\n| `CIRCLE_SHA1`                      | `${{ github.sha }}`                         |\n| `CIRCLE_TAG`                       | `${{ github.ref }}`                         |\n| `CIRCLE_USERNAME`                  | `${{ github.actor }}`                       |\n| `CIRCLE_WORKFLOW_ID`               | `${{ github.run_number }}`                  |\n| `CIRCLE_WORKING_DIRECTORY`         | `${{ github.workspace }}`                   |\n| `<< pipeline.id >>`                | `${{ github.workflow }}`                    |\n| `<< pipeline.number >>`            | `${{ github.run_number }}`                  |\n| `<< pipeline.project.git_url >>`   | `$GITHUB_SERVER_URL/$GITHUB_REPOSITORY`     |\n| `<< pipeline.project.type >>`      | `github`                                    |\n| `<< pipeline.git.tag >>`           | `${{ github.ref }}`                         |\n| `<< pipeline.git.branch >>`        | `${{ github.ref }}`                         |\n| `<< pipeline.git.revision >>`      | `${{ github.event.pull_request.head.sha }}` |\n| `<< pipeline.git.base_revision >>` | `${{ github.event.pull_request.base.sha }}` |\n\n## 法務上の通知\n\nMIT ライセンスのもとで <https://github.com/github/gh-actions-importer/> から一部を引用しています。\n\n```text\nMIT License\n\nCopyright (c) 2022 GitHub\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n```"}