Google Cloud KSA ile test etme

Bu kılavuzda, gcloud CLI kullanılarak XCTest veya Game Loop testinin nasıl çalıştırılacağı açıklanmaktadır.

1. Adım: Yerel Google Cloud SDK ortamınızı yapılandırın

  1. Google Cloud SDK'yı indirin
  2. gcloud CLI aracı da bu kapsamdadır.

  3. Yüklemenizin güncel olduğundan ve gcloud firebase komutunu içerdiğinden emin olun:
          gcloud components update
  4. Google Hesabınızı kullanarak gcloud CLI'ye giriş yapın:
          gcloud auth login
  5. PROJECT_ID, Firebase projenizin kimliğidir:
         gcloud config set project PROJECT_ID

2. adım: Testinizi çalıştırın

XCTest çalıştırma

  1. Aşağıdaki komutu çalıştırarak testinizin .zip dosyasını yükleyin (Uygulamanızı henüz paketlemediyseniz XCTest'inizi paketleme bölümüne bakın):

    cd FOLDER_WITH_TEST_OUTPUT/Build/Products ; \
    zip -r MyTests.zip Debug-iphoneos YOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
  2. Test boyutlarınızı seçin.

    Test Lab, çeşitli iOS sürümlerinde, cihazlarda, ekran yönlerinde ve yerel ayarlarda test çalıştırmanıza olanak tanır. Bu yapılandırmalar, testin test boyutları olarak bilinir. Her boyutun seçeneklerini (ör. cihazın iOS sürümü için desteklenen Xcode sürümleri) görmek üzere aşağıdaki komutta dimension yerine models, versions veya locales yazın:

    gcloud firebase test ios dimension list

    Yalnızca portrait ve landscape seçenekleri olduğundan ekran yönü biraz daha basittir.

    Test boyutları listesine göz atın ve testinizi çalıştırmak istediğiniz birkaç kombinasyonu seçin. Günde çalıştırabileceğiniz maksimum kombinasyon sayısını görmek için Fiyatlandırma Planları'nı ziyaret edin.

  3. Bir test boyutları grubu seçtikten sonra Test Lab komutunu kullanarak testlerinizi firebase test ios run'ın çalıştırmasını sağlayabilirsiniz. Test etmek istediğiniz her test boyutu kombinasyonu için ayrı bir --device işareti ekleyin:

    gcloud firebase test ios run --test PATH/TO/MyTests.zip \
     --device model=MODEL_ID_1,version=VERSION_ID_1,locale=LOCALE_1,orientation=ORIENTATION_1 \
     --device model=MODEL_ID_2,version=VERSION_ID_2,locale=LOCALE_2,orientation=ORIENTATION_2 \
     etc...

    Testinizin, derlendiği Xcode sürümü ile Test Lab tarafından kullanılan varsayılan Xcode sürümü arasındaki uyumsuzluk nedeniyle başarısız olması mümkündür. Testiniz için desteklenen bir Xcode sürümü belirtmek üzere --xcode-version işaretini kullanın:

    gcloud firebase test ios run --test PATH/TO/MyTests.zip \
     --device model=MODEL_ID_1,version=VERSION_ID_1,locale=LOCALE_1,orientation=ORIENTATION_1 \
     --xcode-version=15

    Test matrislerinizi Firebase konsolunda tanımlamanıza ve bulmanıza yardımcı olması için isteğe bağlı olarak aşağıdaki örnekteki --client-details matrixLabel="<label>" işaretini kullanarak test matrisinizi etiketleyebilirsiniz:

    gcloud beta firebase test ios run --test PATH/TO/MyTests.zip \
      --device model=MODEL_ID_1,version=VERSION_ID_1,locale=LOCALE_1,orientation=ORIENTATION_1 \
      --client-details matrixLabel="my label"

Özel Hakların Test Edilmesi

Belirli bir uygulama kimliği gerektiren izinleri test etmek için --test-special-entitlements işaretini ayarlayarak bunu yapabilirsiniz. Test Lab özel ayrıcalıkları desteklemek için uygulamayı yeni bir paket tanımlayıcısı ile yeniden imzalar. Bu nedenle, zip dosyanızda uygulamanın paket tanımlayıcısına doğrudan referanslar içeren kaynaklar bulunmadığından emin olun.

Desteklenen hak talepleri:
  1. Push Bildirimleri apns-environment
  2. Kişisel VPN com.apple.developer.networking.vpn.api
Push Bildirimleri

Kullanıcılar, itme bildirimi isteklerine yetki vermek için C7FD9DJAA8 anahtar kimliği ve 9CKCGNNUQN ekip kimliği ile birlikte özel imza anahtarını kullanarak JSON web jetonları oluşturabilir. Oluşturulan jetonlar bir saat boyunca geçerlidir ve 60 dakikada bir yenilenmelidir. APNS'ye jeton tabanlı bağlantı oluşturma hakkında daha fazla bilgi edinin.

Uygulama grupları

Uygulama grubu kimlikleri evrensel olarak benzersizdir. Bu, kullanıcı uygulamalarını yeniden imzalarken yalnızca Test Lab geliştirici hesabıyla ilişkili uygulama grubu kimliğini kullanabileceğimiz anlamına gelir. Testiniz uygulama gruplarına dayanıyorsa testiniz başarısız olur.

Oyun Döngüsü testi çalıştırma

gcloud beta firebase test ios run komutunu çalıştırın ve çalıştırmayı yapılandırmak için aşağıdaki işaretçileri kullanın:

Oyun Döngüsü testleri için işaretler
--type

Zorunlu: Çalıştırmak istediğiniz iOS testi türünü belirtir. xctest (varsayılan) veya game-loop test türlerini girebilirsiniz.

--app

Zorunlu: Uygulamanızın IPA dosyasının mutlak yolu (GCS veya dosya sistemi). Bu işaret yalnızca Oyun Döngüsü testleri çalıştırıldığında geçerlidir.

--scenario-numbers

Uygulamanızda çalıştırmak istediğiniz döngüler (diğer adıyla senaryolar). Tek bir döngü, döngü listesi veya döngü aralığı girebilirsiniz. Varsayılan döngü 1'dir.

Örneğin, --scenario-numbers=1-3,5 1, 2, 3 ve 5. döngüleri çalıştırır.

--device-model

Testinizi çalıştırmak istediğiniz fiziksel cihaz (kullanılabileceğiniz cihazları öğrenin).

--timeout

Testinizin çalıştırılması için istediğiniz maksimum süre. Süreyi saniye cinsinden temsil etmek için bir tam sayı veya süreyi daha uzun bir zaman birimi olarak temsil etmek için bir tam sayı ve bir liste girebilirsiniz.

Örneğin:

  • --timeout=200, 200 saniyeye kadar çalıştırıldığında testinizin sonlandırılmasını zorunlu kılar.
  • --timeout=1h, testinizin bir saat çalıştıktan sonra sonlandırılmasını zorunlu kılar.

Örneğin, aşağıdaki komut iPhone 8 Plus'ta 1, 4, 6, 7 ve 8 döngülerini yürüten bir Oyun Döngüsü testi çalıştırır:

gcloud beta firebase test ios run
 --type game-loop --app path/to/my/App.ipa --scenario-numbers 1,4,6-8
 --device-model=iphone8plus

gcloud CLI hakkında daha fazla bilgi için referans dokümanlarını inceleyin.

3. Adım (İsteğe bağlı): Oluşturacağınız gelecekteki testleri otomatikleştirin

Test Lab ile gcloud komutlarını komut dosyasından çalıştırma

Aksi takdirde gcloud komut satırını kullanarak çalıştıracağınız mobil uygulama testi komutlarını otomatikleştirmek için kabuk komut dosyalarını veya toplu dosyalarını kullanabilirsiniz. Bu örnek bash komut dosyası, iki dakikalık zaman aşımı olan bir XCTest çalıştırır ve test çalıştırmasının başarıyla tamamlanıp tamamlanmadığını bildirir:

if gcloud firebase test ios run --test MyTest.zip --timeout 2m
then
    echo "Test matrix successfully finished"
else
    echo "Test matrix exited abnormally with non-zero exit code: " $?
fi

Komut dosyası çıkış kodları

Test Lab, komut dosyaları veya toplu dosyalar kullanarak çalıştırdığınız testlerin sonuçlarını daha iyi anlamak için kullanabileceğiniz çeşitli çıkış kodları sağlar.

Çıkış kodu Notlar
0 Tüm test işlemleri geçti.
1 Genel bir hata oluştu. Olası nedenler arasında mevcut olmayan bir dosya adı veya HTTP/ağ hatası yer alır.
2 Bilinmeyen komutlar veya bağımsız değişkenler sağlandığı için testten çıkıldı.
10 Bir test yürütme işleminde bir veya daha fazla test durumu (test edilen sınıflar veya sınıf yöntemleri) geçemedi.
15 Firebase Test Lab, beklenmedik bir hata nedeniyle test matrisinin başarılı olup olmadığını belirleyemedi.
19 Test matrisi kullanıcı tarafından iptal edildi.
20 Test altyapısı hatası oluştu.

4. adım: Test sonuçlarını inceleyin

Test başladığında Test Sonuçları sayfasının bağlantısını alırsınız. Seçtiğiniz farklı yapılandırmaların sayısına ve testleriniz için ayarlanan test zaman aşımı süresine bağlı olarak testlerin çalıştırılması birkaç dakika sürebilir. Testleriniz çalıştırıldıktan sonra test sonuçlarını inceleyebilirsiniz. Test sonuçlarınızı nasıl yorumlayacağınız hakkında daha fazla bilgi edinmek için Firebase Test Lab Sonuçlarını Analiz Etme başlıklı makaleyi inceleyin.

Sonraki adım

Genel kullanıma sunulan veya beta sürümündeki test seçeneklerini keşfetmek için Google Cloud SDK belgelerini okuyun.