Questa guida descrive come preparare un XCTest per il test in Firebase Test Lab.
Passaggio 1: configura la posizione dei dati derivati del progetto
Xcode inserisce gli artefatti iOS compilati, inclusi i test che crei, in una directory Derived Data. Se vuoi, puoi mantenere la posizione predefinita per la directory, ma spesso è utile scegliere una posizione più facilmente accessibile per i file, soprattutto se prevedi di eseguire spesso test con Test Lab:
- Apri il progetto in Xcode.
- Nella barra dei menu di macOS, seleziona File > Impostazioni progetto…
- Modifica il menu a discesa Dati derivati da Posizione predefinita a Posizione personalizzata.
- Nel campo sotto il menu a discesa, seleziona una posizione in cui Xcode possa generare i test. (Questo è il tuo FOLDER_WITH_TEST_OUTPUT)
Passaggio 2: crea un file di test generico
Test Lab esegue test delle unità e della UI utilizzando il framework XCTest. Per eseguire gli XCTest della tua app sui dispositivi Test Lab, creala per i test su un dispositivo iOS generico:
- Dal menu a discesa del dispositivo nella parte superiore della finestra dell'area di lavoro Xcode, seleziona Generic iOS Device.
- Nella barra dei menu di macOS, seleziona Prodotto > Compila per > Test.
In alternativa, puoi creare il tuo XCTest dalla riga di comando. Utilizza questo comando in un terminale:
progetto
xcodebuild -project PATH/TO/YOUR_WORKSPACE/YOUR_PROJECT.xcodeproj \ -scheme YOUR_SCHEME \ -derivedDataPath FOLDER_WITH_TEST_OUTPUT \ -sdk iphoneos build-for-testing
workspace
xcodebuild -workspace PATH/TO/YOUR_WORKSPACE.xcworkspace \ -scheme YOUR_SCHEME \ -derivedDataPath FOLDER_WITH_TEST_OUTPUT \ -sdk iphoneos build-for-testing
Passaggio 3: firma il test e verifica
Assicurati che tutti gli artefatti nell'app e nel test siano firmati. Ad esempio, puoi farlo tramite Xcode specificando le impostazioni di firma come il profilo di provisioning e l'identità. Per ulteriori informazioni, consulta la sezione Firma del codice Apple.
Verifica la firma dell'app eseguendo
codesign --verify --deep --verbose /path/to/MyApp.app
dove "MyApp" è il nome dell'app all'interno della cartella decompressa. Varia in base al progetto. L'output previsto èMyApp.app: valid on disk
.Se esegui un test XCUITest, devi verificare il test e il runner eseguendo
codesign --verify --deep --verbose /path/to/MyTest-Runner.app
, dove "MyTest" è il nome del runner all'interno della cartella decompressa. Varia in base a ogni progetto. L'output previsto èMyTest-Runner.app: valid on disk
.
Passaggio 4: crea il pacchetto dell'app e verifica il caricamento
Una volta creato correttamente il test, comprimilo in formato zip per caricarlo su Test Lab:
cd FOLDER_WITH_TEST_OUTPUT/Build/Products : \ zip -r MyTests.zip Debug-iphoneos YOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
Puoi anche comprimere manualmente i file di test per creare un pacchetto di test:
Apri il Finder e vai a
FOLDER_WITH_TEST_OUTPUT
.Apri la cartella che ha il nome del progetto come prefisso, quindi vai alla cartella
Build/Products
al suo interno.Seleziona le cartelle
Debug-iphoneos
eYOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
e poi comprimile.
Passaggio 5: (facoltativo) esegui il test in locale
Prima di eseguire il test con Test Lab, puoi eseguirlo localmente con un dispositivo connesso tramite USB per verificare la qualità del suo comportamento:
xcodebuild test-without-building \ -xctestrun "Derived Data/Build/Products/YOUR_SCHEME.xctestrun" \ -destination id=your-phone-id
Passaggi successivi
Carica ed esegui il test nella consoleFirebase o in gcloud CLI.