正式なドキュメントは英語版であり、この日本語訳はAI支援翻訳により作成された参考用のものです。日本語訳の一部の内容は人間によるレビューがまだ行われていないため、翻訳のタイミングにより英語版との間に差異が生じることがあります。最新かつ正確な情報については、英語版をご参照ください。

GitLab CI/CDフローに変換する

  • プラン: Premium、Ultimate
  • アドオン: GitLab Duo Core、Pro、またはEnterprise。
  • 提供形態: GitLab.com、GitLab Self-Managed
  • ステータス: ベータ

この機能の利用可否は、機能フラグによって制御されます。詳細については、履歴を参照してください。

GitLab CI/CDフローへの変換は、JenkinsのパイプラインをGitLab CI/CDに移行するのに役立ちます。このフローの内容:

  • 既存のJenkinsのパイプライン設定を分析します。
  • Jenkinsのパイプライン構文をGitLab CI/CDのYAMLに変換します。
  • GitLab CI/CD実装のためのベストプラクティスを提案します。
  • 変換されたパイプライン設定でマージリクエストを作成します。
  • JenkinsのプラグインをGitLabの機能に移行するためのガイダンスを提供します。

このフローは、GitLab UIでのみ使用できます。

前提要件

Jenkinsfileを変換するには、以下が必要です:

フローを使用する

JenkinsfileをGitLab CI/CDに変換するには:

  1. 左側のサイドバーで、検索または移動先を選択して、プロジェクトを見つけます。新しいナビゲーションをオンにしている場合、このフィールドは上部のバーにあります。
  2. Jenkinsfileを開きます。
  3. ファイルの上にあるGitLab CI/CDに変換を選択します。
  4. 自動化 > セッションを選択して、進捗状況を監視します。
  5. パイプラインが正常に実行されたら、左側のサイドバーでコード > マージリクエストを選択します。タイトルDuo Workflow: Convert to GitLab CIのマージリクエストが表示されます。
  6. マージリクエストをレビューし、必要に応じて変更を加えます。

変換プロセス

このプロセスで変換されるもの:

  • パイプラインステージとステップ。
  • 環境変数。
  • ビルドトリガーとパラメータ。
  • アーティファクトと依存関係。
  • 並列実行。
  • 条件ロジック。
  • ビルド後アクション。

Jenkinsfile入力:

pipeline {
    agent any
    stages {
        stage('Build') {
            steps {
                sh 'npm install'
                sh 'npm build'
            }
        }
        stage('Test') {
            steps {
                sh 'npm test'
            }
        }
        stage('Deploy') {
            when { branch 'main' }
            steps {
                sh './deploy.sh'
            }
        }
    }
}

GitLab出力:

stages:
  - build
  - test
  - deploy

build:
  stage: build
  script:
    - npm install
    - npm build
  artifacts:
    paths:
      - node_modules/
      - dist/

test:
  stage: test
  script:
    - npm test

deploy:
  stage: deploy
  script:
    - ./deploy.sh
  only:
    - main