출시 정책

Bazel은 장기적 지원 (LTS) 출시 모델을 유지합니다. 이 모델에서는 주 버전은 9개월마다 출시되고 부 버전은 매월 출시됩니다. 이 페이지에서는 출시 후보, 일정, 공지, 테스트를 포함하여 Bazel 출시 정책을 다룹니다.

Bazel 출시 버전은 GitHub에서 확인할 수 있습니다.

출시 후보

새 버전의 Bazel 출시 후보는 일반적으로 매월 초에 만들어집니다. 이 저작물은 목표 출시일을 나타내는 GitHub의 출시 버그로 추적되며 현재 출시 관리자에게 할당됩니다. 출시 후보는 모든 Bazel 단위 테스트를 통과하고 Buildkite에서 테스트된 프로젝트에서 원치 않는 회귀가 나타나지 않아야 합니다.

출시 후보는 bazel-discuss에 발표됩니다. 다음 며칠 동안 Bazel팀은 후보의 회귀가 있는지 커뮤니티 버그 신고를 모니터링합니다.

출시

회귀가 발견되지 않으면 1주일 후에 후보가 공식 발표됩니다. 그러나 회귀로 인해 출시 후보의 출시가 지연될 수 있습니다. 회귀가 발견되면 Bazel팀은 출시 후보에 상응하는 선별을 적용하여 이러한 회귀를 수정합니다. 첫 번째 출시 후보로부터 1주일 이후부터 연속 2일 동안 더 이상 회귀가 발견되지 않으면 후보가 해제됩니다.

새로운 기능은 검토 과정을 거친 후에 출시 후보로 선별되지 않습니다. 또한 새로운 기능에 버그가 있으면 출시 후보에서 기능이 롤백될 수도 있습니다. 출시 빌드에 큰 영향을 미치거나 이를 중단할 가능성이 있는 버그만 출시 후보에서 수정됩니다.

출시는 다음날이 영업일인 날짜에만 출시됩니다.

최신 버전에서 중대한 문제가 발견되면 Bazel팀은 수정사항을 출시 버전에 적용하여 패치 출시 버전을 만듭니다. 이 패치는 새 버전을 만드는 대신 기존 버전을 업데이트하므로 패치 출시 후보는 영업일 기준 2일 후에 출시될 수 있습니다.

테스트

ci.bazel.build에서 실행되는 모든 프로젝트의 나이틀리 빌드가 헤드에서 빌드된 Bazel 바이너리를 사용하여 실행되고 바이너리를 출시합니다. 브레이킹 체인지의 영향을 받을 프로젝트에 알림이 전송됩니다

출시 후보가 발급되면 TensorFlow와 같은 다른 Google 프로젝트는 출시 후보 바이너리를 사용하여 전체 테스트 모음에서 테스트됩니다. Bazel을 사용하는 중요 프로젝트가 있는 경우 현재 출시 후보를 추적하고 회귀를 보고하는 자동화된 테스트 프로세스를 설정하는 것이 좋습니다.