병합 요청 파이프라인 문제 해결

병합 요청 파이프라인 작업 중 다음과 같은 문제가 발생할 수 있습니다.

브랜치에 푸시할 때 두 개의 파이프라인이 생성됨

병합 요청에서 중복된 파이프라인을 받으면, 파이프라인이 두 개의 브랜치와 병합 요청에 대해 동시에 실행되도록 설정되어 있을 수 있습니다. 중복된 파이프라인을 피하기 위해 파이프라인 구성을 조정하세요.

GitLab 13.7 및 이후에서는 브랜치 파이프라인에서 병합 요청 파이프라인으로 전환하기 위해 workflow:rules를 추가할 수 있습니다. 브랜치에서 병합 요청이 열리면 파이프라인이 병합 요청 파이프라인으로 전환됩니다.

잘못된 CI/CD 구성 파일을 푸시할 때 두 개의 파이프라인이 생성됨

병합 요청 브랜치에 잘못된 CI/CD 구성을 푸시하면, 파이프라인 탭에 두 개의 실패한 파이프라인이 나타납니다. 하나는 실패한 브랜치 파이프라인이고, 다른 하나는 실패한 병합 요청 파이프라인입니다.

구성 구문이 수정되면 더 이상 실패한 파이프라인이 나타나지 않아야 합니다. 이 구성 문제를 찾고 수정하기 위해 다음을 사용할 수 있습니다:

병합 요청의 파이프라인이 실패로 표시되지만 최신 파이프라인은 성공함

단일 병합 요청의 파이프라인 탭에 브랜치 파이프라인과 병합 요청 파이프라인이 모두 있는 것이 가능합니다. 이는 구성에 따라 또는 실수로 발생할 수 있습니다.

프로젝트가 파이프라인 성공 필수를 사용하고 두 종류의 파이프라인이 동시에 존재하는 경우, 병합 요청 파이프라인이 확인되며 브랜치 파이프라인은 확인되지 않습니다.

따라서 병합 요청 파이프라인이 실패하면 브랜치 파이프라인 결과에 상관없이 MR(Merge Request) 파이프라인 결과는 실패로 표시됩니다.

그러나 다음과 같은 경우에는 다릅니다:

  • 이러한 조건이 강제되지는 않습니다.
  • 레이스 조건이 파이프라인 결과를 차단하거나 MR(Merge Request)을 통과시키는 데 사용됩니다.

이 버그는 이슈 384927에서 추적됩니다.

이 병합 요청을 위한 새로운 파이프라인을 실행하는 동안 오류가 발생했습니다.

이 오류는 병합 요청에서 파이프라인 실행을 선택했지만 프로젝트에 더 이상 병합 요청 파이프라인이 활성화되어 있지 않을 때 발생할 수 있습니다.

이 오류 메시지의 가능한 원인:

  • 프로젝트에 병합 요청 파이프라인이 활성화되어 있지 않거나 파이프라인 탭에 파이프라인이 나열되어 있지 않으며 파이프라인 실행을 선택합니다.
  • 프로젝트가 이전에 병합 요청 파이프라인을 활성화했지만 구성이 제거되었습니다. 예를 들어:

    1. 병합 요청이 생성될 때 .gitlab-ci.yml 구성 파일에서 병합 요청 파이프라인을 활성화한 경우.
    2. 병합 요청의 파이프라인 탭에서 파이프라인 실행 옵션이 사용 가능하며, 이 시점에서 파이프라인 실행을 선택하면 오류가 발생하지 않습니다.
    3. 프로젝트의 .gitlab-ci.yml 파일이 변경되어 병합 요청 파이프라인 구성이 제거됩니다.
    4. 업데이트된 구성을 병합 요청으로 가져오기 위해 브랜치를 다시베이스합니다.
    5. 이제 파이프라인 구성은 더 이상 병합 요청 파이프라인을 지원하지 않지만 파이프라인 실행을 선택하여 병합 요청 파이프라인을 실행시킵니다.

파이프라인 실행이 사용 가능하지만 프로젝트에 병합 요청 파이프라인이 활성화되어 있지 않은 경우, 이 옵션을 사용하지 마십시오. 새로운 브랜치 파이프라인을 트리거하기 위해 커밋을 푸시하거나 브랜치를 리베이스할 수 있습니다.

병합이 차단됨: 파이프라인 성공 필요. 오류를 수정하는 새 커밋을 푸시하세요 메시지

이 메시지는 병합 요청 파이프라인, 병합된 결과 파이프라인, 또는 병합 트레인 파이프라인이 실패하거나 취소된 경우에 표시됩니다. 브랜치 파이프라인이 실패한 경우는 해당하지 않습니다.

병합 요청 파이프라인 또는 병합된 결과 파이프라인이 취소되거나 실패한 경우 다음을 수행할 수 있습니다:

  • 병합 요청의 파이프라인 탭에서 파이프라인 실행을 선택하여 전체 파이프라인을 다시 실행합니다.
  • 실패한 작업만 다시 시도. 전체 파이프라인을 다시 실행하면 이 작업은 필요하지 않습니다.
  • 실패를 수정하기 위해 새로운 커밋을 푸시합니다.

병합 트레인 파이프라인이 실패한 경우 다음을 수행할 수 있습니다:

  • 실패를 확인하고 빠른 작업(quick action)을 사용하여 즉시 병합 요청을 다시 기차에 추가할 수 있는지 확인합니다.
  • 병합 요청의 파이프라인 탭에서 파이프라인 실행을 선택하여 전체 파이프라인을 다시 실행한 다음 다시 기차에 병합 요청을 추가합니다.
  • 실패를 수정하기 위해 새로운 커밋을 푸시한 다음 다시 기차에 병합 요청을 추가합니다.

병합 트레인 파이프라인이 실패한 경우, 병합 요청이 병합되기 전에 취소된 경우, 실패한 상태가 없는 경우 다음을 수행할 수 있습니다:

  • 다시 기차에 추가합니다.