Bu sayfa, Bazel kural depolarının sahipleri ve koruyucuları içindir. Bu sayfada, kurallarınızı uzaktan yürütme senaryosuyla uyumluluk için test etmek amacıyla deponuz için Bazel Sürekli Entegrasyon (CI) sistemini nasıl yapılandıracağınız açıklanmaktadır. Bu sayfadaki talimatlar, GitHub depolarında depolanan projeler için geçerlidir.
Ön koşullar
Bu sayfadaki adımları tamamlamadan önce şunlardan emin olun:
- GitHub deponuz Bazel GitHub kuruluşunun bir parçasıdır.
- Buildkite'yi, Bazel Sürekli Entegrasyon bölümünde açıklandığı şekilde deponuz için yapılandırdınız.
Bazel CI'yi test için ayarlama
.bazelci/presubmit.yml
dosyanızda aşağıdakileri yapın:a.
rbe_ubuntu1604
adlı bir yapılandırma ekleyin.b.
rbe_ubuntu1604
yapılandırmasında, uzaktan yürütmeye karşı test etmek istediğiniz derleme ve test hedeflerini ekleyin.bazel-toolchains
GitHub deposunuWORKSPACE
dosyanıza en son sürüme sabitlenmiş şekilde ekleyin. Ayrıcabuildkite_config
adında birrbe_autoconfig
hedefi ekleyin. Bu örnekte,rbe_ubuntu1604
için BuildKite CI ile uzaktan yürütme için araç zinciri yapılandırması oluşturulur.
load("@bazel_toolchains//rules:rbe_repo.bzl", "rbe_autoconfig")
rbe_autoconfig(name = "buildkite_config")
presubmit.yml
dosyasında yaptığınız değişiklikleri içeren bir çekme isteği gönderin. (Örnek çekme isteğine bakın.)Derleme sonuçlarını görüntülemek için aşağıdaki şekilde gösterildiği gibi, GitHub'da RBE (Ubuntu 16.04) pull isteği kontrolü için Ayrıntılar'ı tıklayın. Bu bağlantı, çekme isteği birleştirildikten ve CI testleri çalıştırıldıktan sonra kullanılabilir hale gelir. (Örnek sonuçlara bakın.)
(İsteğe bağlı) bazel test (RBE (Ubuntu 16.04)) kontrolünü, dal koruma kuralınızda birleştirme işleminden önce geçmesi gereken bir test olarak ayarlayın. Bu ayar, GitHub'da aşağıdaki şekilde gösterildiği gibi Ayarlar > Dallar > Dal koruma kuralları altında bulunur.
Başarısız derleme ve testlerle ilgili sorunları giderme
Derleme veya testleriniz başarısız olursa bunun nedeni aşağıdakilerden biri olabilir:
Zorunlu derleme veya test araçları varsayılan kapsayıcıya yüklenmemiş. Birçok Bazel derlemesinde ortak olarak kullanılan araçları içeren
rbe-ubuntu16-04
container'ında varsayılan olarak çalıştırılanrbe_ubuntu1604
yapılandırmasını kullanarak derlemeler. Ancak kurallarınızda varsayılan kapsayıcıda bulunmayan araçlar gerekiyorsarbe-ubuntu16-04
kapsayıcısını temel alan özel bir kapsayıcı oluşturmanız ve daha sonra açıklandığı gibi bu araçları eklemeniz gerekir.Derleme veya test hedefleri, uzaktan yürütmeyle uyumlu olmayan kurallar kullanıyor. Uzaktan yürütmeyle uyumlulukla ilgili ayrıntılar için Uzaktan Yürütme İçin Bazel Kurallarını Uyarlama bölümüne bakın.
rbe_ubuntu1604 CI yapılandırmasında özel bir container kullanma
rbe-ubuntu16-04
kapsayıcısı aşağıdaki URL'de herkese açıktır:
http://gcr.io/cloud-marketplace/google/rbe-ubuntu16-04
Doğrudan Container Registry'den alabilir veya kaynaktan derleyebilirsiniz. Sonraki bölümlerde her iki seçenek de açıklanmaktadır.
Başlamadan önce gcloud
, docker
ve git
uygulamalarını yüklediğinizden emin olun.
Kapsülü kaynaktan derliyorsanız Bazel'in en son sürümünü de yüklemeniz gerekir.
rbe-ubuntu16-04'ü Container Registry'den alma
rbe-ubuntu16-04
kapsayıcısını Container Registry'den almak için aşağıdaki komutu çalıştırın:
gcloud docker -- pull gcr.io/cloud-marketplace/google/rbe-ubuntu16-04@sha256:sha256-checksum
sha256-checksum değerini en son kapsayıcı için SHA256 sağlama değeriyle değiştirin.
rbe-ubuntu16-04 container'ını kaynaktan derleme
rbe-ubuntu16-04
kapsayıcısını kaynaktan derlemek için aşağıdakileri yapın:
bazel-toolchains
deposunu klonlayın:git clone https://github.com/bazelbuild/bazel-toolchains
Aracı Zinciri Kapsayıcıları bölümünde açıklandığı gibi araç zinciri kapsayıcı hedeflerini ayarlayın ve kapsayıcıyı derleyin.
Yeni oluşturulan kapsayıcıyı çekin:
gcloud docker -- pull gcr.io/project-id/custom-container-namesha256-checksum
Özel kapsayıcıyı çalıştırma
Özel kapsayıcıyı çalıştırmak için aşağıdakilerden birini yapın:
Container'ı Container Registry'den çektiyseniz aşağıdaki komutu çalıştırın:
docker run -it gcr.io/cloud-marketplace/google/rbe-ubuntu16-04@sha256:sha256-checksum/bin/bash
sha256-checksum
değerini, en son container için SHA256 sağlama toplamı değeriyle değiştirin.Kapsayıcıyı kaynaktan oluşturduysanız aşağıdaki komutu çalıştırın:
docker run -it gcr.io/project-id/custom-container-name@sha256:sha256sum /bin/bash
Özel kapsayıcıya kaynak ekleme
rbe-ubuntu16-04
kapsayıcısına kaynak veya orijinal kaynakların alternatif sürümlerini eklemek için Dockerfile
veya rules_docker
kullanın.
Docker'ı kullanmaya yeni başladıysanız aşağıdaki bilgileri okuyun:
Örneğin, aşağıdaki Dockerfile
snippet'i my_tool_package
'ı yükler:
FROM gcr.io/cloud-marketplace/google/rbe-ubuntu16-04@sha256:sha256-checksum
RUN apt-get update && yes | apt-get install -y my_tool_package
Özel container'ı Container Registry'ye gönderme
Container'ı özelleştirdikten sonra container görüntüsünü oluşturun ve aşağıdaki gibi Container Registry'ye aktarın:
Container görüntüsünü oluşturun:
docker build -t custom-container-name.
docker tag custom-container-name gcr.io/project-id/custom-container-name
Container görüntüsünü Container Registry'ye aktarın:
gcloud docker -- push gcr.io/project-id/custom-container-name
Kapsayıcının yayınlandığını doğrulamak için aşağıdaki URL'ye gidin:
https://console.cloud.google.com/gcr/images/project-id/GLOBAL/custom-container-name
Özel kapsayıcınızın SHA256 sağlama değerini not edin. Daha sonra bu değeri derleme platformu tanımınıza eklemeniz gerekir.
Resimleri herkese açık olarak yayınlama bölümünde açıklandığı şekilde kapsayıcıyı herkese açık olarak erişilebilir şekilde yapılandırın.
Daha fazla bilgi için Görüntü Aktarma ve Çekme bölümüne bakın.
Derleme platformu tanımını belirtme
Özel araç zinciri yapılandırmanıza bir Bazel platform yapılandırması eklemeniz gerekir. Bu, Bazel'in istenen donanım/yazılım platformuna uygun bir araç zinciri seçmesine olanak tanır. Geçerli bir platformu otomatik olarak oluşturmak için WORKSPACE
'ünüze rbe_autoconfig
adlı bir buildkite_config
hedefi ekleyebilirsiniz. Bu hedef, özel kapsayıcınızı seçmek için ek özellikler içerir. Bu kurulumla ilgili ayrıntılar için rbe_autoconfig
ile ilgili güncel dokümanları okuyun.