Skip to content
This log is too long to show here, 746 KB has been skipped — click to see the complete log
w: file:///home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/respect-app-compose/src/commonMain/kotlin/world/respect/app/view/assignment/edit/AssignmentEditScreen.kt:138:56 'typealias MenuAnchorType = ExposedDropdownMenuAnchorType' is deprecated. Renamed to ExposedDropdownMenuAnchorType.
w: file:///home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/respect-app-compose/src/commonMain/kotlin/world/respect/app/view/playlists/mapping/share/PlaylistShareScreen.kt:27:8 'typealias MenuAnchorType = ExposedDropdownMenuAnchorType' is deprecated. Renamed to ExposedDropdownMenuAnchorType.
w: file:///home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/respect-app-compose/src/commonMain/kotlin/world/respect/app/view/playlists/mapping/share/PlaylistShareScreen.kt:242:29 'typealias MenuAnchorType = ExposedDropdownMenuAnchorType' is deprecated. Renamed to ExposedDropdownMenuAnchorType.
w: file:///home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/respect-app-compose/src/commonMain/kotlin/world/respect/app/view/report/edit/ReportEditScreen.kt:410:18 'fun Modifier.menuAnchor(): Modifier' is deprecated. Use overload that takes ExposedDropdownMenuAnchorType and enabled parameters.

> Task :respect-server:shadowJar
> Task :respect-app-compose:compileDebugJavaWithJavac
> Task :respect-app-compose:processDebugJavaRes
> Task :respect-app-compose:dexBuilderDebug
> Task :respect-app-compose:mergeDebugJavaResource
> Task :respect-app-compose:mergeProjectDexDebug
> Task :respect-app-compose:compileReleaseJavaWithJavac
> Task :respect-app-compose:mergeReleaseGeneratedProguardFiles UP-TO-DATE
> Task :respect-app-compose:processReleaseJavaRes
> Task :respect-app-compose:generateReleaseLintVitalReportModel
> Task :respect-app-compose:compileDesktopMainJava NO-SOURCE
> Task :respect-app-compose:desktopMainClasses
> Task :respect-app-compose:desktopJar
> Task :respect-app-compose:compileTestKotlinDesktop NO-SOURCE
> Task :respect-app-compose:compileDesktopTestJava NO-SOURCE
> Task :respect-app-compose:desktopTestClasses
> Task :respect-app-compose:desktopTest NO-SOURCE
> Task :respect-app-compose:bundleDebugClassesToRuntimeJar
> Task :respect-app-compose:generateDebugLintReportModel
> Task :respect-app-compose:bundleReleaseClassesToRuntimeJar
> Task :respect-app-compose:bundleReleaseClassesToCompileJar
> Task :respect-app-compose:bundleDebugClassesToCompileJar
> Task :respect-app-compose:compileDebugUnitTestKotlinAndroid NO-SOURCE
> Task :respect-app-compose:compileDebugUnitTestJavaWithJavac NO-SOURCE
> Task :respect-app-compose:processDebugUnitTestJavaRes NO-SOURCE
> Task :respect-app-compose:testDebugUnitTest NO-SOURCE
> Task :respect-app-compose:compileReleaseUnitTestKotlinAndroid NO-SOURCE
> Task :respect-app-compose:compileReleaseUnitTestJavaWithJavac NO-SOURCE
> Task :respect-app-compose:processReleaseUnitTestJavaRes NO-SOURCE
> Task :respect-app-compose:testReleaseUnitTest NO-SOURCE
> Task :respect-app-compose:allTests NO-SOURCE
> Task :respect-app-compose:generateDebugAndroidTestLintModel
> Task :respect-app-compose:generateDebugUnitTestLintModel
> Task :respect-credentials:generateDebugAndroidTestLintModel
> Task :respect-app-compose:test UP-TO-DATE
> Task :respect-credentials:compileTestKotlinJvm NO-SOURCE
> Task :respect-credentials:compileJvmTestJava NO-SOURCE
> Task :respect-credentials:jvmTestClasses
> Task :respect-credentials:jvmTest NO-SOURCE
> Task :respect-credentials:allTests NO-SOURCE
> Task :respect-datalayer-repository:compileJvmTestJava NO-SOURCE
> Task :respect-datalayer-repository:jvmTestClasses
> Task :respect-app-compose:expandReleaseArtProfileWildcards
> Task :respect-app-compose:mergeReleaseJavaResource
> Task :respect-credentials:lintAnalyzeDebugAndroidTest
> Task :respect-datalayer-repository:transformJvmTestAtomicfu
> Task :respect-app-compose:packageDebug
> Task :respect-app-compose:createDebugApkListingFileRedirect
> Task :respect-app-compose:assembleDebug
> Task :respect-credentials:lintReportDebug
> Task :respect-datalayer:lintReportDebug
> Task :respect-app-compose:lintAnalyzeDebugAndroidTest
> Task :respect-app-compose:lintAnalyzeDebugUnitTest
OpenJDK 64-Bit Server VM warning: Sharing is only supported for boot loader classes because bootstrap classpath has been appended
Loaded in 643 ms
Loaded in 673 ms
> Task :respect-app-compose:lintVitalAnalyzeRelease
port = 40413
port = 43213
Loaded in 68 ms
DataReadyState(data=[Person(guid=4242, userActive=true, status=ACTIVE, lastModified=2026-03-26T14:04:13.056Z, stored=2026-03-26T14:04:13.248Z, metadata=null, userMasterIdentifier=null, username=null, givenName=Admin, familyName=User, middleName=null, gender=UNSPECIFIED, preferredFirstName=null, preferredMiddleName=null, preferredLastName=null, pronouns=null, roles=[PersonRole(isPrimaryRole=true, roleEnum=SYSTEM_ADMINISTRATOR, beginDate=null, endDate=null)], relatedPersonUids=[], dateOfBirth=null, email=null, phoneNumber=null)], metaInfo=DataLoadMetaInfo(lastModified=1774533853056, lastStored=1774533853248, etag=null, url=http://localhost:34441/api/school/respect/person?includeRelated=false, consistentThrough=2026-03-26T14:04:13.249476733Z, validationInfoKey=0, varyHeader=null, headers=null, permissionsLastModified=null), localState=DataReadyState(data=[Person(guid=4242, userActive=true, status=ACTIVE, lastModified=2026-03-26T14:04:13.056Z, stored=2026-03-26T14:04:13.248Z, metadata=null, userMasterIdentifier=null, username=null, givenName=Admin, familyName=User, middleName=null, gender=UNSPECIFIED, preferredFirstName=null, preferredMiddleName=null, preferredLastName=null, pronouns=null, roles=[PersonRole(isPrimaryRole=true, roleEnum=SYSTEM_ADMINISTRATOR, beginDate=null, endDate=null)], relatedPersonUids=[], dateOfBirth=null, email=null, phoneNumber=null)], metaInfo=DataLoadMetaInfo(lastModified=1774533853056, lastStored=1774533853248, etag=null, url=null, consistentThrough=2026-03-26T14:04:13.249476733Z, validationInfoKey=0, varyHeader=null, headers=null, permissionsLastModified=null), localState=null, remoteState=null), remoteState=DataReadyState(data=[Person(guid=4242, userActive=true, status=ACTIVE, lastModified=2026-03-26T14:04:13.056Z, stored=2026-03-26T14:04:13.134Z, metadata=null, userMasterIdentifier=null, username=null, givenName=Admin, familyName=User, middleName=null, gender=UNSPECIFIED, preferredFirstName=null, preferredMiddleName=null, preferredLastName=null, pronouns=null, roles=[PersonRole(isPrimaryRole=true, roleEnum=SYSTEM_ADMINISTRATOR, beginDate=null, endDate=null)], relatedPersonUids=[], dateOfBirth=null, email=null, phoneNumber=null), Person(guid=42, userActive=true, status=ACTIVE, lastModified=2026-03-26T14:04:13.053Z, stored=2026-03-26T14:04:13.193Z, metadata=null, userMasterIdentifier=null, username=test, givenName=test, familyName=test, middleName=null, gender=FEMALE, preferredFirstName=null, preferredMiddleName=null, preferredLastName=null, pronouns=null, roles=[PersonRole(isPrimaryRole=true, roleEnum=SITE_ADMINISTRATOR, beginDate=null, endDate=null)], relatedPersonUids=[], dateOfBirth=null, email=null, phoneNumber=null)], metaInfo=DataLoadMetaInfo(lastModified=1774533853000, lastStored=-1, etag=null, url=http://localhost:34441/api/school/respect/person?includeRelated=false, consistentThrough=2026-03-26T14:04:13.199217082Z, validationInfoKey=7092960727423664838, varyHeader=Authorization, headers=com.ustadmobile.ihttp.headers.KtorHeadersAdapter@77e9dca8, permissionsLastModified=null), localState=null, remoteState=null))
Run time: 87.049195ms
> Task :respect-app-compose:lintAnalyzeDebug
Mar 26, 2026 6:04:17 PM io.github.aakira.napier.DebugAntilog performLog
FINE: [DEBUG] MapPagingSource$load - MapPagingSource(tag=PersonDataSourceDb/listAsPagingSource(params=GetListParams(common=GetListCommonParams(guid=null, searchQuery=null, since=null, sinceIfPermissionsNotChangedSince=null, includeDeleted=null), filterByClazzUid=null, filterByEnrolmentRole=null, filterByName=null, filterByPersonStatus=null, filterByPersonRole=null, includeRelated=false, inClassOnDay=null))): load Refresh(key=0, loadSize=1000)
Mar 26, 2026 6:04:19 PM io.github.aakira.napier.DebugAntilog performLog
FINE: [DEBUG] DelegatedInvalidationPagingSource$onSrcInvalidated - RPaging/DelegatedInvalidationPagingSource(extra=PersonDataSourceDb/listAsPagingSource(params=GetListParams(common=GetListCommonParams(guid=null, searchQuery=null, since=null, sinceIfPermissionsNotChangedSince=null, includeDeleted=null), filterByClazzUid=null, filterByEnrolmentRole=null, filterByName=null, filterByPersonStatus=null, filterByPersonRole=null, includeRelated=false, inClassOnDay=null))) src invalidated
Mar 26, 2026 6:04:19 PM io.github.aakira.napier.DebugAntilog performLog
FINE: [DEBUG] HttpRequestBuilderExtKt$addCacheValidationHeaders - addCacheValidationHeaders = If-Modified-Since = Thu, 26 Mar 2026 14:04:17 GMT for http://localhost:37381/api/school/respect/person?includeRelated=false
Mar 26, 2026 6:04:19 PM io.github.aakira.napier.DebugAntilog performLog
FINE: [DEBUG] MapPagingSource$load - MapPagingSource(tag=PersonDataSourceDb/listAsPagingSource(params=GetListParams(common=GetListCommonParams(guid=null, searchQuery=null, since=null, sinceIfPermissionsNotChangedSince=null, includeDeleted=null), filterByClazzUid=null, filterByEnrolmentRole=null, filterByName=null, filterByPersonStatus=null, filterByPersonRole=null, includeRelated=false, inClassOnDay=null))): load Refresh(key=0, loadSize=1000)
Mar 26, 2026 6:04:22 PM io.github.aakira.napier.DebugAntilog performLog
FINE: [DEBUG] MapPagingSource$load - MapPagingSource(tag=PersonDataSourceDb/listAsPagingSource(params=GetListParams(common=GetListCommonParams(guid=null, searchQuery=null, since=null, sinceIfPermissionsNotChangedSince=null, includeDeleted=null), filterByClazzUid=null, filterByEnrolmentRole=null, filterByName=null, filterByPersonStatus=null, filterByPersonRole=null, includeRelated=false, inClassOnDay=null))): load Refresh(key=0, loadSize=1000)
DataReadyState(data=[Person(guid=4242, userActive=true, status=ACTIVE, lastModified=2026-03-26T14:04:21.906Z, stored=2026-03-26T14:04:22.125Z, metadata=null, userMasterIdentifier=null, username=null, givenName=Admin, familyName=User, middleName=null, gender=UNSPECIFIED, preferredFirstName=null, preferredMiddleName=null, preferredLastName=null, pronouns=null, roles=[PersonRole(isPrimaryRole=true, roleEnum=SYSTEM_ADMINISTRATOR, beginDate=null, endDate=null)], relatedPersonUids=[], dateOfBirth=null, email=null, phoneNumber=null)], metaInfo=DataLoadMetaInfo(lastModified=1774533861906, lastStored=1774533862125, etag=null, url=http://localhost:44805/api/school/respect/person?includeRelated=false, consistentThrough=2026-03-26T14:04:22.127242690Z, validationInfoKey=0, varyHeader=null, headers=null, permissionsLastModified=null), localState=DataReadyState(data=[Person(guid=4242, userActive=true, status=ACTIVE, lastModified=2026-03-26T14:04:21.906Z, stored=2026-03-26T14:04:22.125Z, metadata=null, userMasterIdentifier=null, username=null, givenName=Admin, familyName=User, middleName=null, gender=UNSPECIFIED, preferredFirstName=null, preferredMiddleName=null, preferredLastName=null, pronouns=null, roles=[PersonRole(isPrimaryRole=true, roleEnum=SYSTEM_ADMINISTRATOR, beginDate=null, endDate=null)], relatedPersonUids=[], dateOfBirth=null, email=null, phoneNumber=null)], metaInfo=DataLoadMetaInfo(lastModified=1774533861906, lastStored=1774533862125, etag=null, url=null, consistentThrough=2026-03-26T14:04:22.127242690Z, validationInfoKey=0, varyHeader=null, headers=null, permissionsLastModified=null), localState=null, remoteState=null), remoteState=DataReadyState(data=[Person(guid=4242, userActive=true, status=ACTIVE, lastModified=2026-03-26T14:04:21.906Z, stored=2026-03-26T14:04:21.976Z, metadata=null, userMasterIdentifier=null, username=null, givenName=Admin, familyName=User, middleName=null, gender=UNSPECIFIED, preferredFirstName=null, preferredMiddleName=null, preferredLastName=null, pronouns=null, roles=[PersonRole(isPrimaryRole=true, roleEnum=SYSTEM_ADMINISTRATOR, beginDate=null, endDate=null)], relatedPersonUids=[], dateOfBirth=null, email=null, phoneNumber=null), Person(guid=42, userActive=true, status=ACTIVE, lastModified=2026-03-26T14:04:21.904Z, stored=2026-03-26T14:04:22.026Z, metadata=null, userMasterIdentifier=null, username=test, givenName=test, familyName=test, middleName=null, gender=FEMALE, preferredFirstName=null, preferredMiddleName=null, preferredLastName=null, pronouns=null, roles=[PersonRole(isPrimaryRole=true, roleEnum=SITE_ADMINISTRATOR, beginDate=null, endDate=null)], relatedPersonUids=[], dateOfBirth=null, email=null, phoneNumber=null)], metaInfo=DataLoadMetaInfo(lastModified=1774533862000, lastStored=-1, etag=null, url=http://localhost:44805/api/school/respect/person?includeRelated=false, consistentThrough=2026-03-26T14:04:22.048283809Z, validationInfoKey=7092960727423664838, varyHeader=Authorization, headers=com.ustadmobile.ihttp.headers.KtorHeadersAdapter@10bdfbcc, permissionsLastModified=null), localState=null, remoteState=null))
Mar 26, 2026 6:04:22 PM io.github.aakira.napier.DebugAntilog performLog
FINE: [DEBUG] DelegatedInvalidationPagingSource$onSrcInvalidated - RPaging/DelegatedInvalidationPagingSource(extra=PersonDataSourceDb/listAsPagingSource(params=GetListParams(common=GetListCommonParams(guid=null, searchQuery=null, since=null, sinceIfPermissionsNotChangedSince=null, includeDeleted=null), filterByClazzUid=null, filterByEnrolmentRole=null, filterByName=null, filterByPersonStatus=null, filterByPersonRole=null, includeRelated=false, inClassOnDay=null))) src invalidated
Mar 26, 2026 6:04:22 PM io.github.aakira.napier.DebugAntilog performLog
FINE: [DEBUG] MapPagingSource$load - MapPagingSource(tag=PersonDataSourceDb/listAsPagingSource(params=GetListParams(common=GetListCommonParams(guid=null, searchQuery=null, since=2026-03-26T14:04:22.048283809Z, sinceIfPermissionsNotChangedSince=null, includeDeleted=null), filterByClazzUid=null, filterByEnrolmentRole=null, filterByName=null, filterByPersonStatus=null, filterByPersonRole=null, includeRelated=false, inClassOnDay=null))): load Refresh(key=0, loadSize=1000)
Run time: 114.835745ms
> Task :respect-datalayer-repository:jvmTest
> Task :respect-app-compose:lintVitalReportRelease SKIPPED
> Task :respect-app-compose:lintVitalRelease SKIPPED
> Task :respect-credentials:lintDebug
> Task :respect-credentials:lint
> Task :respect-credentials:check
> Task :respect-credentials:build
> Task :respect-datalayer:lintDebug
> Task :respect-datalayer:lint
> Task :respect-datalayer:check
> Task :respect-datalayer:build
> Task :respect-datalayer-repository:allTests
> Task :respect-lib-shared:compileJvmTestJava NO-SOURCE
> Task :respect-lib-shared:jvmTestClasses
> Task :respect-datalayer-db:lintReportDebug
> Task :respect-datalayer-http:lintReportDebug
> Task :respect-datalayer-repository:lintReportDebug
> Task :respect-app-compose:minifyReleaseWithR8

> Task :respect-app-compose:lintReportDebug
Wrote HTML report to file:///home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/respect-app-compose/build/reports/lint-results-debug.html
OpenJDK 64-Bit Server VM warning: Sharing is only supported for boot loader classes because bootstrap classpath has been appended

> Task :respect-lib-shared:jvmTest
> Task :respect-app-compose:lintDebug
> Task :respect-app-compose:lint
> Task :respect-app-compose:check
> Task :respect-datalayer-db:lintDebug
> Task :respect-datalayer-db:lint
> Task :respect-datalayer-db:check
> Task :respect-datalayer-db:build
> Task :respect-datalayer-http:lintDebug
> Task :respect-datalayer-http:lint
> Task :respect-datalayer-http:check
> Task :respect-datalayer-http:build
> Task :respect-datalayer-repository:lintDebug
> Task :respect-datalayer-repository:lint
> Task :respect-datalayer-repository:check
> Task :respect-datalayer-repository:build
> Task :respect-lib-shared:allTests

> Task :respect-lib-shared:lintReportDebug
Wrote HTML report to file:///home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/respect-lib-shared/build/reports/lint-results-debug.html

> Task :respect-lib-test:lintReportDebug
> Task :respect-lib-shared-se:lintReportDebug
> Task :respect-server:startShadowScripts
> Task :respect-lib-shared:lintDebug
> Task :respect-lib-shared:lint
> Task :respect-lib-shared:check
> Task :respect-lib-shared:build
> Task :respect-lib-shared-se:lintDebug
> Task :respect-lib-shared-se:lint
> Task :respect-lib-shared-se:check
> Task :respect-lib-shared-se:build
> Task :respect-lib-test:lintDebug
> Task :respect-lib-test:lint
> Task :respect-lib-test:check
> Task :respect-lib-test:build
> Task :respect-server:shadowDistTar
> Task :respect-server:shadowDistZip
> Task :respect-server:assemble
> Task :respect-server:compileTestKotlin NO-SOURCE
> Task :respect-server:compileTestJava NO-SOURCE
> Task :respect-server:testClasses UP-TO-DATE
> Task :respect-server:test NO-SOURCE
> Task :respect-server:check UP-TO-DATE
> Task :respect-server:build
> Task :respect-app-compose:convertShrunkResourcesToBinaryRelease
> Task :respect-app-compose:compileReleaseArtProfile
> Task :respect-app-compose:optimizeReleaseResources
> Task :respect-app-compose:packageRelease
> Task :respect-app-compose:createReleaseApkListingFileRedirect
> Task :respect-app-compose:assembleRelease
> Task :respect-app-compose:assemble
> Task :respect-app-compose:build

[Incubating] Problems report is available at: file:///home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/reports/problems/problems-report.html

Deprecated Gradle features were used in this build, making it incompatible with Gradle 9.0.

You can use '--warning-mode all' to show the individual deprecation warnings and determine if they come from your own scripts or plugins.

For more on this, please refer to https://docs.gradle.org/8.13/userguide/command_line_interface.html#sec:command_line_warnings in the Gradle documentation.

BUILD SUCCESSFUL in 2m 23s
1910 actionable tasks: 1717 executed, 193 up-to-date
Build step 'Invoke Gradle script' changed build result to SUCCESS
[dev-playlists-end-to-end-tests] $ /bin/sh -xe /tmp/jenkins6076791810521273122.sh
+ ./ci-run-maestro.sh cloud
ROOTDIR=/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests BASH_SOURCE=./ci-run-maestro.sh
--2026-03-26 18:04:51--  https://devserver3.ustadmobile.com/jenkins/job/TestServerController/9/artifact/build/distributions/testservercontroller-0.0.8.zip
Resolving devserver3.ustadmobile.com (devserver3.ustadmobile.com)... 37.27.227.212
Connecting to devserver3.ustadmobile.com (devserver3.ustadmobile.com)|37.27.227.212|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 17769863 (17M) [application/zip]
Saving to: ‘/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8.zip’

     0K .......... .......... .......... .......... ..........  0%  310M 0s
    50K .......... .......... .......... .......... ..........  0%  519M 0s
   100K .......... .......... .......... .......... ..........  0%  420M 0s
   150K .......... .......... .......... .......... ..........  1%  337M 0s
   200K .......... .......... .......... .......... ..........  1%  466M 0s
   250K .......... .......... .......... .......... ..........  1%  477M 0s
   300K .......... .......... .......... .......... ..........  2%  503M 0s
   350K .......... .......... .......... .......... ..........  2%  487M 0s
   400K .......... .......... .......... .......... ..........  2%  462M 0s
   450K .......... .......... .......... .......... ..........  2%  446M 0s
   500K .......... .......... .......... .......... ..........  3%  435M 0s
   550K .......... .......... .......... .......... ..........  3%  471M 0s
   600K .......... .......... .......... .......... ..........  3%  368M 0s
   650K .......... .......... .......... .......... ..........  4%  423M 0s
   700K .......... .......... .......... .......... ..........  4%  405M 0s
   750K .......... .......... .......... .......... ..........  4%  354M 0s
   800K .......... .......... .......... .......... ..........  4%  406M 0s
   850K .......... .......... .......... .......... ..........  5%  447M 0s
   900K .......... .......... .......... .......... ..........  5%  428M 0s
   950K .......... .......... .......... .......... ..........  5%  407M 0s
  1000K .......... .......... .......... .......... ..........  6%  367M 0s
  1050K .......... .......... .......... .......... ..........  6%  602M 0s
  1100K .......... .......... .......... .......... ..........  6%  575M 0s
  1150K .......... .......... .......... .......... ..........  6%  579M 0s
  1200K .......... .......... .......... .......... ..........  7%  504M 0s
  1250K .......... .......... .......... .......... ..........  7%  544M 0s
  1300K .......... .......... .......... .......... ..........  7%  515M 0s
  1350K .......... .......... .......... .......... ..........  8%  561M 0s
  1400K .......... .......... .......... .......... ..........  8%  511M 0s
  1450K .......... .......... .......... .......... ..........  8%  597M 0s
  1500K .......... .......... .......... .......... ..........  8%  567M 0s
  1550K .......... .......... .......... .......... ..........  9%  530M 0s
  1600K .......... .......... .......... .......... ..........  9%  493M 0s
  1650K .......... .......... .......... .......... ..........  9%  479M 0s
  1700K .......... .......... .......... .......... .......... 10%  574M 0s
  1750K .......... .......... .......... .......... .......... 10%  345M 0s
  1800K .......... .......... .......... .......... .......... 10%  512M 0s
  1850K .......... .......... .......... .......... .......... 10%  549M 0s
  1900K .......... .......... .......... .......... .......... 11%  552M 0s
  1950K .......... .......... .......... .......... .......... 11%  541M 0s
  2000K .......... .......... .......... .......... .......... 11%  467M 0s
  2050K .......... .......... .......... .......... .......... 12%  528M 0s
  2100K .......... .......... .......... .......... .......... 12%  640M 0s
  2150K .......... .......... .......... .......... .......... 12%  495M 0s
  2200K .......... .......... .......... .......... .......... 12%  556M 0s
  2250K .......... .......... .......... .......... .......... 13%  542M 0s
  2300K .......... .......... .......... .......... .......... 13%  580M 0s
  2350K .......... .......... .......... .......... .......... 13%  534M 0s
  2400K .......... .......... .......... .......... .......... 14%  479M 0s
  2450K .......... .......... .......... .......... .......... 14%  656M 0s
  2500K .......... .......... .......... .......... .......... 14%  504M 0s
  2550K .......... .......... .......... .......... .......... 14%  542M 0s
  2600K .......... .......... .......... .......... .......... 15%  497M 0s
  2650K .......... .......... .......... .......... .......... 15%  546M 0s
  2700K .......... .......... .......... .......... .......... 15%  549M 0s
  2750K .......... .......... .......... .......... .......... 16%  556M 0s
  2800K .......... .......... .......... .......... .......... 16%  509M 0s
  2850K .......... .......... .......... .......... .......... 16%  577M 0s
  2900K .......... .......... .......... .......... .......... 16%  530M 0s
  2950K .......... .......... .......... .......... .......... 17%  570M 0s
  3000K .......... .......... .......... .......... .......... 17%  477M 0s
  3050K .......... .......... .......... .......... .......... 17%  602M 0s
  3100K .......... .......... .......... .......... .......... 18%  535M 0s
  3150K .......... .......... .......... .......... .......... 18%  507M 0s
  3200K .......... .......... .......... .......... .......... 18%  500M 0s
  3250K .......... .......... .......... .......... .......... 19%  514M 0s
  3300K .......... .......... .......... .......... .......... 19%  581M 0s
  3350K .......... .......... .......... .......... .......... 19%  527M 0s
  3400K .......... .......... .......... .......... .......... 19%  514M 0s
  3450K .......... .......... .......... .......... .......... 20%  605M 0s
  3500K .......... .......... .......... .......... .......... 20%  561M 0s
  3550K .......... .......... .......... .......... .......... 20%  536M 0s
  3600K .......... .......... .......... .......... .......... 21%  471M 0s
  3650K .......... .......... .......... .......... .......... 21%  549M 0s
  3700K .......... .......... .......... .......... .......... 21%  532M 0s
  3750K .......... .......... .......... .......... .......... 21%  464M 0s
  3800K .......... .......... .......... .......... .......... 22%  271M 0s
  3850K .......... .......... .......... .......... .......... 22%  595M 0s
  3900K .......... .......... .......... .......... .......... 22%  543M 0s
  3950K .......... .......... .......... .......... .......... 23%  540M 0s
  4000K .......... .......... .......... .......... .......... 23%  466M 0s
  4050K .......... .......... .......... .......... .......... 23%  580M 0s
  4100K .......... .......... .......... .......... .......... 23%  611M 0s
  4150K .......... .......... .......... .......... .......... 24%  497M 0s
  4200K .......... .......... .......... .......... .......... 24%  329M 0s
  4250K .......... .......... .......... .......... .......... 24%  414M 0s
  4300K .......... .......... .......... .......... .......... 25%  443M 0s
  4350K .......... .......... .......... .......... .......... 25%  450M 0s
  4400K .......... .......... .......... .......... .......... 25%  409M 0s
  4450K .......... .......... .......... .......... .......... 25%  432M 0s
  4500K .......... .......... .......... .......... .......... 26%  391M 0s
  4550K .......... .......... .......... .......... .......... 26%  449M 0s
  4600K .......... .......... .......... .......... .......... 26%  376M 0s
  4650K .......... .......... .......... .......... .......... 27%  470M 0s
  4700K .......... .......... .......... .......... .......... 27%  477M 0s
  4750K .......... .......... .......... .......... .......... 27%  474M 0s
  4800K .......... .......... .......... .......... .......... 27%  415M 0s
  4850K .......... .......... .......... .......... .......... 28%  440M 0s
  4900K .......... .......... .......... .......... .......... 28%  443M 0s
  4950K .......... .......... .......... .......... .......... 28%  382M 0s
  5000K .......... .......... .......... .......... .......... 29%  452M 0s
  5050K .......... .......... .......... .......... .......... 29%  539M 0s
  5100K .......... .......... .......... .......... .......... 29%  556M 0s
  5150K .......... .......... .......... .......... .......... 29%  559M 0s
  5200K .......... .......... .......... .......... .......... 30%  422M 0s
  5250K .......... .......... .......... .......... .......... 30%  524M 0s
  5300K .......... .......... .......... .......... .......... 30%  556M 0s
  5350K .......... .......... .......... .......... .......... 31%  546M 0s
  5400K .......... .......... .......... .......... .......... 31%  492M 0s
  5450K .......... .......... .......... .......... .......... 31%  545M 0s
  5500K .......... .......... .......... .......... .......... 31%  509M 0s
  5550K .......... .......... .......... .......... .......... 32%  569M 0s
  5600K .......... .......... .......... .......... .......... 32%  475M 0s
  5650K .......... .......... .......... .......... .......... 32%  510M 0s
  5700K .......... .......... .......... .......... .......... 33%  566M 0s
  5750K .......... .......... .......... .......... .......... 33%  474M 0s
  5800K .......... .......... .......... .......... .......... 33%  524M 0s
  5850K .......... .......... .......... .......... .......... 33%  558M 0s
  5900K .......... .......... .......... .......... .......... 34%  561M 0s
  5950K .......... .......... .......... .......... .......... 34%  367M 0s
  6000K .......... .......... .......... .......... .......... 34%  456M 0s
  6050K .......... .......... .......... .......... .......... 35%  569M 0s
  6100K .......... .......... .......... .......... .......... 35%  454M 0s
  6150K .......... .......... .......... .......... .......... 35%  507M 0s
  6200K .......... .......... .......... .......... .......... 36%  515M 0s
  6250K .......... .......... .......... .......... .......... 36%  539M 0s
  6300K .......... .......... .......... .......... .......... 36%  545M 0s
  6350K .......... .......... .......... .......... .......... 36%  548M 0s
  6400K .......... .......... .......... .......... .......... 37%  499M 0s
  6450K .......... .......... .......... .......... .......... 37%  502M 0s
  6500K .......... .......... .......... .......... .......... 37%  504M 0s
  6550K .......... .......... .......... .......... .......... 38%  565M 0s
  6600K .......... .......... .......... .......... .......... 38%  510M 0s
  6650K .......... .......... .......... .......... .......... 38%  514M 0s
  6700K .......... .......... .......... .......... .......... 38%  544M 0s
  6750K .......... .......... .......... .......... .......... 39%  588M 0s
  6800K .......... .......... .......... .......... .......... 39%  409M 0s
  6850K .......... .......... .......... .......... .......... 39%  516M 0s
  6900K .......... .......... .......... .......... .......... 40%  504M 0s
  6950K .......... .......... .......... .......... .......... 40%  551M 0s
  7000K .......... .......... .......... .......... .......... 40%  497M 0s
  7050K .......... .......... .......... .......... .......... 40%  575M 0s
  7100K .......... .......... .......... .......... .......... 41%  563M 0s
  7150K .......... .......... .......... .......... .......... 41%  432M 0s
  7200K .......... .......... .......... .......... .......... 41%  480M 0s
  7250K .......... .......... .......... .......... .......... 42%  512M 0s
  7300K .......... .......... .......... .......... .......... 42%  545M 0s
  7350K .......... .......... .......... .......... .......... 42%  560M 0s
  7400K .......... .......... .......... .......... .......... 42%  495M 0s
  7450K .......... .......... .......... .......... .......... 43%  563M 0s
  7500K .......... .......... .......... .......... .......... 43%  557M 0s
  7550K .......... .......... .......... .......... .......... 43%  448M 0s
  7600K .......... .......... .......... .......... .......... 44%  490M 0s
  7650K .......... .......... .......... .......... .......... 44%  518M 0s
  7700K .......... .......... .......... .......... .......... 44%  325M 0s
  7750K .......... .......... .......... .......... .......... 44%  400M 0s
  7800K .......... .......... .......... .......... .......... 45%  435M 0s
  7850K .......... .......... .......... .......... .......... 45%  336M 0s
  7900K .......... .......... .......... .......... .......... 45%  403M 0s
  7950K .......... .......... .......... .......... .......... 46%  453M 0s
  8000K .......... .......... .......... .......... .......... 46%  374M 0s
  8050K .......... .......... .......... .......... .......... 46%  460M 0s
  8100K .......... .......... .......... .......... .......... 46%  445M 0s
  8150K .......... .......... .......... .......... .......... 47%  435M 0s
  8200K .......... .......... .......... .......... .......... 47%  494M 0s
  8250K .......... .......... .......... .......... .......... 47%  417M 0s
  8300K .......... .......... .......... .......... .......... 48%  534M 0s
  8350K .......... .......... .......... .......... .......... 48%  540M 0s
  8400K .......... .......... .......... .......... .......... 48%  479M 0s
  8450K .......... .......... .......... .......... .......... 48%  541M 0s
  8500K .......... .......... .......... .......... .......... 49%  444M 0s
  8550K .......... .......... .......... .......... .......... 49%  551M 0s
  8600K .......... .......... .......... .......... .......... 49%  352M 0s
  8650K .......... .......... .......... .......... .......... 50%  675M 0s
  8700K .......... .......... .......... .......... .......... 50%  668M 0s
  8750K .......... .......... .......... .......... .......... 50%  677M 0s
  8800K .......... .......... .......... .......... .......... 50%  593M 0s
  8850K .......... .......... .......... .......... .......... 51%  671M 0s
  8900K .......... .......... .......... .......... .......... 51%  562M 0s
  8950K .......... .......... .......... .......... .......... 51%  685M 0s
  9000K .......... .......... .......... .......... .......... 52%  485M 0s
  9050K .......... .......... .......... .......... .......... 52%  680M 0s
  9100K .......... .......... .......... .......... .......... 52%  659M 0s
  9150K .......... .......... .......... .......... .......... 53%  685M 0s
  9200K .......... .......... .......... .......... .......... 53%  568M 0s
  9250K .......... .......... .......... .......... .......... 53%  615M 0s
  9300K .......... .......... .......... .......... .......... 53%  676M 0s
  9350K .......... .......... .......... .......... .......... 54%  517M 0s
  9400K .......... .......... .......... .......... .......... 54%  470M 0s
  9450K .......... .......... .......... .......... .......... 54%  678M 0s
  9500K .......... .......... .......... .......... .......... 55%  678M 0s
  9550K .......... .......... .......... .......... .......... 55%  691M 0s
  9600K .......... .......... .......... .......... .......... 55%  597M 0s
  9650K .......... .......... .......... .......... .......... 55%  621M 0s
  9700K .......... .......... .......... .......... .......... 56%  528M 0s
  9750K .......... .......... .......... .......... .......... 56%  602M 0s
  9800K .......... .......... .......... .......... .......... 56%  593M 0s
  9850K .......... .......... .......... .......... .......... 57%  694M 0s
  9900K .......... .......... .......... .......... .......... 57%  693M 0s
  9950K .......... .......... .......... .......... .......... 57%  657M 0s
 10000K .......... .......... .......... .......... .......... 57%  563M 0s
 10050K .......... .......... .......... .......... .......... 58%  541M 0s
 10100K .......... .......... .......... .......... .......... 58%  728M 0s
 10150K .......... .......... .......... .......... .......... 58%  609M 0s
 10200K .......... .......... .......... .......... .......... 59%  641M 0s
 10250K .......... .......... .......... .......... .......... 59%  683M 0s
 10300K .......... .......... .......... .......... .......... 59%  667M 0s
 10350K .......... .......... .......... .......... .......... 59%  673M 0s
 10400K .......... .......... .......... .......... .......... 60%  394M 0s
 10450K .......... .......... .......... .......... .......... 60%  518M 0s
 10500K .......... .......... .......... .......... .......... 60%  608M 0s
 10550K .......... .......... .......... .......... .......... 61%  684M 0s
 10600K .......... .......... .......... .......... .......... 61%  631M 0s
 10650K .......... .......... .......... .......... .......... 61%  679M 0s
 10700K .......... .......... .......... .......... .......... 61%  680M 0s
 10750K .......... .......... .......... .......... .......... 62%  559M 0s
 10800K .......... .......... .......... .......... .......... 62%  597M 0s
 10850K .......... .......... .......... .......... .......... 62%  687M 0s
 10900K .......... .......... .......... .......... .......... 63%  643M 0s
 10950K .......... .......... .......... .......... .......... 63%  676M 0s
 11000K .......... .......... .......... .......... .......... 63%  609M 0s
 11050K .......... .......... .......... .......... .......... 63%  578M 0s
 11100K .......... .......... .......... .......... .......... 64%  612M 0s
 11150K .......... .......... .......... .......... .......... 64%  684M 0s
 11200K .......... .......... .......... .......... .......... 64%  608M 0s
 11250K .......... .......... .......... .......... .......... 65%  633M 0s
 11300K .......... .......... .......... .......... .......... 65%  686M 0s
 11350K .......... .......... .......... .......... .......... 65%  685M 0s
 11400K .......... .......... .......... .......... .......... 65%  490M 0s
 11450K .......... .......... .......... .......... .......... 66%  680M 0s
 11500K .......... .......... .......... .......... .......... 66%  681M 0s
 11550K .......... .......... .......... .......... .......... 66%  690M 0s
 11600K .......... .......... .......... .......... .......... 67%  612M 0s
 11650K .......... .......... .......... .......... .......... 67%  623M 0s
 11700K .......... .......... .......... .......... .......... 67%  665M 0s
 11750K .......... .......... .......... .......... .......... 67%  600M 0s
 11800K .......... .......... .......... .......... .......... 68%  507M 0s
 11850K .......... .......... .......... .......... .......... 68%  679M 0s
 11900K .......... .......... .......... .......... .......... 68%  685M 0s
 11950K .......... .......... .......... .......... .......... 69%  663M 0s
 12000K .......... .......... .......... .......... .......... 69%  551M 0s
 12050K .......... .......... .......... .......... .......... 69%  678M 0s
 12100K .......... .......... .......... .......... .......... 70%  576M 0s
 12150K .......... .......... .......... .......... .......... 70%  609M 0s
 12200K .......... .......... .......... .......... .......... 70%  644M 0s
 12250K .......... .......... .......... .......... .......... 70%  676M 0s
 12300K .......... .......... .......... .......... .......... 71%  655M 0s
 12350K .......... .......... .......... .......... .......... 71%  631M 0s
 12400K .......... .......... .......... .......... .......... 71%  285M 0s
 12450K .......... .......... .......... .......... .......... 72%  683M 0s
 12500K .......... .......... .......... .......... .......... 72%  517M 0s
 12550K .......... .......... .......... .......... .......... 72%  689M 0s
 12600K .......... .......... .......... .......... .......... 72%  665M 0s
 12650K .......... .......... .......... .......... .......... 73%  662M 0s
 12700K .......... .......... .......... .......... .......... 73%  675M 0s
 12750K .......... .......... .......... .......... .......... 73%  686M 0s
 12800K .......... .......... .......... .......... .......... 74%  601M 0s
 12850K .......... .......... .......... .......... .......... 74%  664M 0s
 12900K .......... .......... .......... .......... .......... 74%  639M 0s
 12950K .......... .......... .......... .......... .......... 74%  642M 0s
 13000K .......... .......... .......... .......... .......... 75%  581M 0s
 13050K .......... .......... .......... .......... .......... 75%  674M 0s
 13100K .......... .......... .......... .......... .......... 75%  670M 0s
 13150K .......... .......... .......... .......... .......... 76%  690M 0s
 13200K .......... .......... .......... .......... .......... 76%  596M 0s
 13250K .......... .......... .......... .......... .......... 76%  608M 0s
 13300K .......... .......... .......... .......... .......... 76%  667M 0s
 13350K .......... .......... .......... .......... .......... 77%  662M 0s
 13400K .......... .......... .......... .......... .......... 77%  587M 0s
 13450K .......... .......... .......... .......... .......... 77%  700M 0s
 13500K .......... .......... .......... .......... .......... 78%  661M 0s
 13550K .......... .......... .......... .......... .......... 78%  648M 0s
 13600K .......... .......... .......... .......... .......... 78%  568M 0s
 13650K .......... .......... .......... .......... .......... 78%  630M 0s
 13700K .......... .......... .......... .......... .......... 79%  680M 0s
 13750K .......... .......... .......... .......... .......... 79%  622M 0s
 13800K .......... .......... .......... .......... .......... 79%  656M 0s
 13850K .......... .......... .......... .......... .......... 80%  689M 0s
 13900K .......... .......... .......... .......... .......... 80%  691M 0s
 13950K .......... .......... .......... .......... .......... 80%  669M 0s
 14000K .......... .......... .......... .......... .......... 80%  558M 0s
 14050K .......... .......... .......... .......... .......... 81%  676M 0s
 14100K .......... .......... .......... .......... .......... 81%  746M 0s
 14150K .......... .......... .......... .......... .......... 81%  608M 0s
 14200K .......... .......... .......... .......... .......... 82%  639M 0s
 14250K .......... .......... .......... .......... .......... 82%  674M 0s
 14300K .......... .......... .......... .......... .......... 82%  627M 0s
 14350K .......... .......... .......... .......... .......... 82%  677M 0s
 14400K .......... .......... .......... .......... .......... 83%  603M 0s
 14450K .......... .......... .......... .......... .......... 83%  684M 0s
 14500K .......... .......... .......... .......... .......... 83%  615M 0s
 14550K .......... .......... .......... .......... .......... 84%  679M 0s
 14600K .......... .......... .......... .......... .......... 84%  634M 0s
 14650K .......... .......... .......... .......... .......... 84%  682M 0s
 14700K .......... .......... .......... .......... .......... 84%  669M 0s
 14750K .......... .......... .......... .......... .......... 85%  666M 0s
 14800K .......... .......... .......... .......... .......... 85%  605M 0s
 14850K .......... .......... .......... .......... .......... 85%  674M 0s
 14900K .......... .......... .......... .......... .......... 86%  637M 0s
 14950K .......... .......... .......... .......... .......... 86%  636M 0s
 15000K .......... .......... .......... .......... .......... 86%  610M 0s
 15050K .......... .......... .......... .......... .......... 87%  674M 0s
 15100K .......... .......... .......... .......... .......... 87%  638M 0s
 15150K .......... .......... .......... .......... .......... 87%  678M 0s
 15200K .......... .......... .......... .......... .......... 87%  597M 0s
 15250K .......... .......... .......... .......... .......... 88%  625M 0s
 15300K .......... .......... .......... .......... .......... 88%  684M 0s
 15350K .......... .......... .......... .......... .......... 88%  671M 0s
 15400K .......... .......... .......... .......... .......... 89%  578M 0s
 15450K .......... .......... .......... .......... .......... 89%  683M 0s
 15500K .......... .......... .......... .......... .......... 89%  686M 0s
 15550K .......... .......... .......... .......... .......... 89%  697M 0s
 15600K .......... .......... .......... .......... .......... 90%  563M 0s
 15650K .......... .......... .......... .......... .......... 90%  622M 0s
 15700K .......... .......... .......... .......... .......... 90%  678M 0s
 15750K .......... .......... .......... .......... .......... 91%  599M 0s
 15800K .......... .......... .......... .......... .......... 91%  644M 0s
 15850K .......... .......... .......... .......... .......... 91%  691M 0s
 15900K .......... .......... .......... .......... .......... 91%  684M 0s
 15950K .......... .......... .......... .......... .......... 92%  672M 0s
 16000K .......... .......... .......... .......... .......... 92%  559M 0s
 16050K .......... .......... .......... .......... .......... 92%  685M 0s
 16100K .......... .......... .......... .......... .......... 93%  718M 0s
 16150K .......... .......... .......... .......... .......... 93%  613M 0s
 16200K .......... .......... .......... .......... .......... 93%  643M 0s
 16250K .......... .......... .......... .......... .......... 93%  634M 0s
 16300K .......... .......... .......... .......... .......... 94%  673M 0s
 16350K .......... .......... .......... .......... .......... 94%  654M 0s
 16400K .......... .......... .......... .......... .......... 94%  581M 0s
 16450K .......... .......... .......... .......... .......... 95%  197M 0s
 16500K .......... .......... .......... .......... .......... 95%  619M 0s
 16550K .......... .......... .......... .......... .......... 95%  658M 0s
 16600K .......... .......... .......... .......... .......... 95%  627M 0s
 16650K .......... .......... .......... .......... .......... 96%  662M 0s
 16700K .......... .......... .......... .......... .......... 96%  676M 0s
 16750K .......... .......... .......... .......... .......... 96%  685M 0s
 16800K .......... .......... .......... .......... .......... 97%  570M 0s
 16850K .......... .......... .......... .......... .......... 97%  685M 0s
 16900K .......... .......... .......... .......... .......... 97%  615M 0s
 16950K .......... .......... .......... .......... .......... 97%  675M 0s
 17000K .......... .......... .......... .......... .......... 98%  602M 0s
 17050K .......... .......... .......... .......... .......... 98%  686M 0s
 17100K .......... .......... .......... .......... .......... 98%  687M 0s
 17150K .......... .......... .......... .......... .......... 99%  681M 0s
 17200K .......... .......... .......... .......... .......... 99%  603M 0s
 17250K .......... .......... .......... .......... .......... 99%  618M 0s
 17300K .......... .......... .......... .......... .......... 99%  678M 0s
 17350K ...                                                   100%  359M=0.03s

2026-03-26 18:04:51 (544 MB/s) - ‘/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8.zip’ saved [17769863/17769863]

Archive:  /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8.zip
   creating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/
   creating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/testservercontroller-0.0.8.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-client-okhttp-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-client-core-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-server-conditional-headers-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-server-auto-head-response-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-server-content-negotiation-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-server-call-logging-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-server-netty-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-server-config-yaml-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-server-core-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/okhttp-jvm-5.1.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-http-cio-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-websocket-serialization-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-serialization-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-websockets-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-http-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-events-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-sse-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-network-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-utils-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/ktor-io-jvm-3.3.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlinx-coroutines-core-jvm-1.10.2.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlinx-coroutines-slf4j-1.10.2.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlinx-datetime-jvm-0.7.1.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlin-reflect-2.2.10.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/yamlkt-jvm-0.13.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kaml-jvm-0.79.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/snakeyaml-engine-kmp-jvm-3.1.1.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/okio-jvm-3.16.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlinx-serialization-core-jvm-1.9.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlin-stdlib-jdk8-1.8.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlin-stdlib-jdk7-1.8.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlinx-io-core-jvm-0.8.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/urlencoder-lib-jvm-1.6.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlinx-io-bytestring-jvm-0.8.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/kotlin-stdlib-2.2.20.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/logback-classic-1.5.19.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/annotations-23.0.0.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/logback-core-1.5.19.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/slf4j-api-2.0.17.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/config-1.4.4.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/jansi-2.4.2.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-codec-http2-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/alpn-api-1.1.3.v20160715.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-transport-native-kqueue-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-transport-native-epoll-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-codec-http-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-handler-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-codec-compression-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-codec-base-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-transport-classes-kqueue-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-transport-classes-epoll-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-transport-native-unix-common-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-transport-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-buffer-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-resolver-4.2.4.Final.jar  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/netty-common-4.2.4.Final.jar  
   creating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/bin/
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/bin/testservercontroller  
  inflating: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/bin/testservercontroller.bat  
ci-run-maestro: TESTCONTROLLER_URL is https://8070.ustadtesting.ustadmobile.com/
Waiting for localhost:8070..18:04:52,007 |-INFO in ch.qos.logback.classic.LoggerContext[default] - This is logback-classic version 1.5.19
18:04:52,008 |-INFO in ch.qos.logback.classic.util.ContextInitializer@71075444 - No custom configurators were discovered as a service.
18:04:52,008 |-INFO in ch.qos.logback.classic.util.ContextInitializer@71075444 - Trying to configure with ch.qos.logback.classic.joran.SerializedModelConfigurator
18:04:52,008 |-INFO in ch.qos.logback.classic.util.ContextInitializer@71075444 - Constructed configurator of type class ch.qos.logback.classic.joran.SerializedModelConfigurator
18:04:52,010 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Could NOT find resource [logback-test.scmo]
18:04:52,010 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Could NOT find resource [logback.scmo]
18:04:52,014 |-INFO in ch.qos.logback.classic.util.ContextInitializer@71075444 - ch.qos.logback.classic.joran.SerializedModelConfigurator.configure() call lasted 2 milliseconds. ExecutionStatus=INVOKE_NEXT_IF_ANY
18:04:52,014 |-INFO in ch.qos.logback.classic.util.ContextInitializer@71075444 - Trying to configure with ch.qos.logback.classic.util.DefaultJoranConfigurator
18:04:52,015 |-INFO in ch.qos.logback.classic.util.ContextInitializer@71075444 - Constructed configurator of type class ch.qos.logback.classic.util.DefaultJoranConfigurator
18:04:52,015 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Could NOT find resource [logback-test.xml]
18:04:52,016 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Found resource [logback.xml] at [jar:file:/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/testservercontroller-0.0.8.jar!/logback.xml]
18:04:52,018 |-INFO in ch.qos.logback.core.joran.spi.ConfigurationWatchList@4f32a3ad - URL [jar:file:/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/testservercontroller-0.0.8.jar!/logback.xml] is not of type file
18:04:52,052 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@6b695b06 - value "/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/workspace/logs/" substituted for "${logs_dir:-./log/}"
18:04:52,052 |-INFO in ch.qos.logback.classic.model.processor.ConfigurationModelHandlerFull - Main configuration file URL: jar:file:/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/testservercontroller-0.0.8/lib/testservercontroller-0.0.8.jar!/logback.xml
18:04:52,052 |-INFO in ch.qos.logback.classic.model.processor.ConfigurationModelHandlerFull - FileWatchList= {}
18:04:52,053 |-INFO in ch.qos.logback.classic.model.processor.ConfigurationModelHandlerFull - URLWatchList= {}
18:04:52,053 |-INFO in ch.qos.logback.core.model.processor.AppenderModelHandler - Processing appender named [FILE]
18:04:52,053 |-INFO in ch.qos.logback.core.model.processor.AppenderModelHandler - About to instantiate appender of type [ch.qos.logback.core.rolling.RollingFileAppender]
18:04:52,056 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@6b695b06 - value "/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/workspace/logs//testservercontroller.log" substituted for "${LOG_DIR}/testservercontroller.log"
18:04:52,058 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@6b695b06 - value "/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/workspace/logs//testservercontroller.%d{yyyy-MM-dd}.%i.log" substituted for "${LOG_DIR}/testservercontroller.%d{yyyy-MM-dd}.%i.log"
18:04:52,061 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy@1293677337 - No compression will be used
18:04:52,069 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy@1293677337 - Will use the pattern /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/workspace/logs//testservercontroller.%d{yyyy-MM-dd}.%i.log for the active file
18:04:52,069 |-WARN in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@6f53b8a - SizeAndTimeBasedFNATP class was renamed as SizeAndTimeBasedFileNamingAndTriggeringPolicy.
18:04:52,078 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@6f53b8a - The date pattern is 'yyyy-MM-dd' from file name pattern '/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/workspace/logs//testservercontroller.%d{yyyy-MM-dd}.%i.log'.
18:04:52,078 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@6f53b8a - Roll-over at midnight.
18:04:52,081 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@6f53b8a - Setting initial period to 2026-03-26T14:04:52.081Z
18:04:52,081 |-WARN in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@6f53b8a - Direct use of either SizeAndTimeBasedFNATP or SizeAndTimeBasedFileNamingAndTriggeringPolicy 
18:04:52,081 |-WARN in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@6f53b8a - is deprecated. Please use SizeAndTimeBasedRollingPolicy instead.
18:04:52,081 |-WARN in ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP@6f53b8a - For more information see https://logback.qos.ch/manual/appenders.html#SizeAndTimeBasedRollingPolicy
18:04:52,082 |-INFO in ch.qos.logback.core.model.processor.ImplicitModelHandler - Assuming default type [ch.qos.logback.classic.encoder.PatternLayoutEncoder] for [encoder] property
18:04:52,092 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[FILE] - Active log file name: /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/workspace/logs//testservercontroller.log
18:04:52,092 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[FILE] - File property is set to [/home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/workspace/logs//testservercontroller.log]
18:04:52,093 |-INFO in ch.qos.logback.classic.model.processor.RootLoggerModelHandler - Setting level of ROOT logger to TRACE
18:04:52,093 |-INFO in ch.qos.logback.core.model.processor.AppenderRefModelHandler - Attaching appender named [FILE] to Logger[ROOT]
18:04:52,093 |-INFO in ch.qos.logback.classic.model.processor.LoggerModelHandler - Setting level of logger [org.eclipse.jetty] to INFO
18:04:52,093 |-INFO in ch.qos.logback.classic.model.processor.LoggerModelHandler - Setting level of logger [io.netty] to INFO
18:04:52,093 |-INFO in ch.qos.logback.core.model.processor.DefaultProcessor@5c80cf32 - End of configuration.
18:04:52,093 |-INFO in ch.qos.logback.classic.joran.JoranConfigurator@7d900ecf - Registering current configuration as safe fallback point
18:04:52,093 |-INFO in ch.qos.logback.classic.util.ContextInitializer@71075444 - ch.qos.logback.classic.util.DefaultJoranConfigurator.configure() call lasted 78 milliseconds. ExecutionStatus=DO_NOT_INVOKE_NEXT_IF_ANY

.
Connected!
ci-run-maestro: TestServerController now running on port 8070 (pid 4095388)
Run Maestro using  and 5CQZiWqzxlYri

Evaluating workspace...

Uploading Flow(s)...

....................
╭──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╮
│                                                                                                                              │
│   Robin device specs:                                                                                                        │
│   * Maestro_ANDROID_pixel_6_android-33 - en_US                                                                               │
│                                                                                                                              │
│   To change OS version use this option: --android-api-level=<version>                                                        │
│                                                                                                                              │
│   To change device locale use this option: --device-locale=<device_locale>                                                   │
│                                                                                                                              │
│   To create a similar device locally, run: `maestro start-device --platform=android --os-version=33 --device-locale=en_US`   │
│                                                                                                                              │
╰──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯


Visit the web console for more details about the upload: https://app.robintest.com/project/proj_01k6wzp0pwf75vpcw8vw1gh0y8/maestro-test/app/app_01k6x3hyf9exztk0022nehadkk/upload/mupload_01kmn7cvzpe81a324d4hqa9g86

App binary id: 98342d0df291cbb30bb2a898f77fc866676a89df

Waiting for analyses to complete...

[Preparing Device] 002_user_add_apps_playlists_bookmarks_test (0s)
[Preparing Device] 001_005_add_school_self_registration_test (0s)
https://8060.ustadtesting.ustadmobile.com/api/directory/school ready
https://8061.ustadtesting.ustadmobile.com/api/directory/school ready
[Preparing Device] 001_001_invite_users_using_qr_code_or_link_test (0s)
https://8065.ustadtesting.ustadmobile.com/api/directory/school ready
[Preparing Device] 001_003_login_using_school_link_test (0s)
https://8067.ustadtesting.ustadmobile.com/api/directory/school ready
[Preparing Device] 003_admin_user_assigns_assignment_to_a_class_test (0s)
https://8067.ustadtesting.ustadmobile.com/api/directory/school ready
[Preparing Device] 001_002_add_user_direct_test (0s)
https://8068.ustadtesting.ustadmobile.com/api/directory/school ready
java.lang.IllegalStateException: url https://8061.ustadtesting.ustadmobile.com/api/directory/school not ready after 6000 ms
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl(OkHttpClientExt.kt:28)
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl$default(OkHttpClientExt.kt:6)
	at com.ustadmobile.testservercontroller.runner.TestServersRunner.startServer(TestServersRunner.kt:150)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invokeSuspend(TestServerControllerRoute.kt:28)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invokeSuspend(RoutingNode.kt:126)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.routing.RoutingRoot.executeResult(RoutingRoot.kt:212)
	at io.ktor.server.routing.RoutingRoot.interceptor(RoutingRoot.kt:71)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invokeSuspend(RoutingRoot.kt:156)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invokeSuspend(BaseApplicationEngine.kt:119)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invokeSuspend(DefaultEnginePipeline.kt:134)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invokeSuspend(BaseApplicationResponse.kt:349)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invokeSuspend(NettyApplicationCallHandler.kt:140)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at kotlinx.coroutines.intrinsics.UndispatchedKt.startCoroutineUndispatched(Undispatched.kt:20)
	at kotlinx.coroutines.CoroutineStart.invoke(CoroutineStart.kt:360)
	at kotlinx.coroutines.AbstractCoroutine.start(AbstractCoroutine.kt:134)
	at kotlinx.coroutines.BuildersKt__Builders_commonKt.launch(Builders.common.kt:53)
	at kotlinx.coroutines.BuildersKt.launch(Unknown Source)
	at io.ktor.server.netty.NettyApplicationCallHandler.handleRequest(NettyApplicationCallHandler.kt:41)
	at io.ktor.server.netty.NettyApplicationCallHandler.channelRead(NettyApplicationCallHandler.kt:33)
	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:356)
	at io.netty.channel.AbstractChannelHandlerContext.lambda$fireChannelRead$2(AbstractChannelHandlerContext.java:365)
	at io.netty.util.concurrent.AbstractEventExecutor.runTask(AbstractEventExecutor.java:148)
	at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:141)
	at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:507)
	at io.netty.channel.SingleThreadIoEventLoop.run(SingleThreadIoEventLoop.java:183)
	at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:1073)
	at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
	at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
	at java.base/java.lang.Thread.run(Thread.java:1583)
java.lang.IllegalStateException: url https://8061.ustadtesting.ustadmobile.com/api/directory/school not ready after 6000 ms
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl(OkHttpClientExt.kt:28)
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl$default(OkHttpClientExt.kt:6)
	at com.ustadmobile.testservercontroller.runner.TestServersRunner.startServer(TestServersRunner.kt:150)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invokeSuspend(TestServerControllerRoute.kt:28)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invokeSuspend(RoutingNode.kt:126)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.routing.RoutingRoot.executeResult(RoutingRoot.kt:212)
	at io.ktor.server.routing.RoutingRoot.interceptor(RoutingRoot.kt:71)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invokeSuspend(RoutingRoot.kt:156)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invokeSuspend(BaseApplicationEngine.kt:119)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invokeSuspend(DefaultEnginePipeline.kt:134)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invokeSuspend(BaseApplicationResponse.kt:349)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invokeSuspend(NettyApplicationCallHandler.kt:140)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at kotlinx.coroutines.intrinsics.UndispatchedKt.startCoroutineUndispatched(Undispatched.kt:20)
	at kotlinx.coroutines.CoroutineStart.invoke(CoroutineStart.kt:360)
	at kotlinx.coroutines.AbstractCoroutine.start(AbstractCoroutine.kt:134)
	at kotlinx.coroutines.BuildersKt__Builders_commonKt.launch(Builders.common.kt:53)
	at kotlinx.coroutines.BuildersKt.launch(Unknown Source)
	at io.ktor.server.netty.NettyApplicationCallHandler.handleRequest(NettyApplicationCallHandler.kt:41)
	at io.ktor.server.netty.NettyApplicationCallHandler.channelRead(NettyApplicationCallHandler.kt:33)
	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:356)
	at io.netty.channel.AbstractChannelHandlerContext.lambda$fireChannelRead$2(AbstractChannelHandlerContext.java:365)
	at io.netty.util.concurrent.AbstractEventExecutor.runTask(AbstractEventExecutor.java:148)
	at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:141)
	at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:507)
	at io.netty.channel.SingleThreadIoEventLoop.run(SingleThreadIoEventLoop.java:183)
	at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:1073)
	at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
	at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
	at java.base/java.lang.Thread.run(Thread.java:1583)
java.lang.IllegalStateException: url https://8062.ustadtesting.ustadmobile.com/api/directory/school not ready after 6000 ms
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl(OkHttpClientExt.kt:28)
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl$default(OkHttpClientExt.kt:6)
	at com.ustadmobile.testservercontroller.runner.TestServersRunner.startServer(TestServersRunner.kt:150)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invokeSuspend(TestServerControllerRoute.kt:28)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invokeSuspend(RoutingNode.kt:126)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.routing.RoutingRoot.executeResult(RoutingRoot.kt:212)
	at io.ktor.server.routing.RoutingRoot.interceptor(RoutingRoot.kt:71)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invokeSuspend(RoutingRoot.kt:156)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invokeSuspend(BaseApplicationEngine.kt:119)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invokeSuspend(DefaultEnginePipeline.kt:134)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invokeSuspend(BaseApplicationResponse.kt:349)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invokeSuspend(NettyApplicationCallHandler.kt:140)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at kotlinx.coroutines.intrinsics.UndispatchedKt.startCoroutineUndispatched(Undispatched.kt:20)
	at kotlinx.coroutines.CoroutineStart.invoke(CoroutineStart.kt:360)
	at kotlinx.coroutines.AbstractCoroutine.start(AbstractCoroutine.kt:134)
	at kotlinx.coroutines.BuildersKt__Builders_commonKt.launch(Builders.common.kt:53)
	at kotlinx.coroutines.BuildersKt.launch(Unknown Source)
	at io.ktor.server.netty.NettyApplicationCallHandler.handleRequest(NettyApplicationCallHandler.kt:41)
	at io.ktor.server.netty.NettyApplicationCallHandler.channelRead(NettyApplicationCallHandler.kt:33)
	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:356)
	at io.netty.channel.AbstractChannelHandlerContext.lambda$fireChannelRead$2(AbstractChannelHandlerContext.java:365)
	at io.netty.util.concurrent.AbstractEventExecutor.runTask(AbstractEventExecutor.java:148)
	at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:141)
	at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:507)
	at io.netty.channel.SingleThreadIoEventLoop.run(SingleThreadIoEventLoop.java:183)
	at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:1073)
	at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
	at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
	at java.base/java.lang.Thread.run(Thread.java:1583)
java.lang.IllegalStateException: url https://8066.ustadtesting.ustadmobile.com/api/directory/school not ready after 6000 ms
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl(OkHttpClientExt.kt:28)
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl$default(OkHttpClientExt.kt:6)
	at com.ustadmobile.testservercontroller.runner.TestServersRunner.startServer(TestServersRunner.kt:150)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invokeSuspend(TestServerControllerRoute.kt:28)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invokeSuspend(RoutingNode.kt:126)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.routing.RoutingRoot.executeResult(RoutingRoot.kt:212)
	at io.ktor.server.routing.RoutingRoot.interceptor(RoutingRoot.kt:71)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invokeSuspend(RoutingRoot.kt:156)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invokeSuspend(BaseApplicationEngine.kt:119)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invokeSuspend(DefaultEnginePipeline.kt:134)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invokeSuspend(BaseApplicationResponse.kt:349)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invokeSuspend(NettyApplicationCallHandler.kt:140)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at kotlinx.coroutines.intrinsics.UndispatchedKt.startCoroutineUndispatched(Undispatched.kt:20)
	at kotlinx.coroutines.CoroutineStart.invoke(CoroutineStart.kt:360)
	at kotlinx.coroutines.AbstractCoroutine.start(AbstractCoroutine.kt:134)
	at kotlinx.coroutines.BuildersKt__Builders_commonKt.launch(Builders.common.kt:53)
	at kotlinx.coroutines.BuildersKt.launch(Unknown Source)
	at io.ktor.server.netty.NettyApplicationCallHandler.handleRequest(NettyApplicationCallHandler.kt:41)
	at io.ktor.server.netty.NettyApplicationCallHandler.channelRead(NettyApplicationCallHandler.kt:33)
	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:356)
	at io.netty.channel.AbstractChannelHandlerContext.lambda$fireChannelRead$2(AbstractChannelHandlerContext.java:365)
	at io.netty.util.concurrent.AbstractEventExecutor.runTask(AbstractEventExecutor.java:148)
	at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:141)
	at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:507)
	at io.netty.channel.SingleThreadIoEventLoop.run(SingleThreadIoEventLoop.java:183)
	at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:1073)
	at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
	at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
	at java.base/java.lang.Thread.run(Thread.java:1583)
java.lang.IllegalStateException: url https://8066.ustadtesting.ustadmobile.com/api/directory/school not ready after 6000 ms
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl(OkHttpClientExt.kt:28)
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl$default(OkHttpClientExt.kt:6)
	at com.ustadmobile.testservercontroller.runner.TestServersRunner.startServer(TestServersRunner.kt:150)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invokeSuspend(TestServerControllerRoute.kt:28)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invokeSuspend(RoutingNode.kt:126)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.routing.RoutingRoot.executeResult(RoutingRoot.kt:212)
	at io.ktor.server.routing.RoutingRoot.interceptor(RoutingRoot.kt:71)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invokeSuspend(RoutingRoot.kt:156)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invokeSuspend(BaseApplicationEngine.kt:119)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invokeSuspend(DefaultEnginePipeline.kt:134)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invokeSuspend(BaseApplicationResponse.kt:349)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invokeSuspend(NettyApplicationCallHandler.kt:140)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at kotlinx.coroutines.intrinsics.UndispatchedKt.startCoroutineUndispatched(Undispatched.kt:20)
	at kotlinx.coroutines.CoroutineStart.invoke(CoroutineStart.kt:360)
	at kotlinx.coroutines.AbstractCoroutine.start(AbstractCoroutine.kt:134)
	at kotlinx.coroutines.BuildersKt__Builders_commonKt.launch(Builders.common.kt:53)
	at kotlinx.coroutines.BuildersKt.launch(Unknown Source)
	at io.ktor.server.netty.NettyApplicationCallHandler.handleRequest(NettyApplicationCallHandler.kt:41)
	at io.ktor.server.netty.NettyApplicationCallHandler.channelRead(NettyApplicationCallHandler.kt:33)
	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:356)
	at io.netty.channel.AbstractChannelHandlerContext.lambda$fireChannelRead$2(AbstractChannelHandlerContext.java:365)
	at io.netty.util.concurrent.AbstractEventExecutor.runTask(AbstractEventExecutor.java:148)
	at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:141)
	at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:507)
	at io.netty.channel.SingleThreadIoEventLoop.run(SingleThreadIoEventLoop.java:183)
	at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:1073)
	at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
	at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
	at java.base/java.lang.Thread.run(Thread.java:1583)
java.lang.IllegalStateException: url https://8063.ustadtesting.ustadmobile.com/api/directory/school not ready after 6000 ms
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl(OkHttpClientExt.kt:28)
	at com.ustadmobile.test.http.OkHttpClientExtKt.waitForUrl$default(OkHttpClientExt.kt:6)
	at com.ustadmobile.testservercontroller.runner.TestServersRunner.startServer(TestServersRunner.kt:150)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invokeSuspend(TestServerControllerRoute.kt:28)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at com.ustadmobile.testservercontroller.TestServerControllerRouteKt$TestServerControllerRoute$1$1.invoke(TestServerControllerRoute.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invokeSuspend(RoutingNode.kt:126)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.server.routing.RoutingNode$buildPipeline$1$1.invoke(RoutingNode.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.routing.RoutingRoot$executeResult$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.routing.RoutingRoot.executeResult(RoutingRoot.kt:212)
	at io.ktor.server.routing.RoutingRoot.interceptor(RoutingRoot.kt:71)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invokeSuspend(RoutingRoot.kt:156)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.server.routing.RoutingRoot$Plugin$install$1.invoke(RoutingRoot.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invokeSuspend(BaseApplicationEngine.kt:119)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.server.engine.BaseApplicationEngineKt$installDefaultTransformationChecker$1.invoke(BaseApplicationEngine.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invokeSuspend(DefaultEnginePipeline.kt:134)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.server.engine.DefaultEnginePipelineKt$defaultEnginePipeline$1.invoke(DefaultEnginePipeline.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invokeSuspend(BaseApplicationResponse.kt:349)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.server.engine.BaseApplicationResponse$Companion$setupFallbackResponse$1.invoke(BaseApplicationResponse.kt)
	at io.ktor.util.pipeline.PipelineJvmKt.pipelineStartCoroutineUninterceptedOrReturn(PipelineJvm.kt:15)
	at io.ktor.util.pipeline.SuspendFunctionGun.loop(SuspendFunctionGun.kt:131)
	at io.ktor.util.pipeline.SuspendFunctionGun.proceed(SuspendFunctionGun.kt:89)
	at io.ktor.util.pipeline.SuspendFunctionGun.execute$ktor_utils(SuspendFunctionGun.kt:109)
	at io.ktor.util.pipeline.Pipeline.execute(Pipeline.kt:92)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invokeSuspend(Pipeline.kt:510)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1$invokeSuspend$$inlined$execute$1.invoke(Pipeline.kt)
	at io.ktor.util.debug.ContextUtilsKt.initContextInDebugMode(ContextUtils.kt:19)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invokeSuspend(NettyApplicationCallHandler.kt:140)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at io.ktor.server.netty.NettyApplicationCallHandler$handleRequest$1.invoke(NettyApplicationCallHandler.kt)
	at kotlinx.coroutines.intrinsics.UndispatchedKt.startCoroutineUndispatched(Undispatched.kt:20)
	at kotlinx.coroutines.CoroutineStart.invoke(CoroutineStart.kt:360)
	at kotlinx.coroutines.AbstractCoroutine.start(AbstractCoroutine.kt:134)
	at kotlinx.coroutines.BuildersKt__Builders_commonKt.launch(Builders.common.kt:53)
	at kotlinx.coroutines.BuildersKt.launch(Unknown Source)
	at io.ktor.server.netty.NettyApplicationCallHandler.handleRequest(NettyApplicationCallHandler.kt:41)
	at io.ktor.server.netty.NettyApplicationCallHandler.channelRead(NettyApplicationCallHandler.kt:33)
	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:356)
	at io.netty.channel.AbstractChannelHandlerContext.lambda$fireChannelRead$2(AbstractChannelHandlerContext.java:365)
	at io.netty.util.concurrent.AbstractEventExecutor.runTask(AbstractEventExecutor.java:148)
	at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:141)
	at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:507)
	at io.netty.channel.SingleThreadIoEventLoop.run(SingleThreadIoEventLoop.java:183)
	at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:1073)
	at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
	at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
	at java.base/java.lang.Thread.run(Thread.java:1583)

2/6 Flows Failed

==== View details in the console ====

https://app.robintest.com/project/proj_01k6wzp0pwf75vpcw8vw1gh0y8/maestro-test/app/app_01k6x3hyf9exztk0022nehadkk/upload/mupload_01kmn7cvzpe81a324d4hqa9g86


Process will exit with code 1 (FAIL)
ci-run-maestro: Cloud run finished. Extracting URL from log file...
ci-run-maestro: Found URL: https://app.robintest.com/project/proj_01k6wzp0pwf75vpcw8vw1gh0y8/maestro-test/app/app_01k6x3hyf9exztk0022nehadkk/upload/mupload_01kmn7cvzpe81a324d4hqa9g86
ci-run-maestro: Navigating to downloader script...
Detected Maestro Cloud URL: https://app.robintest.com/project/proj_01k6wzp0pwf75vpcw8vw1gh0y8/maestro-test/app/app_01k6x3hyf9exztk0022nehadkk/upload/mupload_01kmn7cvzpe81a324d4hqa9g86
Starting Cypress to extract video URLs...

up to date, audited 176 packages in 872ms

40 packages are looking for funding
  run `npm fund` for details

3 vulnerabilities (1 low, 2 moderate)

To address all issues, run:
  npm audit fix

Run `npm audit` for details.

DevTools listening on ws://127.0.0.1:34047/devtools/browser/a4a2f72e-4ad4-4017-8adf-b1fceba6ff46

resize:  can't open terminal /dev/tty
tput: No value for $TERM and no -T specified
====================================================================================================

  (Run Starting)

  ┌────────────────────────────────────────────────────────────────────────────────────────────────┐
  │ Cypress:        14.0.0                                                                         │
  │ Browser:        Chrome 144 (headless)                                                          │
  │ Node Version:   v18.20.5 (/home/jenkins/.nvm/versions/node/v18.20.5/bin/node)                  │
  │ Specs:          1 found (extract-maestro-video-urls.cy.js)                                     │
  │ Searched:       cypress/e2e/**/*.cy.{js,jsx,ts,tsx}                                            │
  └────────────────────────────────────────────────────────────────────────────────────────────────┘


────────────────────────────────────────────────────────────────────────────────────────────────────
                                                                                                    
  Running:  extract-maestro-video-urls.cy.js                                                (1 of 1)


  Login, collect tests & Save Video URLs
    ✓ Login and save video URLs to text file (59832ms)


  1 passing (60s)


  (Results)

  ┌────────────────────────────────────────────────────────────────────────────────────────────────┐
  │ Tests:        1                                                                                │
  │ Passing:      1                                                                                │
  │ Failing:      0                                                                                │
  │ Pending:      0                                                                                │
  │ Skipped:      0                                                                                │
  │ Screenshots:  7                                                                                │
  │ Video:        false                                                                            │
  │ Duration:     59 seconds                                                                       │
  │ Spec Ran:     extract-maestro-video-urls.cy.js                                                 │
  └────────────────────────────────────────────────────────────────────────────────────────────────┘


  (Screenshots)

  -  /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/.maestro/video-d    (1000x1267)
     ownloader/cypress/screenshots/extract-maestro-video-urls.cy.js/00_Main_Dashboard               
     .png                                                                                           
  -  /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/.maestro/video-d    (1000x7635)
     ownloader/cypress/screenshots/extract-maestro-video-urls.cy.js/001_001_invite_us               
     ers_using_qr_code_or_link_test.png                                                             
  -  /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/.maestro/video-d   (1000x10365)
     ownloader/cypress/screenshots/extract-maestro-video-urls.cy.js/001_002_add_user_               
     direct_test.png                                                                                
  -  /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/.maestro/video-d    (1000x1843)
     ownloader/cypress/screenshots/extract-maestro-video-urls.cy.js/001_003_login_usi               
     ng_school_link_test.png                                                                        
  -  /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/.maestro/video-d    (1000x2929)
     ownloader/cypress/screenshots/extract-maestro-video-urls.cy.js/001_005_add_schoo               
     l_self_registration_test.png                                                                   
  -  /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/.maestro/video-d    (1000x7805)
     ownloader/cypress/screenshots/extract-maestro-video-urls.cy.js/002_user_add_apps               
     _playlists_bookmarks_test.png                                                                  
  -  /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/.maestro/video-d    (1000x6461)
     ownloader/cypress/screenshots/extract-maestro-video-urls.cy.js/003_admin_user_as               
     signs_assignment_to_a_class_test.png                                                           


resize:  can't open terminal /dev/tty
tput: No value for $TERM and no -T specified
====================================================================================================

  (Run Finished)


       Spec                                              Tests  Passing  Failing  Pending  Skipped  
  ┌────────────────────────────────────────────────────────────────────────────────────────────────┐
  │ ✔  extract-maestro-video-urls.cy.js         00:59        1        1        -        -        - │
  └────────────────────────────────────────────────────────────────────────────────────────────────┘
    ✔  All specs passed!                        00:59        1        1        -        -        -  

------------------------------------------------
Video URL file found. Starting downloads...
------------------------------------------------
Downloading: 001_001_invite_users_using_qr_code_or_link_test
Downloading: 001_002_add_user_direct_test
Downloading: 001_003_login_using_school_link_test
Downloading: 001_005_add_school_self_registration_test
Downloading: 002_user_add_apps_playlists_bookmarks_test
Downloading: 003_admin_user_assigns_assignment_to_a_class_test
------------------------------------------------
Downloads completed in cypress/downloads
-rw-r--r-- 1 jenkins jenkins  44M Mar 26 18:15 cypress/downloads/001_001_invite_users_using_qr_code_or_link_test.mp4
-rw-r--r-- 1 jenkins jenkins  51M Mar 26 18:27 cypress/downloads/001_002_add_user_direct_test.mp4
-rw-r--r-- 1 jenkins jenkins 5.4M Mar 26 18:10 cypress/downloads/001_003_login_using_school_link_test.mp4
-rw-r--r-- 1 jenkins jenkins  11M Mar 26 18:07 cypress/downloads/001_005_add_school_self_registration_test.mp4
-rw-r--r-- 1 jenkins jenkins 9.8M Mar 26 18:08 cypress/downloads/002_user_add_apps_playlists_bookmarks_test.mp4
-rw-r--r-- 1 jenkins jenkins  31M Mar 26 18:17 cypress/downloads/003_admin_user_assigns_assignment_to_a_class_test.mp4
Process completed successfully.
ci-run-maestro: Maestro test completed. Workspaces are in /home/jenkins/.jenkins/workspace/dev-playlists-end-to-end-tests/build/testservercontroller/workspace
ci-run-maestro: note 'No instance for key AttributeKey: KOIN_SCOPE' can be safely ignored
ci-run-maestro: Stopping TestServerController
ci-run-maestro: calling kill just in case (no such process error can be ignored)
Build step 'Execute shell' marked build as failure
Archiving artifacts
Finished: FAILURE