PowerShell
PowerShell ビルドステップは、PowerShell スクリプトを実行するために特別に設計されています。
PowerShell 統合を担当するプラグインは、GitHub (英語) でオープンソース化されています。
クロスプラットフォーム PowerShell
クロスプラットフォーム PowerShell (PowerShell コア (英語)) は、Windows、macOS、Linux でサポートされています。プラットフォーム用の PowerShell パッケージをダウンロード(英語)し、TeamCity エージェントにインストールします。
PowerShell Desktop と PowerShell Core の並行インストールは、Windows でサポートされています。
ビルドエージェントにインストールされている PowerShell の検出
起動時に、TeamCity エージェントは、Program Files および Windows ディレクトリ、または ARM64 システムの ~/powershell および /opt/microsoft/powershell/<version>/ などの標準の場所で PowerShell インストールを検索します。teamcity.powershell.detector.search.paths エージェントプロパティでカスタムの場所を指定できるため、エージェントはこのディレクトリ (およびその子) でも PowerShell を検出できます。
複数の場所をリストするには、パスを ; で区切ります。
PowerShell の設定
オプション | 説明 |
|---|---|
バージョン | TeamCity がサポートしている PowerShell バージョンのリスト。これは |
PowerShell ランモード | x64 マシンで希望の実行モードを選択します。 バージョン バージョンを指定してください(たとえば、1.0 または 2.0)。エージェントにインストールされているバージョンと比較され、適切な要件が追加されます。Core エディションの場合は、下限として使用されます。デスクトップ版では、正確なバージョンが使用されます( バージョンフィールドが空白のままの場合、バージョン要件の下限は追加されず、PowerShell のデスクトップエディションでは プラットフォーム プラットフォームのビット数を選択します。
版 使用する PowerShell エディションを選択します。
|
標準エラー出力を次のようにフォーマットします。 | ランナーによるエラー出力の処理方法を指定します。
|
作業ディレクトリ | ビルド作業ディレクトリへのパスを指定します。 |
スクリプト | スクリプトを TeamCity に直接入力するか、スクリプトへのパスを指定するかを選択します。
|
スクリプト実行モード | PowerShell スクリプトの実行モードを指定してください。デフォルトでは、PowerShell は任意の |
スクリプト引数 | スクリプト実行モードオプションが外部ファイルから .ps1 スクリプトを実行するに設定されている場合に使用できます。 PowerShell スクリプトに引数として渡されるビルドパラメーターを指定します。 |
追加のコマンドラインパラメーター | PowerShell 実行可能ファイルに渡されるパラメーターを指定します。 |
Docker の設定
このセクションでは、ビルドステップの実行に使用される Docker イメージを指定できます。
現在の制限
Docker で実行するには、PowerShell 実行可能ファイルを PATH に追加する必要があります。
Docker を使用してビルドステップを実行する場合、Docker 関連のビルドエージェント要件のみがビルドに適用されます。
PowerShell ビルドステップでのエディションの選択は、使用されている実行可能ファイルに影響します(デスクトップの場合は
powershell.exe、コアの場合はpwsh)。<Auto> のデフォルトは
pwsh(Core) です。カスタム PowerShell 実行可能ファイルを指定するには、
teamcity.powershell.virtual.executable構成パラメーターを、提供されたイメージ内のこの実行可能ファイルの絶対パスに設定する必要があります。Container Wrapper の現在の制限により、Windows システム上で Linux コンテナーを実行することはできません。
既知の問題
docker-composeコマンドが PowerShell デスクトップバージョン 5.1.17763 以降を介して実行された場合、ビルドログに誤検知の警告しかないにもかかわらず、PowerShell スクリプトがエラーで失敗する可能性があります。
この問題を回避するには、代わりに PowerShell Core を使用することをお勧めします。または、--log-level ERROR属性を追加して、docker-composeコマンドのログレベルを制限することもできます。
TeamCity との相互作用
PowerShell を使用してサービスメッセージを介して TeamCity と対話する場合は、注意が必要です。PowerShell は、コンソールに書き込まれた文字列を Write-Output、Write-Error などのコマンドでラップする傾向があります(TW-15080(英語) を参照)。この動作を回避するには、Write-Host コマンドを使用するか、バッファー長を手動で調整します。
エラー処理
ゼロの終了コードが常に呼び出し元に返される PowerShell の問題により、TeamCity はスクリプトが正しく実行されたかどうかを常に検出できるわけではありません。スクリプトの実行エラーの検出に役立ついくつかのアプローチをお勧めします。
手動で例外をキャッチして明示的に終了コードを返す
PowerShell プラグインはpowershell.exeの周囲の cmd ラッパーを使用しません。明示的な終了コードを返すことを可能にします。try { # your code here } Catch { $ErrorMessage = $_.Exception.Message Write-Output $ErrorMessage exit(1) }ビルド失敗条件の設定と追加 :
構文エラーや例外が存在する場合、PowerShell はそれらをstderrに書き込みます。TeamCity のビルドを失敗させるには、エラー出力オプションをErrorに設定し、エラー出力があるとビルドが失敗するビルド失敗条件を追加します。ビルドログ内の特定のメッセージでビルドに失敗した :
ビルドログ内の特定のメッセージ (「POWERSHELL ERROR」など) でビルドが失敗するビルド失敗条件を追加します。$ErrorMessage = "POWERSHELL ERROR" try { # your code here } Catch { Write-Output $ErrorMessage exit(1) }
出力処理
PowerShell からの非 ASCII 出力を正しく処理するには、PowerShell 側と TeamCity 側の両方で正しいエンコードを設定する必要があります。
PowerShell の出力エンコーディングを UTF-8 に設定するには、PowerShell スクリプトの先頭に次の行を追加します。
[Console]::OutputEncoding = [System.Text.Encoding]::UTF8TeamCity エージェント側でエンコーディングを設定するには、Java 起動オプション
-Dfile.encoding=UTF-8を設定するか、ビルド構成パラメーターteamcity.runner.commandline.stdstreams.encodingの値をUTF-8に設定します。
一時ファイル
TeamCity PowerShell プラグインは、エントリポイントとして一時ファイルを使用します。これらのファイルはビルド一時ディレクトリに作成され、PowerShell ビルドステップの終了後に削除されます。ファイルを保持するには、powershell.keep.generated または teamcity.dont.delete.temp.files 構成パラメーターを true に設定します。
開発リンク
PowerShell サポートはオープンソースのプラグインとして実装されています。開発リンクについてはプラグインのページ(英語)を参照してください。
関連ページ:
ビルドステップの設定
ビルドステップは、CI/CD ワークフローの最小単位です。ビルドステップは、全体として実行される一連のアクションを定義します。ビルドステップは、ビルド構成とパイプラインジョブに属します。構成とパイプラインのビルドステップ:TeamCity は、.NET、Maven、NAnt、Xcode などの特定のビルドツール用に設計された幅広いビルドステップを提供します。現在、ビルド構成ではすべてのステップが利用可能です。バージョン 2025.07 で導入された
事前定義されたビルドパラメーターのリスト
TeamCity には、ビルド構成の設定やビルドスクリプトですぐに使用できる定義済みのビルドパラメーターが数十個用意されています。これらのパラメーターはすべて(事前定義された構成パラメーターを除く)ビルドプロセスに渡されます。これらのパラメーターにアクセスするために必要な手法は、ビルド型によって異なる場合があることに注意してください(たとえば、Gradle ビルドで TeamCity システムプロパティにアクセスする方法については、ビルドプロパティセクションを参照してください)。事前定義されたサ...
ビルドパラメーターの設定
パラメーターは、TeamCity 設定およびビルドスクリプトの構文を介して参照するペアです。パラメーター部分は、生の値 () にすることも、別のパラメーターへの参照 () を含めることもできます。パラメーター型:TeamCity は次の 3 種類のパラメーターをサポートします。構成パラメーター — ビルド構成内で設定を共有することを主な目的とするパラメーター。これらのパラメーターを使用して、テンプレートから作成された構成やレシピを使用する構成をカスタマイズすることもできます。TeamCity は...
Kotlin DSL
TeamCity では、バージョン管理で設定を XML 形式で保存するだけでなく、DSL (Kotlin 言語に基づく) で設定を保存することもできます。バージョン管理に保存された DSL を使用すると、プログラムで設定を定義できます。Kotlin は静的に型指定されるため、IDE で自動補完機能を自動的に受け取ります。これにより、利用可能な API オプションの発見がはるかに簡単になります。TeamCity での Kotlin DSL の使用に関するブログ投稿シリーズと推奨リファクタリングの記...