UI-tests ui-testing
Het testen UI van de douane is een facultatieve eigenschap die u toelaat om tests UI voor uw toepassingen tot stand te brengen en automatisch in werking te stellen.
Overzicht custom-ui-testing
AEM verstrekt een geïntegreerde reeks van de kwaliteitsgates van Cloud Managerom vlotte updates aan douanetoepassingen te verzekeren. Met name ondersteunen IT-testpoorten al het maken en automatiseren van aangepaste tests met behulp van AEM API's.
De tests UI worden verpakt in een beeld van de Docker om een brede keus in taal en kaders (zoals Cypress, Selenium, Java en Maven, en JavaScript) toe te staan. Ook, kan een UI testproject gemakkelijk worden geproduceerd door het Archieftype van het Project van de AEM te gebruiken.
Adobe stimuleert het gebruik van Cypress, omdat deze in real time opnieuw laden en automatisch wachten biedt, wat tijd bespaart en de productiviteit tijdens het testen verbetert. Cypress biedt ook een eenvoudige en intuïtieve syntaxis, waardoor het gemakkelijk is om te leren en te gebruiken, zelfs voor mensen die nog niet aan tests hebben gewerkt.
De tests UI worden uitgevoerd als deel van een specifieke kwaliteitsgate voor elke pijpleiding van Cloud Manager met het Testen van de Douane UI van de a stapin productiepijpleidingenof naar keuze niet-productiepijpleidingen. Om het even welke tests van de UI met inbegrip van regressie en nieuwe functionaliteiten toelaten om fouten te ontdekken en te melden.
In tegenstelling tot douane functionele tests, die de tests zijn van HTTP in Java worden geschreven, kunnen de tests UI een beeld van de Docker met tests zijn die in om het even welke taal worden geschreven, zolang zij de overeenkomsten volgen die in de sectie worden bepaald de Tests van de Bouw UI.
Aan de slag met gebruikersinterfacetests get-started-ui-tests
In deze sectie worden de stappen beschreven die zijn vereist voor het instellen van UI-tests voor uitvoering in Cloud Manager.
-
Bepaal de programmeertaal die u wilt gebruiken.
-
Voor Cypress, gebruik de steekproefcode van de AEM bewaarplaats van de Steekproeven van de Test.
-
Gebruik voor JavaScript en WDIO de voorbeeldcode die automatisch wordt gegenereerd in de map
ui.tests
van de Cloud Manager-opslagplaats.note note NOTE Als uw bewaarplaats vóór Cloud Manager automatisch creeerde ui.tests
omslagen werd gecreeerd, kunt u de recentste versie ook produceren gebruikend AEM Archetype van het Project. -
Voor Java en WebDriver, gebruik de steekproefcode van de AEM bewaarplaats van de Steekproeven van de Test.
-
Voor andere programmeertalen, zie de sectie Tests van de Bouw UIin dit document aan opstelling het testproject.
-
-
Zorg ervoor dat het testen UI zoals per de sectie verkiesbare Klantin dit document wordt geactiveerd.
-
Ontwikkel uw testgevallen en stel de tests plaatselijkin werking.
-
Leg uw code vast in de Cloud Manager-opslagplaats en voer een Cloud Manager-pijplijn uit.
Interfacetests maken building-ui-tests
Een Maven project produceert een Docker bouwt context. In deze docker wordt de bouwcontext beschreven hoe u een Docker-afbeelding kunt maken die de UI-tests bevat en die door Cloud Manager wordt gebruikt om een Docker-afbeelding te genereren die de werkelijke UI-tests bevat.
In deze sectie worden de stappen beschreven die nodig zijn om een UI-testproject toe te voegen aan uw opslagplaats.
Context van een Docker-build genereren generate-docker-build-context
Om een Docker-buildcontext te genereren, hebt u een Maven-module nodig die:
- Produceert een archief dat een
Dockerfile
en elk ander bestand bevat dat nodig is om de Docker-afbeelding met uw tests te maken. - Hiermee wordt het archief gelabeld met de
ui-test-docker-context
classificatie.
De eenvoudigste manier om dit te doen, is door de Maven Assembly-insteekmodule te configureren om het Docker-contextarchief te maken en de juiste classificatie toe te wijzen.
U kunt tests UI met verschillende technologieën en kaders bouwen, maar deze sectie veronderstelt dat uw project op een manier gelijkend op het volgende wordt opgemaakt.
├── Dockerfile
├── assembly-ui-test-docker-context.xml
├── pom.xml
├── test-module
│ ├── package.json
│ ├── index.js
│ └── wdio.conf.js
└── wait-for-grid.sh
Het bestand pom.xml
verzorgt de Maven-build. Voeg een uitvoering aan de Geweven Insteekmodule van de Assemblage toe gelijkend op het volgende.
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<descriptors>
<descriptor>${project.basedir}/assembly-ui-test-docker-context.xml</descriptor>
</descriptors>
<tarLongFileMode>gnu</tarLongFileMode>
</configuration>
<executions>
<execution>
<id>make-assembly</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
Deze uitvoering instrueert de Geweven Insteekmodule van de Assemblage om een archief tot stand te brengen dat op de instructies in assembly-ui-test-docker-context.xml
wordt gebaseerd, genoemd een assemblagebeschrijver in het jargon van de insteekmodule. De assemblagebeschrijver maakt een lijst van alle dossiers die deel van het archief moeten uitmaken.
<assembly>
<id>ui-test-docker-context</id>
<includeBaseDirectory>false</includeBaseDirectory>
<formats>
<format>tar.gz</format>
</formats>
<fileSets>
<fileSet>
<directory>${basedir}</directory>
<includes>
<include>Dockerfile</include>
<include>wait-for-grid.sh</include>
</includes>
</fileSet>
<fileSet>
<directory>${basedir}/test-module</directory>
<excludes>
<exclude>node/**</exclude>
<exclude>node_modules/**</exclude>
<exclude>reports/**</exclude>
</excludes>
</fileSet>
</fileSets>
</assembly>
De assemblagedescriptor geeft de plug-in de instructie een archief van het type .tar.gz
te maken en wijst er de classificator ui-test-docker-context
aan toe. Bovendien worden de bestanden weergegeven die in het archief moeten worden opgenomen, waaronder:
- A
Dockerfile
, verplicht voor het samenstellen van de Docker-afbeelding - Het script
wait-for-grid.sh
, waarvan de doeleinden hieronder worden beschreven - De daadwerkelijke tests UI, die door een project Node.js in de
test-module
omslag worden uitgevoerd
De assemblagebeschrijver sluit ook sommige dossiers uit die terwijl het runnen van de tests UI plaatselijk zouden kunnen worden geproduceerd. Dit garandeert een kleiner archief en snellere builds.
Het archief met de Docker-build-context wordt automatisch opgepakt door Cloud Manager, dat het Docker-image met uw tests zal maken tijdens de implementatiepijplijnen. Uiteindelijk zal Cloud Manager het Docker-beeld in werking stellen om de tests UI tegen uw toepassing uit te voeren.
De build moet nul of één archief produceren. Als het nul archieven produceert, gaat de teststap door gebrek over. Als de build meer dan één archief produceert, is het geselecteerde archief niet-deterministisch.
Klanten kiezen customer-opt-in
Cloud Manager kan uw UI-tests alleen uitvoeren als u zich aanmeldt voor deze functie door een bestand aan uw opslagplaats toe te voegen.
- De bestandsnaam moet
testing.properties
zijn. - De bestandsinhoud moet
ui-tests.version=1
zijn. - Het bestand moet zich onder de toegewezen submodule bevinden voor UI-tests naast het
pom.xml
-bestand van de submodule UI-tests. - Het bestand moet de basis van het samengestelde
tar.gz
bestand zijn.
De UI-tests worden uitgevoerd en uitgevoerd als dit bestand niet aanwezig is.
Als u een testing.properties
-bestand wilt opnemen in het constructieartefact, voegt u een include
-instructie toe in het assembly-ui-test-docker-context.xml
-bestand.
[...]
<includes>
<include>Dockerfile</include>
<include>wait-for-grid.sh</include>
<include>testing.properties</include> <!-- opt-in test module in Cloud Manager -->
</includes>
[...]
Als u de voorbeelden gebruikt die door Adobe worden verstrekt:
-
Voor de op JavaScript-Gebaseerde
ui.tests
die omslag van wordt geproduceerd AEM Archetype van het Project, kunt u onder bevel uitvoeren om de vereiste configuratie toe te voegen.code language-shell echo "ui-tests.version=1" > testing.properties if ! grep -q "testing.properties" "assembly-ui-test-docker-context.xml"; then awk -v line=' <include>testing.properties</include>' '/<include>wait-for-grid.sh<\/include>/ { printf "%s\n%s\n", $0, line; next }; 1' assembly-ui-test-docker-context.xml > assembly-ui-test-docker-context.xml.new && mv assembly-ui-test-docker-context.xml.new assembly-ui-test-docker-context.xml fi
-
De Cypress- en Java Selenium-testmonsters die door de Adobe worden geleverd, beschikken al over de markering opt-in.
Tests voor gebruikersinterface schrijven writing-ui-tests
Deze sectie beschrijft de overeenkomsten die het beeld van de Docker dat uw tests UI bevat moet volgen. De Docker-afbeelding is gemaakt op basis van de constructiecontext van Docker die in de vorige sectie is beschreven.
Omgevingsvariabelen environment-variables
De volgende omgevingsvariabelen worden bij uitvoering aan de Docker-afbeelding doorgegeven, afhankelijk van uw framework.
SELENIUM_BASE_URL
http://my-ip:4444
SELENIUM_BROWSER
chrome
AEM_AUTHOR_URL
http://my-ip:4502/context-path
AEM_AUTHOR_USERNAME
admin
AEM_AUTHOR_PASSWORD
admin
AEM_PUBLISH_URL
http://my-ip:4503/context-path
AEM_PUBLISH_USERNAME
admin
AEM_PUBLISH_PASSWORD
admin
REPORTS_PATH
/usr/src/app/reports
UPLOAD_URL
http://upload-host:9090/upload
PROXY_HOST
proxy-host
PROXY_HTTPS_PORT
8071
PROXY_HTTP_PORT
8070
PROXY_CA_PATH
/path/to/root_ca.pem
PROXY_OBSERVABILITY_PORT
8081
PROXY_RETRY_ATTEMPTS
12
PROXY_RETRY_DELAY
5
* these values will be empty if there is no publish instance
De testmonsters van de Adobe verstrekken helperfuncties om tot de configuratieparameters toegang te hebben:
- Cypress: de standaardfunctie gebruiken
Cypress.env('VARIABLE_NAME')
- JavaScript: Zie de module
lib/config.js
- Java: Zie de
Config
-klasse
Testrapporten genereren generate-test-reports
De Docker-afbeelding moet testrapporten genereren in de XML-indeling JUnit en deze opslaan in het pad dat is opgegeven door de omgevingsvariabele REPORTS_PATH
. De indeling JUnit XML is een veelgebruikte indeling voor het rapporteren van de resultaten van tests. Als het beeld van de Docker Java en Geweven gebruikt, kunnen de standaardtestmodules zoals Gemaakte Steven Stevige Insteekmoduleen Geweven Insteekmodule Failsafedergelijke rapporten uit de doos produceren.
Als het Docker-beeld samen met andere programmeertalen of testrunners wordt geïmplementeerd, controleert u de documentatie voor de gekozen hulpmiddelen op hoe u JUnit-XML-rapporten kunt genereren.
request.log
-bestand.Vereisten prerequisites
- De tests in Cloud Manager worden uitgevoerd met een technische admin-gebruiker.
- De containerinfrastructuur die is bestemd voor functionele tests, wordt beperkt door de volgende grenzen:
Seleniumspecifieke details
Wachten op klaar voor selenium waiting-for-selenium
Alvorens de tests beginnen, is het de verantwoordelijkheid van het beeld van de Docker om ervoor te zorgen dat de server van Selenium in gebruik is. Wachten op de seleniumservice is een proces in twee stappen.
- Lees URL van de dienst van Selenium van de
SELENIUM_BASE_URL
omgevingsvariabele. - Opiniepeiling bij regelmatig interval aan het statuseindpuntblootgesteld door Selenium API.
Zodra het statuseindpunt van Selenium met een positieve reactie beantwoordt, kunnen de tests beginnen.
De de teststeekproeven van UI van de Adobe behandelen dit met het manuscript wait-for-grid.sh
, dat bij het opstarten van Docker wordt uitgevoerd en de daadwerkelijke testuitvoering begint slechts zodra het net klaar is.
Schermafbeeldingen en video's vastleggen capture-screenshots
De Docker-afbeelding kan aanvullende testuitvoer genereren (bijvoorbeeld schermafbeeldingen of video's) en deze opslaan in het pad dat wordt aangegeven door de omgevingsvariabele REPORTS_PATH
. Alle bestanden die onder REPORTS_PATH
worden gevonden, worden opgenomen in het archief met testresultaten.
De teststeekproeven die door Adobe door gebrek worden verstrekt leiden tot schermafbeeldingen voor om het even welke ontbroken test.
U kunt de hulpfuncties gebruiken om schermafbeeldingen tot stand te brengen door uw tests.
- JavaScript: opdracht takeScreenshot
- Java: opdrachten
Als een archief van testresultaat wordt gemaakt tijdens het uitvoeren van een ui-test, kunt u dit downloaden van Cloud Manager met de Download Details
knop onder de **stap Aangepaste UI testen**.
Bestanden uploaden upload-files
Tests moeten soms bestanden uploaden naar de toepassing die wordt getest. Omdat je de implementatie van Anime flexibel wilt houden ten opzichte van je tests, is het niet mogelijk om een asset rechtstreeks naar Daarom te uploaden. In plaats daarvan moet u de volgende stappen uitvoeren om een bestand te uploaden.
-
Upload het bestand naar de URL die door de omgevingsvariabele
UPLOAD_URL
wordt opgegeven.-
Het uploaden moet worden uitgevoerd in één verzoek van de POST met een meerdelige vorm.
-
Het formulier met meerdere delen moet één bestandsveld hebben.
-
Dit is gelijk aan
curl -X POST ${UPLOAD_URL} -F "data=@file.txt"
. -
Raadpleeg de documentatie en bibliotheken van de programmeertaal die in het beeld van de Docker wordt gebruikt om te weten hoe te om zulk een HTTP- verzoek uit te voeren.
-
De testmonsters van de Adobe verstrekken helperfuncties voor het uploaden van dossiers:
- JavaScript: Zie getFileHandleForUploadbevel.
- Java: Zie de klasse FileHandler.
-
-
Als het uploaden is voltooid, retourneert de aanvraag een
200 OK
reactie van het typetext/plain
.- De inhoud van de reactie is een ondoorzichtige bestandshandgreep.
- U kunt deze greep gebruiken in plaats van een bestandspad in een
<input>
-element om het uploaden van bestanden in uw toepassing te testen.
Cypersspecifieke details
HTTP-proxy instellen
Het ingangspunt van de Docker-container moet de waarde van de omgevingsvariabele PROXY_HOST
controleren.
Als deze waarde leeg is, zijn geen extra stappen vereist en de tests zouden zonder de volmacht van HTTP moeten worden uitgevoerd.
Als het niet leeg is, moet het entryPoint manuscript:
-
Vorm een de volmachtsverbinding van HTTP voor het runnen van tests UI. Dit kan worden bereikt door de omgevingsvariabele
HTTP_PROXY
die is samengesteld, te exporteren met de volgende waarden:- Proxyhost, die wordt geleverd door
PROXY_HOST
variable - Proxypoort, die wordt opgegeven door
PROXY_HTTPS_PORT
ofPROXY_HTTP_PORT
variable (de variabele met een niet-lege waarde wordt gebruikt)
- Proxyhost, die wordt geleverd door
-
Stel het CA-certificaat in dat wordt gebruikt wanneer u verbinding maakt met de HTTP-proxy. De locatie wordt opgegeven door de variabele
PROXY_CA_PATH
.- Dit kan worden bereikt door de omgevingsvariabele
NODE_EXTRA_CA_CERTS
te exporteren.
- Dit kan worden bereikt door de omgevingsvariabele
-
Wacht tot de HTTP-proxy gereed is.
- U kunt de gereedheid controleren door de omgevingsvariabelen
PROXY_HOST
,PROXY_OBSERVABILITY_PORT
,PROXY_RETRY_ATTEMPTS
enPROXY_RETRY_DELAY
te gebruiken. - U kunt controleren met een cURL-aanvraag. Controleer of u cURL hebt geïnstalleerd in uw
Dockerfile
.
- U kunt de gereedheid controleren door de omgevingsvariabelen
Een voorbeeldimplementatie kan in het Centrum van de Test van de Steekproef van de Cypress van de Module op GitHubworden gevonden.
Specifieke gegevens voor afspelen
HTTP-proxy instellen
Net als bij Cypress moeten tests de HTTP-proxy gebruiken als een niet-lege PROXY_HOST
omgevingsvariabele wordt opgegeven.
Daartoe moeten de volgende wijzigingen worden aangebracht.
Dockerfile
Installeer cURL en libnss3-tools
met certutil.
RUN apt -y update \
&& apt -y --no-install-recommends install curl libnss3-tools \
&& rm -rf /var/lib/apt/lists/*
EnterPoint-script
Neem een basscript op dat, voor het geval PROXY_HOST
environment variable wordt gegeven, het volgende doet:
- Aan proxy gerelateerde variabelen exporteren, zoals
HTTP_PROXY
enNODE_EXTRA_CA_CERTS
- Gebruik
certutil
om CA-proxycertificaat voor chroom te installeren - Wacht tot de volmacht van HTTP klaar is (of weg bij mislukking).
Voorbeeldimplementatie:
# setup proxy environment variables and CA certificate
if [ -n "${PROXY_HOST:-}" ]; then
if [ -n "${PROXY_HTTPS_PORT:-}" ]; then
export HTTP_PROXY="https://${PROXY_HOST}:${PROXY_HTTPS_PORT}"
elif [ -n "${PROXY_HTTP_PORT:-}" ]; then
export HTTP_PROXY="http://${PROXY_HOST}:${PROXY_HTTP_PORT}"
fi
if [ -n "${PROXY_CA_PATH:-}" ]; then
echo "installing certificate"
mkdir -p $HOME/.pki/nssdb
certutil -d sql:$HOME/.pki/nssdb -A -t "CT,c,c" -n "EaaS Client Proxy Root" -i $PROXY_CA_PATH
export NODE_EXTRA_CA_CERTS=${PROXY_CA_PATH}
fi
if [ -n "${PROXY_OBSERVABILITY_PORT:-}" ] && [ -n "${HTTP_PROXY:-}" ]; then
echo "waiting for proxy"
curl --silent --retry ${PROXY_RETRY_ATTEMPTS:-3} --retry-connrefused --retry-delay ${PROXY_RETRY_DELAY:-10} \
--proxy ${HTTP_PROXY} --proxy-cacert ${PROXY_CA_PATH:-""} \
${PROXY_HOST}:${PROXY_OBSERVABILITY_PORT}
if [ $? -ne 0 ]; then
echo "proxy is not ready"
exit 1
fi
fi
fi
Configuratie afspelen
Wijzig de afspeelrechterconfiguratie (bijvoorbeeld in playwright.config.js
) om een proxy te gebruiken voor het geval dat de omgevingsvariabele HTTP_PROXY
wordt ingesteld.
Voorbeeldimplementatie:
const proxyServer = process.env.HTTP_PROXY || ''
// enable proxy if set
if (proxyServer !== '') {
cfg.use.proxy = {
server: proxyServer,
}
}
UI-tests lokaal uitvoeren run-ui-tests-locally
Alvorens tests UI in een pijpleiding van Cloud Manager te activeren, adviseert het om de tests UI plaatselijk tegen AEM as a Cloud Service SDKof tegen een daadwerkelijke instantie van AEM as a Cloud Service in werking te stellen.
Monster van Cypress-test cypress-sample
-
Open een shell en navigeer naar de
ui.tests/test-module
-map in uw repository -
Cypress en andere voorwaarden installeren
code language-shell npm install
-
Omgevingsvariabelen instellen die vereist zijn voor de uitvoering van de test
code language-shell export AEM_AUTHOR_URL=https://author-<program-id>-<environment-id>.adobeaemcloud.com export AEM_AUTHOR_USERNAME=<user> export AEM_AUTHOR_PASSWORD=<password> export AEM_PUBLISH_URL=https://publish-<program-id>-<environment-id>.adobeaemcloud.com export AEM_PUBLISH_USERNAME=<user> export AEM_PUBLISH_PASSWORD=<password> export REPORTS_PATH=target/
-
Test uitvoeren met een van de volgende opdrachten
code language-shell npm test # Using default Cypress browser npm run test-chrome # Using Google Chrome browser npm run test-firefox # Using Firefox browser
target/
van uw opslagplaats.JavaScript WebdriverIO-testvoorbeeld javascript-sample
-
Een shell openen en naar de map in de
ui.tests
opslagplaats navigeren -
Voer de onderstaande opdracht uit om de tests te starten met Maven.
code language-shell mvn verify -Pui-tests-local-execution \ -DAEM_AUTHOR_URL=https://author-<program-id>-<environment-id>.adobeaemcloud.com \ -DAEM_AUTHOR_USERNAME=<user> \ -DAEM_AUTHOR_PASSWORD=<password> \ -DAEM_PUBLISH_URL=https://publish-<program-id>-<environment-id>.adobeaemcloud.com \ -DAEM_PUBLISH_USERNAME=<user> \ -DAEM_PUBLISH_PASSWORD=<password>
- Hiermee start u een zelfstandige instantie van Standalone en voert u de tests tegen deze uit.
- De logbestanden worden opgeslagen in de
target/reports
map van de opslagplaats - U moet ervoor zorgen dat uw computer de nieuwste versie van Chrome gebruikt, want met de test wordt automatisch de nieuwste versie van ChromeDriver gedownload voor tests.
Java Selenium WebDriver Test Sample java-sample
-
Open een shell en navigeer naar de
ui.tests/test-module
-map in uw repository -
Voer de onderstaande opdrachten uit om de tests te starten met Maven
code language-shell # Start selenium docker image (for x64 CPUs) docker run --platform linux/amd64 -d -p 4444:4444 selenium/standalone-chrome-debug:latest # Start selenium docker image (for ARM CPUs) docker run -d -p 4444:4444 seleniarm/standalone-chromium # Run the tests using the previously started Selenium instance mvn verify -Pui-tests-local-execution -DSELENIUM_BASE_URL=http://<server>:4444
target/reports
van uw opslagplaats.