InfoGrab DocsInfoGrab Docs

CI/CD 구성에 기여하기

요약

CI/CD configuration: 프로젝트의 CI/CD 구성을 정의하는 YAML 파일. keyword: CI/CD 구성의 각 키워드. entry: CI/CD 구성에서 키워드를 나타내는 Entry 클래스. CI/CD 구성의 모든 키워드가 Entry 클래스로 표현되는 것은 아닙니다.

용어 설명#

  • CI/CD configuration: 프로젝트의 CI/CD 구성을 정의하는 YAML 파일.

  • keyword: CI/CD 구성의 각 키워드.

  • entry: CI/CD 구성에서 키워드를 나타내는 Entry 클래스.

CI/CD 구성의 모든 키워드가 Entry 클래스로 표현되는 것은 아닙니다. 복잡한 구조나 재사용 가능한 부분이 있는 키워드에 대해서만 Entry 클래스를 생성합니다.

예를 들어:

  • image 키워드는 Entry::Image 클래스로 표현됩니다.

  • image 키워드의 name 서브키워드는 Entry 클래스로 표현되지 않습니다.

  • image 키워드의 pull_policy 서브키워드는 Entry::PullPolicy 클래스로 표현됩니다.

새 키워드 추가하기#

실험적 CI 키워드는 피처 플래그 뒤에 보호되어야 합니다. 사용자가 CI 구성에 키워드를 추가하는 것은 명시적 동의(opt-in)로 간주되지 않습니다. 해당 키워드가 실험적임을 알지 못한 채 추가할 수 있기 때문입니다. 실험적 CI 키워드는 사용자에게 자동 완성 제안이 되지 않도록 JSON 스키마에 추가해서는 안 됩니다.

CI 설정 키워드는 lib/gitlab/ci/config/entry 디렉터리에 추가됩니다. EE 전용 변경 사항의 경우, ee/lib/gitlab/ci/config/entry 또는 ee/lib/ee/gitlab/ci/config/entry 디렉터리를 사용합니다.

JSON 스키마도 그에 맞게 업데이트하세요.

상속#

entry는 다음 중 하나를 상속하는 클래스로 표현됩니다:

  • Entry::Node: 단순한 키워드의 경우. (예: Entry::Stage)

  • Entry::Simplifiable: 여러 구조를 가지는 키워드의 경우. 예를 들어, Entry::Retry는 단순한 숫자 또는 해시 구성이 될 수 있습니다.

  • Entry::ComposableArray: 단일 타입 서브 요소 목록을 가지는 키워드의 경우. 예를 들어, Entry::IncludesEntry::Include 요소의 목록을 가집니다.

  • Entry::ComposableHash: 사용자 정의 키를 가진 단일 타입 서브 요소를 가지는 키워드의 경우. 예를 들어, Entry::Variables는 사용자 정의 키를 가진 Entry::Variable 요소의 목록을 가집니다.

헬퍼 클래스#

entry에서 사용할 수 있는 헬퍼 클래스는 다음과 같습니다:

  • Entry::Validatable: entry 클래스에서 validations 블록을 활성화하고 유효성 검사를 제공합니다.

  • Entry::Attributable: entry 클래스에서 attributes 메서드를 활성화합니다. 각 속성에 대해 xxx, has_xxx?, has_xxx_value? 메서드를 생성합니다.

  • Entry::Configurable: entry 클래스에서 entry 메서드를 활성화합니다. 각 entry에 대해 xxx_defined?, xxx_entry, xxx_value 메서드를 생성합니다.

value 메서드#

value 메서드는 entry 클래스의 주요 메서드입니다. entry의 실제 값을 반환합니다. 기본적으로 Entry::Node 클래스에서 value 메서드는 중첩된 entry가 없는 경우 entry의 해시 구성을 반환합니다. 단순한 entry에 유용할 수 있습니다. 예를 들어, Entry::Paths는 문자열 배열을 값으로 가지므로 문자열 배열을 직접 반환할 수 있습니다.

일부 키워드에서는 value 메서드를 재정의합니다. 이 메서드에서는 entry에서 반환할 내용과 방식을 정의합니다. Entry::AttributableEntry::Configurable의 사용이 여기서 중요한 역할을 할 수 있습니다. 예를 들어, Entry::Secret에는 다음과 같이 정의되어 있습니다:

attributes %i[vault file token].freeze

entry :vault, Entry::Vault::Secret
entry :file, ::Gitlab::Config::Entry::Boolean

def value
  {
    vault: vault_value,
    file: file_value,
    token: token
  }.compact
end
  • vault_value는 중첩된 vault entry의 값입니다.

  • file_value는 중첩된 file entry의 값입니다.

  • token은 기본 token 속성의 값입니다.

중요한 것은 중첩된 entry의 값을 가져올 때는 항상 xxx_value 메서드를 사용해야 한다는 점입니다.

피처 플래그 사용#

새 CI/CD 구성 키워드를 추가할 때는 변경 사항의 롤아웃을 제어하기 위해 피처 플래그를 사용하는 것이 중요합니다. 이를 통해 모든 사용자에게 영향을 주지 않고 프로덕션에서 변경 사항을 테스트할 수 있습니다. 자세한 내용은 피처 플래그 문서를 참고하세요.

피처 플래그를 확인하는 일반적인 위치는 Gitlab::Config::Entry::Node#value 메서드입니다. 예를 들어:

def value
  {
    vault: vault_value,
    file: file_available? ? file_value : nil,
    token: token
  }.compact
end

private

def file_available?
  ::Gitlab::Ci::Config::FeatureFlags.enabled?(:secret_file_available, type: :beta)
end

피처 플래그 액터#

entry 클래스에서는 현재 프로젝트나 사용자에 접근할 수 없습니다. 그러나 액터 없이 피처 플래그를 사용하는 것은 권장되지 않습니다. 이 문제를 해결하기 위해 세 가지 옵션이 있습니다:

  • Feature.enabled?(:feature_flag, Feature.current_request) 사용.

  • Config::FeatureFlags.enabled?(:feature_flag) 사용.

  • entry 클래스에서 피처 플래그를 사용하지 않고 코드의 다른 부분에서 사용.

테스트 및 검증#

entry를 추가하거나 수정할 때는 해당 스펙 파일도 추가하거나 업데이트해야 합니다. 또한, 완전히 통합된 테스트를 위해 spec/lib/gitlab/ci/yaml_processor_spec.rb 파일이나 spec/lib/gitlab/ci/yaml_processor/test_cases/* 디렉터리의 파일에 테스트를 추가하거나 수정하는 것도 중요합니다.

CI/CD 구성에 기여하기

GitLab v19.1
원문 보기
요약

CI/CD configuration: 프로젝트의 CI/CD 구성을 정의하는 YAML 파일. keyword: CI/CD 구성의 각 키워드. entry: CI/CD 구성에서 키워드를 나타내는 Entry 클래스. CI/CD 구성의 모든 키워드가 Entry 클래스로 표현되는 것은 아닙니다.

용어 설명#

  • CI/CD configuration: 프로젝트의 CI/CD 구성을 정의하는 YAML 파일.

  • keyword: CI/CD 구성의 각 키워드.

  • entry: CI/CD 구성에서 키워드를 나타내는 Entry 클래스.

CI/CD 구성의 모든 키워드가 Entry 클래스로 표현되는 것은 아닙니다. 복잡한 구조나 재사용 가능한 부분이 있는 키워드에 대해서만 Entry 클래스를 생성합니다.

예를 들어:

  • image 키워드는 Entry::Image 클래스로 표현됩니다.

  • image 키워드의 name 서브키워드는 Entry 클래스로 표현되지 않습니다.

  • image 키워드의 pull_policy 서브키워드는 Entry::PullPolicy 클래스로 표현됩니다.

새 키워드 추가하기#

실험적 CI 키워드는 피처 플래그 뒤에 보호되어야 합니다. 사용자가 CI 구성에 키워드를 추가하는 것은 명시적 동의(opt-in)로 간주되지 않습니다. 해당 키워드가 실험적임을 알지 못한 채 추가할 수 있기 때문입니다. 실험적 CI 키워드는 사용자에게 자동 완성 제안이 되지 않도록 JSON 스키마에 추가해서는 안 됩니다.

CI 설정 키워드는 lib/gitlab/ci/config/entry 디렉터리에 추가됩니다. EE 전용 변경 사항의 경우, ee/lib/gitlab/ci/config/entry 또는 ee/lib/ee/gitlab/ci/config/entry 디렉터리를 사용합니다.

JSON 스키마도 그에 맞게 업데이트하세요.

상속#

entry는 다음 중 하나를 상속하는 클래스로 표현됩니다:

  • Entry::Node: 단순한 키워드의 경우. (예: Entry::Stage)

  • Entry::Simplifiable: 여러 구조를 가지는 키워드의 경우. 예를 들어, Entry::Retry는 단순한 숫자 또는 해시 구성이 될 수 있습니다.

  • Entry::ComposableArray: 단일 타입 서브 요소 목록을 가지는 키워드의 경우. 예를 들어, Entry::IncludesEntry::Include 요소의 목록을 가집니다.

  • Entry::ComposableHash: 사용자 정의 키를 가진 단일 타입 서브 요소를 가지는 키워드의 경우. 예를 들어, Entry::Variables는 사용자 정의 키를 가진 Entry::Variable 요소의 목록을 가집니다.

헬퍼 클래스#

entry에서 사용할 수 있는 헬퍼 클래스는 다음과 같습니다:

  • Entry::Validatable: entry 클래스에서 validations 블록을 활성화하고 유효성 검사를 제공합니다.

  • Entry::Attributable: entry 클래스에서 attributes 메서드를 활성화합니다. 각 속성에 대해 xxx, has_xxx?, has_xxx_value? 메서드를 생성합니다.

  • Entry::Configurable: entry 클래스에서 entry 메서드를 활성화합니다. 각 entry에 대해 xxx_defined?, xxx_entry, xxx_value 메서드를 생성합니다.

value 메서드#

value 메서드는 entry 클래스의 주요 메서드입니다. entry의 실제 값을 반환합니다. 기본적으로 Entry::Node 클래스에서 value 메서드는 중첩된 entry가 없는 경우 entry의 해시 구성을 반환합니다. 단순한 entry에 유용할 수 있습니다. 예를 들어, Entry::Paths는 문자열 배열을 값으로 가지므로 문자열 배열을 직접 반환할 수 있습니다.

일부 키워드에서는 value 메서드를 재정의합니다. 이 메서드에서는 entry에서 반환할 내용과 방식을 정의합니다. Entry::AttributableEntry::Configurable의 사용이 여기서 중요한 역할을 할 수 있습니다. 예를 들어, Entry::Secret에는 다음과 같이 정의되어 있습니다:

attributes %i[vault file token].freeze

entry :vault, Entry::Vault::Secret
entry :file, ::Gitlab::Config::Entry::Boolean

def value
  {
    vault: vault_value,
    file: file_value,
    token: token
  }.compact
end
  • vault_value는 중첩된 vault entry의 값입니다.

  • file_value는 중첩된 file entry의 값입니다.

  • token은 기본 token 속성의 값입니다.

중요한 것은 중첩된 entry의 값을 가져올 때는 항상 xxx_value 메서드를 사용해야 한다는 점입니다.

피처 플래그 사용#

새 CI/CD 구성 키워드를 추가할 때는 변경 사항의 롤아웃을 제어하기 위해 피처 플래그를 사용하는 것이 중요합니다. 이를 통해 모든 사용자에게 영향을 주지 않고 프로덕션에서 변경 사항을 테스트할 수 있습니다. 자세한 내용은 피처 플래그 문서를 참고하세요.

피처 플래그를 확인하는 일반적인 위치는 Gitlab::Config::Entry::Node#value 메서드입니다. 예를 들어:

def value
  {
    vault: vault_value,
    file: file_available? ? file_value : nil,
    token: token
  }.compact
end

private

def file_available?
  ::Gitlab::Ci::Config::FeatureFlags.enabled?(:secret_file_available, type: :beta)
end

피처 플래그 액터#

entry 클래스에서는 현재 프로젝트나 사용자에 접근할 수 없습니다. 그러나 액터 없이 피처 플래그를 사용하는 것은 권장되지 않습니다. 이 문제를 해결하기 위해 세 가지 옵션이 있습니다:

  • Feature.enabled?(:feature_flag, Feature.current_request) 사용.

  • Config::FeatureFlags.enabled?(:feature_flag) 사용.

  • entry 클래스에서 피처 플래그를 사용하지 않고 코드의 다른 부분에서 사용.

테스트 및 검증#

entry를 추가하거나 수정할 때는 해당 스펙 파일도 추가하거나 업데이트해야 합니다. 또한, 완전히 통합된 테스트를 위해 spec/lib/gitlab/ci/yaml_processor_spec.rb 파일이나 spec/lib/gitlab/ci/yaml_processor/test_cases/* 디렉터리의 파일에 테스트를 추가하거나 수정하는 것도 중요합니다.