Bu kılavuzda, Firebase Test Lab'te test için XCTest'in nasıl hazırlanacağı açıklanmaktadır.
1. adım: Projenizin türetilmiş veri konumunu yapılandırın
Xcode, derlediğiniz testler de dahil olmak üzere derlenmiş iOS yapılarını bir Türetilmiş Veriler dizinine yerleştirir. İsterseniz bu dizinin varsayılan konumunu koruyabilirsiniz ancak özellikle Test Lab ile sık sık test çalıştıracaksanız dosyalar için daha kolay erişilebilir bir yer seçmek genellikle yararlıdır:
- Projenizi Xcode'da açın.
- macOS menü çubuğunda Dosya > Proje Ayarları...'nı seçin.
- türetilmiş veri açılır menüsünü varsayılan konum yerine özel konum olarak değiştirin.
- Açılır menünün altındaki alanda, Xcode'un testlerinizi yayınlayacağı bir konum seçin. (Bu sizin FOLDER_WITH_TEST_OUTPUT)
2. adım: Genel bir test dosyası oluşturun
Test Lab, XCTest çerçevesini kullanarak birim testleri ve kullanıcı arayüzü testleri çalıştırır. Uygulamanızın XCTests'ini Test Lab cihazlarda çalıştırmak için uygulamayı Genel iOS Cihaz'da test edilecek şekilde derleyin:
- Xcode çalışma alanı pencerenizin üst kısmındaki cihaz açılır listesinden Genel iOS Cihazı'nı seçin.
- macOS menü çubuğunda Ürün > Derleme > Test'i seçin.
Alternatif olarak, XCTest'inizi komut satırından derleyebilirsiniz. Terminalde aşağıdaki komutu kullanın:
proje
xcodebuild -project PATH/TO/YOUR_WORKSPACE/YOUR_PROJECT.xcodeproj \ -scheme YOUR_SCHEME \ -derivedDataPath FOLDER_WITH_TEST_OUTPUT \ -sdk iphoneos build-for-testing
çalışma alanı
xcodebuild -workspace PATH/TO/YOUR_WORKSPACE.xcworkspace \ -scheme YOUR_SCHEME \ -derivedDataPath FOLDER_WITH_TEST_OUTPUT \ -sdk iphoneos build-for-testing
3. Adım: Testinizi imzalayın ve doğrulayın
Uygulama ve testteki tüm yapıların imzalandığından emin olun. Örneğin, hazırlık profili ve kimlik gibi imzalama ayarlarını belirterek bunu Xcode üzerinden yapabilirsiniz. Daha fazla bilgi için Apple Kod İmzası başlıklı makaleyi inceleyin.
"Uygulamam", sıkıştırılmış klasördeki uygulamanın adı olmak üzere
codesign --verify --deep --verbose /path/to/MyApp.app
dosyasını çalıştırarak uygulama imzasını doğrulayın. Bu durum her proje için değişir. Beklenen çıkışMyApp.app: valid on disk
.XCUITest çalıştırıyorsanız
codesign --verify --deep --verbose /path/to/MyTest-Runner.app
komutunu çalıştırarak testi ve çalıştırıcıyı doğrulamanız gerekir. Burada "Testim", sıkıştırılmış klasördeki çalıştırıcının adıdır. Bu süre her proje için değişir. Beklenen çıkışMyTest-Runner.app: valid on disk
.
4. adım: Uygulamanızı paketleyin ve yüklemeyi test edin
Testiniz başarıyla oluşturulduktan sonra Test Lab adresine yüklemek için sıkıştırın:
cd FOLDER_WITH_TEST_OUTPUT/Build/Products : \ zip -r MyTests.zip Debug-iphoneos YOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
Test dosyalarını manuel olarak sıkıştırarak da testinizi paketleyebilirsiniz:
Finder'ı açıp
FOLDER_WITH_TEST_OUTPUT
'e gidin.Ön ek olarak proje adınızın bulunduğu klasörü açın, ardından içindeki
Build/Products
klasörüne gidin.Debug-iphoneos
veYOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
klasörlerini seçip sıkıştırın.
5. adım: (İsteğe bağlı) Testinizi yerel olarak çalıştırın
Testinizi Test Lab ile çalıştırmadan önce, davranışını kalite kontrol etmek için USB'ye bağlı bir cihazla yerel olarak çalıştırabilirsiniz:
xcodebuild test-without-building \ -xctestrun "Derived Data/Build/Products/YOUR_SCHEME.xctestrun" \ -destination id=your-phone-id
Sonraki adımlar
Testinizi Firebase konsolunda veya gcloud CLI'de yükleyip çalıştırın.