私はジェンキンスパイプラインとともにGitHubの組織プラグインを使用して依存チェーンを編成しようとしている目標パスアーティファクトまたはString
。
ビルドしている製品には、多くの共有依存があります。依存バージョンの管理と更新を管理するために、nugetパッケージを使用しています。
しかし、私は、オーケストレーションを行っているプロジェクトに必要なアーティファクト/情報を得ることができません。
SCMの戦略
nugetパッケージを構築し、任意の下流の新しいリファレンス必要があることをビルドします画策すべき任意の上流の共有ライブラリを変更します。私は、各上流プロジェクトの下流オーケストレーションをハードコーディングしています
- を。 Aが構築されると、Aに依存するBとCはAからの最新の成果物で構築されます。その後、BとCに依存するDとAとCに依存するEが最新の成果物必要に応じてA、B、Cから等々。これらは、ビルドジョブ:ジョブ名の構文を使用して依存関係が構築されるため、AのJenkinsfileからすべてトリガーされます。依存関係が分岐して下流に集中するため、各ステップでオーケストレーションを下流に渡すことができたソリューションを見つけることができず、上流プロジェクトとは異なる参照で同じ下流プロジェクトの複数のビルドをトリガーしたくありません。
- 親プロジェクトのアーティファクト情報をダウンストリームジョブに渡すことはできますが、私が直面している問題は、親プロジェクトにはダウンストリームアーティファクトのアセンブリバージョン情報がありません(ジョブをさらに下流に編成する必要があります)。 Stash/Unstashにはクロスジョブ機能がないようで、アーカイブ/アーカイブ解除は廃止予定です。
TLDR: 私は(複数の下流ジョブから)ジョブ実行途中に上流の文字列またはテキストファイルを渡すのいずれかの方法を必要とするか、または私はと共有下流の依存関係を持つ複数のdowstreamジョブのための方法を必要としますダウンストリームジョブに情報を統合して渡します(1回だけトリガーします)。
ありがとうございます!
おかげで、これは、しかし、依然として次にオーケストレーションであり、アーティファクトプラグインを使用することによって達成結構です。最新のパイプラインプラグインには、必要なワークフローを処理する能力があると思いますが、実装する時間はまだありません。 – tphuoc