diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 8191721c36..57b693c330 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -58,9 +58,9 @@ They are placed in `maestro-android/build/outputs/apk`, and are copied over to `
Maestro requires 3 artifacts to run on iOS:
-- `maestro-driver-ios` - the host app for the test runner. Does nothing and is not installed.
-- `maestro-driver-iosUITests-Runner.app` - the test runner app. Starts an HTTP server inside an infinite XCTest.
-- `maestro-driver-ios-config.xctestrun` - the configuration file required to run the test runner app.
+- `maestro-driver` - the host app for the test runner. Does nothing and is not installed.
+- `maestro-driverUITests-Runner.app` - the test runner app. Starts an HTTP server inside an infinite XCTest.
+- `maestro-driver-config.xctestrun` - the configuration file required to run the test runner app.
These artifacts are built by the `build-maestro-ios-runner.sh` script. It places them in `maestro-ios-driver/src/main/resources`.
diff --git a/maestro-client/src/main/java/maestro/drivers/IOSDriver.kt b/maestro-client/src/main/java/maestro/drivers/IOSDriver.kt
index 672a2c9cdf..b221e47d57 100644
--- a/maestro-client/src/main/java/maestro/drivers/IOSDriver.kt
+++ b/maestro-client/src/main/java/maestro/drivers/IOSDriver.kt
@@ -130,25 +130,7 @@ class IOSDriver(
override fun pressKey(code: KeyCode) {
metrics.measured("operation", mapOf("command" to "pressKey")) {
- val keyCodeNameMap = mapOf(
- KeyCode.BACKSPACE to "delete",
- KeyCode.ENTER to "return",
- )
-
- val buttonNameMap = mapOf(
- KeyCode.HOME to "home",
- KeyCode.LOCK to "lock",
- )
-
- runDeviceCall("pressKey") {
- keyCodeNameMap[code]?.let { name ->
- iosDevice.pressKey(name)
- }
-
- buttonNameMap[code]?.let { name ->
- iosDevice.pressButton(name)
- }
- }
+ iosDevice.pressButton(code.description)
}
}
diff --git a/maestro-ios-driver/build.gradle.kts b/maestro-ios-driver/build.gradle.kts
index 04da74c4f3..632169bc9b 100644
--- a/maestro-ios-driver/build.gradle.kts
+++ b/maestro-ios-driver/build.gradle.kts
@@ -15,6 +15,7 @@ dependencies {
implementation(project(":maestro-utils"))
api(libs.square.okhttp)
+ api(libs.google.gson)
api(libs.square.okhttp.logs)
api(libs.jackson.module.kotlin)
api(libs.jarchivelib)
diff --git a/maestro-ios-driver/src/main/kotlin/xcuitest/installer/LocalXCTestInstaller.kt b/maestro-ios-driver/src/main/kotlin/xcuitest/installer/LocalXCTestInstaller.kt
index 8af21430dc..19313cfaab 100644
--- a/maestro-ios-driver/src/main/kotlin/xcuitest/installer/LocalXCTestInstaller.kt
+++ b/maestro-ios-driver/src/main/kotlin/xcuitest/installer/LocalXCTestInstaller.kt
@@ -13,6 +13,7 @@ import okio.source
import org.apache.commons.io.FileUtils
import org.rauschig.jarchivelib.ArchiverFactory
import org.slf4j.LoggerFactory
+import util.LocalSimulatorUtils
import util.XCRunnerCLIUtils
import xcuitest.XCTestClient
import java.io.File
@@ -176,25 +177,41 @@ class LocalXCTestInstaller(
return checkSuccessful
}
+ private fun isTV(deviceId: String): Boolean {
+ val list = LocalSimulatorUtils.list()
+ for (entry in list.devices.entries) {
+ for (device in entry.value) {
+ if (device.udid != deviceId) continue
+ if (device.deviceTypeIdentifier == null) continue
+ logger.trace("Device is an AppleTV")
+ return device.deviceTypeIdentifier.contains("Apple-TV")
+ }
+ }
+
+ return false
+ }
+
private fun startXCTestRunner() {
if (isChannelAlive()) {
logger.info("UI Test runner already running, returning")
return
}
+ val isTV = isTV(deviceId)
+
logger.info("[Start] Writing xctest run file")
val tempDir = File(tempDir).apply { mkdir() }
- val xctestRunFile = File("$tempDir/maestro-driver-ios-config.xctestrun")
- writeFileToDestination(XCTEST_RUN_PATH, xctestRunFile)
+ val xctestRunFile = File("${tempDir}/maestro-driver-config.xctestrun")
+ writeFileToDestination(XCTEST_RUN_PATH, xctestRunFile, isTV)
logger.info("[Done] Writing xctest run file")
- logger.info("[Start] Writing maestro-driver-iosUITests-Runner app")
- extractZipToApp("maestro-driver-iosUITests-Runner", UI_TEST_RUNNER_PATH)
- logger.info("[Done] Writing maestro-driver-iosUITests-Runner app")
+ logger.info("[Start] Writing maestro-driverUITests-Runner app")
+ extractZipToApp("maestro-driverUITests-Runner", UI_TEST_RUNNER_PATH, isTV)
+ logger.info("[Done] Writing maestro-driverUITests-Runner app")
- logger.info("[Start] Writing maestro-driver-ios app")
- extractZipToApp("maestro-driver-ios", UI_TEST_HOST_PATH)
- logger.info("[Done] Writing maestro-driver-ios app")
+ logger.info("[Start] Writing maestro-driver app")
+ extractZipToApp("maestro-driver", UI_TEST_HOST_PATH, isTV)
+ logger.info("[Done] Writing maestro-driver app")
logger.info("[Start] Running XcUITest with `xcodebuild test-without-building`")
xcTestProcess = XCRunnerCLIUtils.runXcTestWithoutBuild(
@@ -218,18 +235,25 @@ class LocalXCTestInstaller(
logger.info("[Done] Cleaning up the ui test runner files")
}
- private fun extractZipToApp(appFileName: String, srcAppPath: String) {
- val appFile = File("$tempDir/Debug-iphonesimulator").apply { mkdir() }
+ private fun extractZipToApp(appFileName: String, srcAppPath: String, isTV: Boolean) {
+ val appFile = when(isTV) {
+ true -> File("$tempDir/Debug-appletvsimulator").apply { mkdir() }
+ false -> File("$tempDir/Debug-iphonesimulator").apply { mkdir() }
+ }
val appZip = File("$tempDir/$appFileName.zip")
- writeFileToDestination(srcAppPath, appZip)
+ writeFileToDestination(srcAppPath, appZip, isTV)
ArchiverFactory.createArchiver(appZip).apply {
extract(appZip, appFile)
}
}
- private fun writeFileToDestination(srcPath: String, destFile: File) {
- LocalXCTestInstaller::class.java.getResourceAsStream(srcPath)?.let {
+ private fun writeFileToDestination(srcPath: String, destFile: File, isTV: Boolean) {
+ val prefix = when (isTV) {
+ true -> "/tvos/"
+ false -> "/ios/"
+ }
+ LocalXCTestInstaller::class.java.getResourceAsStream(prefix + srcPath)?.let {
val bufferedSink = destFile.sink().buffer()
bufferedSink.writeAll(it.source())
bufferedSink.flush()
@@ -237,11 +261,10 @@ class LocalXCTestInstaller(
}
companion object {
- private const val UI_TEST_RUNNER_PATH = "/maestro-driver-iosUITests-Runner.zip"
- private const val XCTEST_RUN_PATH = "/maestro-driver-ios-config.xctestrun"
- private const val UI_TEST_HOST_PATH = "/maestro-driver-ios.zip"
- private const val UI_TEST_RUNNER_APP_BUNDLE_ID =
- "dev.mobile.maestro-driver-iosUITests.xctrunner"
+ private const val UI_TEST_RUNNER_PATH = "maestro-driverUITests-Runner.zip"
+ private const val XCTEST_RUN_PATH = "maestro-driver-config.xctestrun"
+ private const val UI_TEST_HOST_PATH = "maestro-driver.zip"
+ private const val UI_TEST_RUNNER_APP_BUNDLE_ID = "dev.mobile.maestro-driverUITests.xctrunner"
private const val SERVER_LAUNCH_TIMEOUT_MS = 120000L
private const val MAESTRO_DRIVER_STARTUP_TIMEOUT = "MAESTRO_DRIVER_STARTUP_TIMEOUT"
diff --git a/maestro-ios-driver/src/main/resources/ios/maestro-driver-config.xctestrun b/maestro-ios-driver/src/main/resources/ios/maestro-driver-config.xctestrun
new file mode 100644
index 0000000000..101950495e
--- /dev/null
+++ b/maestro-ios-driver/src/main/resources/ios/maestro-driver-config.xctestrun
@@ -0,0 +1,300 @@
+
+
+
+
+ CodeCoverageBuildableInfos
+
+
+ Architectures
+
+ x86_64
+
+ BuildableIdentifier
+ FlyingFox:primary
+ IncludeInReport
+
+ IsStatic
+
+ Name
+ FlyingFox
+ ProductPaths
+
+ __TESTROOT__/Debug-iphonesimulator/PackageFrameworks/FlyingFox_-2E0323E0FD627E61_PackageProduct.framework/FlyingFox_-2E0323E0FD627E61_PackageProduct
+
+ SourceFiles
+
+ AsyncSequence+Extensions.swift
+ HTTPBodyPattern.swift
+ HTTPConnection.swift
+ HTTPDecoder.swift
+ HTTPEncoder.swift
+ HTTPHandler.swift
+ HTTPHeader.swift
+ HTTPLogging+OSLog.swift
+ HTTPLogging.swift
+ HTTPMethod.swift
+ HTTPRequest+QueryItem.swift
+ HTTPRequest.swift
+ HTTPResponse.swift
+ HTTPRoute.swift
+ HTTPServer+Listening.swift
+ HTTPServer.swift
+ HTTPStatusCode.swift
+ HTTPVersion.swift
+ Handlers/ClosureHTTPHandler.swift
+ Handlers/DirectoryHTTPHandler.swift
+ Handlers/FileHTTPHandler.swift
+ Handlers/ProxyHTTPHandler.swift
+ Handlers/RedirectHTTPHandler.swift
+ Handlers/RoutedHTTPHandler.swift
+ Handlers/WebSocketHTTPHandler.swift
+ SocketAddress+Glibc.swift
+ Task+Timeout.swift
+ URLSession+Async.swift
+ UncheckedSendable.swift
+ WebSocket/AsyncStream+WSFrame.swift
+ WebSocket/SHA1.swift
+ WebSocket/WSFrame.swift
+ WebSocket/WSFrameEncoder.swift
+ WebSocket/WSFrameValidator.swift
+ WebSocket/WSHandler.swift
+ WebSocket/WSMessage.swift
+
+ SourceFilesCommonPathPrefix
+ /Users/max.phillips/Library/Developer/Xcode/DerivedData/maestro-driver-ios-fvvxconyzcmjvwfefmqamltwvirm/SourcePackages/checkouts/FlyingFox/FlyingFox/Sources/
+ Toolchains
+
+ com.apple.dt.toolchain.XcodeDefault
+
+
+
+ Architectures
+
+ x86_64
+
+ BuildableIdentifier
+ 44F995232C9D6F8800D15B50:primary
+ IncludeInReport
+
+ IsStatic
+
+ Name
+ maestro-driver.app
+ ProductPaths
+
+ __TESTROOT__/Debug-iphonesimulator/maestro-driver.app/maestro-driver
+
+ SourceFiles
+
+ ContentView.swift
+ maestro_driverApp.swift
+
+ SourceFilesCommonPathPrefix
+ /Users/max.phillips/dev/maestro-tvos/maestro-ios-xctest-runner/maestro-driver/
+ Toolchains
+
+ com.apple.dt.toolchain.XcodeDefault
+
+
+
+ Architectures
+
+ x86_64
+
+ BuildableIdentifier
+ 52049BF2293503A200807AA3:primary
+ IncludeInReport
+
+ IsStatic
+
+ Name
+ maestro-driverUITests.xctest
+ ProductPaths
+
+ __TESTROOT__/Debug-iphonesimulator/maestro-driverUITests-Runner.app/PlugIns/maestro-driverUITests.xctest/maestro-driverUITests
+
+ SourceFiles
+
+ Routes/Extensions/Logger.swift
+ Routes/Extensions/StringExtensions.swift
+ Routes/Extensions/XCUIElement+Extensions.swift
+ Routes/Handlers/DeviceInfoHandler.swift
+ Routes/Handlers/EraseTextHandler.swift
+ Routes/Handlers/InputTextRouteHandler.swift
+ Routes/Handlers/KeyboardRouteHandler.swift
+ Routes/Handlers/PressButtonHandler.swift
+ Routes/Handlers/PressKeyHandler.swift
+ Routes/Handlers/RunningAppRouteHandler.swift
+ Routes/Handlers/ScreenDiffHandler.swift
+ Routes/Handlers/ScreenshotHandler.swift
+ Routes/Handlers/SetPermissionsHandler.swift
+ Routes/Handlers/StatusHandler.swift
+ Routes/Handlers/SwipeRouteHandler.swift
+ Routes/Handlers/SwipeRouteHandlerV2.swift
+ Routes/Handlers/TouchRouteHandler.swift
+ Routes/Handlers/ViewHierarchyHandler.swift
+ Routes/Helpers/AppError.swift
+ Routes/Helpers/ScreenSizeHelper.swift
+ Routes/Helpers/SystemPermissionHelper.swift
+ Routes/Helpers/TextInputHelper.swift
+ Routes/Helpers/TimeoutHelper.swift
+ Routes/Models/AXElement.swift
+ Routes/Models/DeviceInfoResponse.swift
+ Routes/Models/EraseTextRequest.swift
+ Routes/Models/GetRunningAppRequest.swift
+ Routes/Models/InputTextRequest.swift
+ Routes/Models/KeyboardHandlerRequest.swift
+ Routes/Models/KeyboardHandlerResponse.swift
+ Routes/Models/PressButtonRequest.swift
+ Routes/Models/PressKeyRequest.swift
+ Routes/Models/SetPermissionsRequest.swift
+ Routes/Models/StatusResponse.swift
+ Routes/Models/SwipeRequest.swift
+ Routes/Models/TouchRequest.swift
+ Routes/Models/ViewHierarchyRequest.swift
+ Routes/RouteHandlerFactory.swift
+ Routes/XCTest/AXClientSwizzler.swift
+ Routes/XCTest/EventRecord.swift
+ Routes/XCTest/EventTarget.swift
+ Routes/XCTest/KeyModifierFlags.swift
+ Routes/XCTest/PointerEventPath.swift
+ Routes/XCTest/RunnerDaemonProxy.swift
+ Routes/XCTest/RunningApp.swift
+ Routes/XCTestHTTPServer.swift
+ maestro_driver_iosUITests.swift
+
+ SourceFilesCommonPathPrefix
+ /Users/max.phillips/dev/maestro-tvos/maestro-ios-xctest-runner/maestro-driver-iosUITests/
+ Toolchains
+
+ com.apple.dt.toolchain.XcodeDefault
+
+
+
+ ContainerInfo
+
+ ContainerName
+ maestro-driver-ios
+ SchemeName
+ maestro-driver
+
+ TestConfigurations
+
+
+ Name
+ Test Scheme Action
+ TestTargets
+
+
+ BlueprintName
+ maestro-driverUITests
+ BlueprintProviderName
+ maestro-driver-ios
+ BlueprintProviderRelativePath
+ maestro-driver-ios.xcodeproj
+ BundleIdentifiersForCrashReportEmphasis
+
+ dev.mobile.maestro-driver
+ dev.mobile.maestro-driverUITests
+
+ ClangProfileDataDirectoryPath
+ __DERIVEDDATA__/Build/Intermediates.noindex/CodeCoverage/ProfileData
+ CommandLineArguments
+
+ DefaultTestExecutionTimeAllowance
+ 600
+ DependentProductPaths
+
+ __TESTROOT__/Debug-iphonesimulator/maestro-driver.app
+ __TESTROOT__/Debug-iphonesimulator/maestro-driverUITests-Runner.app
+ __TESTROOT__/Debug-iphonesimulator/maestro-driverUITests-Runner.app/PlugIns/maestro-driverUITests.xctest
+
+ DiagnosticCollectionPolicy
+ 1
+ EnvironmentVariables
+
+ APP_DISTRIBUTOR_ID_OVERRIDE
+ com.apple.AppStore
+ OS_ACTIVITY_DT_MODE
+ YES
+ SQLITE_ENABLE_THREAD_ASSERTIONS
+ 1
+ TERM
+ dumb
+
+ IsUITestBundle
+
+ IsXCTRunnerHostedTestBundle
+
+ PreferredScreenCaptureFormat
+ screenRecording
+ ProductModuleName
+ maestro_driverUITests
+ SystemAttachmentLifetime
+ deleteOnSuccess
+ TestBundlePath
+ __TESTHOST__/PlugIns/maestro-driverUITests.xctest
+ TestHostBundleIdentifier
+ dev.mobile.maestro-driverUITests.xctrunner
+ TestHostPath
+ __TESTROOT__/Debug-iphonesimulator/maestro-driverUITests-Runner.app
+ TestLanguage
+
+ TestRegion
+
+ TestTimeoutsEnabled
+
+ TestingEnvironmentVariables
+
+ DYLD_FRAMEWORK_PATH
+ __TESTROOT__/Debug-iphonesimulator:__TESTROOT__/Debug-iphonesimulator/PackageFrameworks:__PLATFORMS__/iPhoneSimulator.platform/Developer/Library/Frameworks
+ DYLD_LIBRARY_PATH
+ __TESTROOT__/Debug-iphonesimulator:__PLATFORMS__/iPhoneSimulator.platform/Developer/usr/lib
+ __XCODE_BUILT_PRODUCTS_DIR_PATHS
+ __TESTROOT__/Debug-iphonesimulator
+ __XPC_DYLD_FRAMEWORK_PATH
+ __TESTROOT__/Debug-iphonesimulator
+ __XPC_DYLD_LIBRARY_PATH
+ __TESTROOT__/Debug-iphonesimulator
+
+ ToolchainsSettingValue
+
+ UITargetAppCommandLineArguments
+
+ UITargetAppEnvironmentVariables
+
+ APP_DISTRIBUTOR_ID_OVERRIDE
+ com.apple.AppStore
+ DYLD_FRAMEWORK_PATH
+ __TESTROOT__/Debug-iphonesimulator:__TESTROOT__/Debug-iphonesimulator/PackageFrameworks
+ DYLD_LIBRARY_PATH
+ __TESTROOT__/Debug-iphonesimulator
+ __XCODE_BUILT_PRODUCTS_DIR_PATHS
+ __TESTROOT__/Debug-iphonesimulator
+ __XPC_DYLD_FRAMEWORK_PATH
+ __TESTROOT__/Debug-iphonesimulator
+ __XPC_DYLD_LIBRARY_PATH
+ __TESTROOT__/Debug-iphonesimulator
+
+ UITargetAppPath
+ __TESTROOT__/Debug-iphonesimulator/maestro-driver.app
+ UserAttachmentLifetime
+ deleteOnSuccess
+
+
+
+
+ TestPlan
+
+ IsDefault
+
+ Name
+ maestro-driver
+
+ __xctestrun_metadata__
+
+ FormatVersion
+ 2
+
+
+
diff --git a/maestro-ios-driver/src/main/resources/ios/maestro-driver.zip b/maestro-ios-driver/src/main/resources/ios/maestro-driver.zip
new file mode 100644
index 0000000000..68873f39b8
Binary files /dev/null and b/maestro-ios-driver/src/main/resources/ios/maestro-driver.zip differ
diff --git a/maestro-ios-driver/src/main/resources/ios/maestro-driverUITests-Runner.zip b/maestro-ios-driver/src/main/resources/ios/maestro-driverUITests-Runner.zip
new file mode 100644
index 0000000000..454d0a5fe4
Binary files /dev/null and b/maestro-ios-driver/src/main/resources/ios/maestro-driverUITests-Runner.zip differ
diff --git a/maestro-ios-driver/src/main/resources/maestro-driver-ios-config.xctestrun b/maestro-ios-driver/src/main/resources/maestro-driver-ios-config.xctestrun
deleted file mode 100644
index c5e7c04356..0000000000
--- a/maestro-ios-driver/src/main/resources/maestro-driver-ios-config.xctestrun
+++ /dev/null
@@ -1,113 +0,0 @@
-
-
-
-
- __xctestrun_metadata__
-
- ContainerInfo
-
- ContainerName
- maestro-driver-ios
- SchemeName
- maestro-driver-ios
-
- FormatVersion
- 1
-
- maestro-driver-iosUITests
-
- BlueprintName
- maestro-driver-iosUITests
- BlueprintProviderName
- maestro-driver-ios
- BlueprintProviderRelativePath
- maestro-driver-ios.xcodeproj
- BundleIdentifiersForCrashReportEmphasis
-
- dev.mobile.maestro-driver-ios
- dev.mobile.maestro-driver-iosUITests
-
- CommandLineArguments
-
- DefaultTestExecutionTimeAllowance
- 600
- DependentProductPaths
-
- __TESTROOT__/Debug-iphonesimulator/maestro-driver-ios.app
- __TESTROOT__/Debug-iphonesimulator/maestro-driver-iosUITests-Runner.app
- __TESTROOT__/Debug-iphonesimulator/maestro-driver-iosUITests-Runner.app/PlugIns/maestro-driver-iosUITests.xctest
-
- DiagnosticCollectionPolicy
- 1
- EnvironmentVariables
-
- APP_DISTRIBUTOR_ID_OVERRIDE
- com.apple.AppStore
- OS_ACTIVITY_DT_MODE
- YES
- SQLITE_ENABLE_THREAD_ASSERTIONS
- 1
-
- IsUITestBundle
-
- IsXCTRunnerHostedTestBundle
-
- PreferredScreenCaptureFormat
- screenRecording
- ProductModuleName
- maestro_driver_iosUITests
- RunOrder
- 0
- SystemAttachmentLifetime
- deleteOnSuccess
- TestBundlePath
- __TESTHOST__/PlugIns/maestro-driver-iosUITests.xctest
- TestHostBundleIdentifier
- dev.mobile.maestro-driver-iosUITests.xctrunner
- TestHostPath
- __TESTROOT__/Debug-iphonesimulator/maestro-driver-iosUITests-Runner.app
- TestLanguage
-
- TestRegion
-
- TestTimeoutsEnabled
-
- TestingEnvironmentVariables
-
- DYLD_FRAMEWORK_PATH
- __TESTROOT__/Debug-iphonesimulator:__TESTROOT__/Debug-iphonesimulator/PackageFrameworks:__PLATFORMS__/iPhoneSimulator.platform/Developer/Library/Frameworks
- DYLD_LIBRARY_PATH
- __TESTROOT__/Debug-iphonesimulator:__PLATFORMS__/iPhoneSimulator.platform/Developer/usr/lib
- __XCODE_BUILT_PRODUCTS_DIR_PATHS
- __TESTROOT__/Debug-iphonesimulator
- __XPC_DYLD_FRAMEWORK_PATH
- __TESTROOT__/Debug-iphonesimulator
- __XPC_DYLD_LIBRARY_PATH
- __TESTROOT__/Debug-iphonesimulator
-
- ToolchainsSettingValue
-
- UITargetAppCommandLineArguments
-
- UITargetAppEnvironmentVariables
-
- APP_DISTRIBUTOR_ID_OVERRIDE
- com.apple.AppStore
- DYLD_FRAMEWORK_PATH
- __TESTROOT__/Debug-iphonesimulator:__TESTROOT__/Debug-iphonesimulator/PackageFrameworks
- DYLD_LIBRARY_PATH
- __TESTROOT__/Debug-iphonesimulator
- __XCODE_BUILT_PRODUCTS_DIR_PATHS
- __TESTROOT__/Debug-iphonesimulator
- __XPC_DYLD_FRAMEWORK_PATH
- __TESTROOT__/Debug-iphonesimulator
- __XPC_DYLD_LIBRARY_PATH
- __TESTROOT__/Debug-iphonesimulator
-
- UITargetAppPath
- __TESTROOT__/Debug-iphonesimulator/maestro-driver-ios.app
- UserAttachmentLifetime
- deleteOnSuccess
-
-
-
diff --git a/maestro-ios-driver/src/main/resources/maestro-driver-ios.zip b/maestro-ios-driver/src/main/resources/maestro-driver-ios.zip
deleted file mode 100644
index a7e1ed2a58..0000000000
Binary files a/maestro-ios-driver/src/main/resources/maestro-driver-ios.zip and /dev/null differ
diff --git a/maestro-ios-driver/src/main/resources/maestro-driver-iosUITests-Runner.zip b/maestro-ios-driver/src/main/resources/maestro-driver-iosUITests-Runner.zip
deleted file mode 100644
index 653be4e4a4..0000000000
Binary files a/maestro-ios-driver/src/main/resources/maestro-driver-iosUITests-Runner.zip and /dev/null differ
diff --git a/maestro-ios-driver/src/main/resources/tvos/maestro-driver-config.xctestrun b/maestro-ios-driver/src/main/resources/tvos/maestro-driver-config.xctestrun
new file mode 100644
index 0000000000..98e553dbdb
--- /dev/null
+++ b/maestro-ios-driver/src/main/resources/tvos/maestro-driver-config.xctestrun
@@ -0,0 +1,237 @@
+
+
+
+
+ CodeCoverageBuildableInfos
+
+
+ Architectures
+
+ x86_64
+
+ BuildableIdentifier
+ 44F995232C9D6F8800D15B50:primary
+ IncludeInReport
+
+ IsStatic
+
+ Name
+ maestro-driver.app
+ ProductPaths
+
+ __TESTROOT__/Debug-appletvsimulator/maestro-driver.app/maestro-driver
+
+ SourceFiles
+
+ ContentView.swift
+ maestro_driverApp.swift
+
+ SourceFilesCommonPathPrefix
+ /Users/max.phillips/dev/maestro-tvos/maestro-ios-xctest-runner/maestro-driver/
+ Toolchains
+
+ com.apple.dt.toolchain.XcodeDefault
+
+
+
+ Architectures
+
+ x86_64
+
+ BuildableIdentifier
+ 52049BF2293503A200807AA3:primary
+ IncludeInReport
+
+ IsStatic
+
+ Name
+ maestro-driverUITests.xctest
+ ProductPaths
+
+ __TESTROOT__/Debug-appletvsimulator/maestro-driverUITests-Runner.app/PlugIns/maestro-driverUITests.xctest/maestro-driverUITests
+
+ SourceFiles
+
+ Routes/Extensions/Logger.swift
+ Routes/Extensions/StringExtensions.swift
+ Routes/Extensions/XCUIElement+Extensions.swift
+ Routes/Handlers/DeviceInfoHandler.swift
+ Routes/Handlers/EraseTextHandler.swift
+ Routes/Handlers/InputTextRouteHandler.swift
+ Routes/Handlers/KeyboardRouteHandler.swift
+ Routes/Handlers/PressButtonHandler.swift
+ Routes/Handlers/PressKeyHandler.swift
+ Routes/Handlers/RunningAppRouteHandler.swift
+ Routes/Handlers/ScreenDiffHandler.swift
+ Routes/Handlers/ScreenshotHandler.swift
+ Routes/Handlers/SetPermissionsHandler.swift
+ Routes/Handlers/StatusHandler.swift
+ Routes/Handlers/SwipeRouteHandler.swift
+ Routes/Handlers/SwipeRouteHandlerV2.swift
+ Routes/Handlers/TouchRouteHandler.swift
+ Routes/Handlers/ViewHierarchyHandler.swift
+ Routes/Helpers/AppError.swift
+ Routes/Helpers/ScreenSizeHelper.swift
+ Routes/Helpers/SystemPermissionHelper.swift
+ Routes/Helpers/TextInputHelper.swift
+ Routes/Helpers/TimeoutHelper.swift
+ Routes/Models/AXElement.swift
+ Routes/Models/DeviceInfoResponse.swift
+ Routes/Models/EraseTextRequest.swift
+ Routes/Models/GetRunningAppRequest.swift
+ Routes/Models/InputTextRequest.swift
+ Routes/Models/KeyboardHandlerRequest.swift
+ Routes/Models/KeyboardHandlerResponse.swift
+ Routes/Models/PressButtonRequest.swift
+ Routes/Models/PressKeyRequest.swift
+ Routes/Models/SetPermissionsRequest.swift
+ Routes/Models/StatusResponse.swift
+ Routes/Models/SwipeRequest.swift
+ Routes/Models/TouchRequest.swift
+ Routes/Models/ViewHierarchyRequest.swift
+ Routes/RouteHandlerFactory.swift
+ Routes/XCTest/AXClientSwizzler.swift
+ Routes/XCTest/EventRecord.swift
+ Routes/XCTest/EventTarget.swift
+ Routes/XCTest/KeyModifierFlags.swift
+ Routes/XCTest/PointerEventPath.swift
+ Routes/XCTest/RunnerDaemonProxy.swift
+ Routes/XCTest/RunningApp.swift
+ Routes/XCTestHTTPServer.swift
+ maestro_driver_iosUITests.swift
+
+ SourceFilesCommonPathPrefix
+ /Users/max.phillips/dev/maestro-tvos/maestro-ios-xctest-runner/maestro-driver-iosUITests/
+ Toolchains
+
+ com.apple.dt.toolchain.XcodeDefault
+
+
+
+ ContainerInfo
+
+ ContainerName
+ maestro-driver-ios
+ SchemeName
+ maestro-driver
+
+ TestConfigurations
+
+
+ Name
+ Test Scheme Action
+ TestTargets
+
+
+ BlueprintName
+ maestro-driverUITests
+ BlueprintProviderName
+ maestro-driver-ios
+ BlueprintProviderRelativePath
+ maestro-driver-ios.xcodeproj
+ BundleIdentifiersForCrashReportEmphasis
+
+ dev.mobile.maestro-driver
+ dev.mobile.maestro-driverUITests
+
+ ClangProfileDataDirectoryPath
+ __DERIVEDDATA__/Build/Intermediates.noindex/CodeCoverage/ProfileData
+ CommandLineArguments
+
+ DefaultTestExecutionTimeAllowance
+ 600
+ DependentProductPaths
+
+ __TESTROOT__/Debug-appletvsimulator/maestro-driver.app
+ __TESTROOT__/Debug-appletvsimulator/maestro-driverUITests-Runner.app
+ __TESTROOT__/Debug-appletvsimulator/maestro-driverUITests-Runner.app/PlugIns/maestro-driverUITests.xctest
+
+ DiagnosticCollectionPolicy
+ 1
+ EnvironmentVariables
+
+ APP_DISTRIBUTOR_ID_OVERRIDE
+ com.apple.AppStore
+ OS_ACTIVITY_DT_MODE
+ YES
+ SQLITE_ENABLE_THREAD_ASSERTIONS
+ 1
+ TERM
+ dumb
+
+ IsUITestBundle
+
+ IsXCTRunnerHostedTestBundle
+
+ PreferredScreenCaptureFormat
+ screenRecording
+ ProductModuleName
+ maestro_driverUITests
+ SystemAttachmentLifetime
+ deleteOnSuccess
+ TestBundlePath
+ __TESTHOST__/PlugIns/maestro-driverUITests.xctest
+ TestHostBundleIdentifier
+ dev.mobile.maestro-driverUITests.xctrunner
+ TestHostPath
+ __TESTROOT__/Debug-appletvsimulator/maestro-driverUITests-Runner.app
+ TestLanguage
+
+ TestRegion
+
+ TestTimeoutsEnabled
+
+ TestingEnvironmentVariables
+
+ DYLD_FRAMEWORK_PATH
+ __TESTROOT__/Debug-appletvsimulator:__TESTROOT__/Debug-appletvsimulator/PackageFrameworks:__PLATFORMS__/AppleTVSimulator.platform/Developer/Library/Frameworks
+ DYLD_LIBRARY_PATH
+ __TESTROOT__/Debug-appletvsimulator:__PLATFORMS__/AppleTVSimulator.platform/Developer/usr/lib
+ __XCODE_BUILT_PRODUCTS_DIR_PATHS
+ __TESTROOT__/Debug-appletvsimulator
+ __XPC_DYLD_FRAMEWORK_PATH
+ __TESTROOT__/Debug-appletvsimulator
+ __XPC_DYLD_LIBRARY_PATH
+ __TESTROOT__/Debug-appletvsimulator
+
+ ToolchainsSettingValue
+
+ UITargetAppCommandLineArguments
+
+ UITargetAppEnvironmentVariables
+
+ APP_DISTRIBUTOR_ID_OVERRIDE
+ com.apple.AppStore
+ DYLD_FRAMEWORK_PATH
+ __TESTROOT__/Debug-appletvsimulator:__TESTROOT__/Debug-appletvsimulator/PackageFrameworks
+ DYLD_LIBRARY_PATH
+ __TESTROOT__/Debug-appletvsimulator
+ __XCODE_BUILT_PRODUCTS_DIR_PATHS
+ __TESTROOT__/Debug-appletvsimulator
+ __XPC_DYLD_FRAMEWORK_PATH
+ __TESTROOT__/Debug-appletvsimulator
+ __XPC_DYLD_LIBRARY_PATH
+ __TESTROOT__/Debug-appletvsimulator
+
+ UITargetAppPath
+ __TESTROOT__/Debug-appletvsimulator/maestro-driver.app
+ UserAttachmentLifetime
+ deleteOnSuccess
+
+
+
+
+ TestPlan
+
+ IsDefault
+
+ Name
+ maestro-driver
+
+ __xctestrun_metadata__
+
+ FormatVersion
+ 2
+
+
+
diff --git a/maestro-ios-driver/src/main/resources/tvos/maestro-driver.zip b/maestro-ios-driver/src/main/resources/tvos/maestro-driver.zip
new file mode 100644
index 0000000000..e1935bc506
Binary files /dev/null and b/maestro-ios-driver/src/main/resources/tvos/maestro-driver.zip differ
diff --git a/maestro-ios-driver/src/main/resources/tvos/maestro-driverUITests-Runner.zip b/maestro-ios-driver/src/main/resources/tvos/maestro-driverUITests-Runner.zip
new file mode 100644
index 0000000000..5e0dc4b449
Binary files /dev/null and b/maestro-ios-driver/src/main/resources/tvos/maestro-driverUITests-Runner.zip differ
diff --git a/maestro-ios-xctest-runner/build-maestro-ios-runner.sh b/maestro-ios-xctest-runner/build-maestro-ios-runner.sh
index 4ef34f5617..2ecb2370a0 100755
--- a/maestro-ios-xctest-runner/build-maestro-ios-runner.sh
+++ b/maestro-ios-xctest-runner/build-maestro-ios-runner.sh
@@ -12,7 +12,7 @@ xcodebuild \
ARCHS="x86_64 arm64" \
ONLY_ACTIVE_ARCH=NO \
-project ./maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj \
- -scheme maestro-driver-ios \
+ -scheme maestro-driver \
-sdk iphonesimulator \
-destination "generic/platform=iOS Simulator" \
-IDEBuildLocationStyle=Custom \
@@ -20,19 +20,46 @@ xcodebuild \
-IDECustomBuildProductsPath="$PWD/build/Products" \
build-for-testing
+xcodebuild \
+ ARCHS="x86_64 arm64" \
+ ONLY_ACTIVE_ARCH=NO \
+ -project ./maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj \
+ -scheme maestro-driver \
+ -sdk appletvsimulator \
+ -destination "generic/platform=tvOS Simulator" \
+ -IDEBuildLocationStyle=Custom \
+ -IDECustomBuildLocationType=Absolute \
+ -IDECustomBuildProductsPath="$PWD/build/Products" \
+ build-for-testing
+
## Remove intermediates, output and copy runner in maestro-ios-driver
cp -r \
- ./build/Products/Debug-iphonesimulator/maestro-driver-iosUITests-Runner.app \
- ./maestro-ios-driver/src/main/resources/maestro-driver-iosUITests-Runner.app
+ ./build/Products/Debug-iphonesimulator/maestro-driverUITests-Runner.app \
+ ./maestro-ios-driver/src/main/resources/ios/maestro-driverUITests-Runner.app
+
+cp -r \
+ ./build/Products/Debug-appletvsimulator/maestro-driverUITests-Runner.app \
+ ./maestro-ios-driver/src/main/resources/tvos/maestro-driverUITests-Runner.app
cp -r \
- ./build/Products/Debug-iphonesimulator/maestro-driver-ios.app \
- ./maestro-ios-driver/src/main/resources/maestro-driver-ios.app
+ ./build/Products/Debug-iphonesimulator/maestro-driver.app \
+ ./maestro-ios-driver/src/main/resources/ios/maestro-driver.app
+
+cp -r \
+ ./build/Products/Debug-appletvsimulator/maestro-driver.app \
+ ./maestro-ios-driver/src/main/resources/tvos/maestro-driver.app
+
+cp \
+ ./build/Products/*iphonesimulator*.xctestrun \
+ ./maestro-ios-driver/src/main/resources/ios/maestro-driver-config.xctestrun
cp \
- ./build/Products/*.xctestrun \
- ./maestro-ios-driver/src/main/resources/maestro-driver-ios-config.xctestrun
+ ./build/Products/*appletvsimulator*.xctestrun \
+ ./maestro-ios-driver/src/main/resources/tvos/maestro-driver-config.xctestrun
-(cd ./maestro-ios-driver/src/main/resources && zip -r maestro-driver-iosUITests-Runner.zip ./maestro-driver-iosUITests-Runner.app)
-(cd ./maestro-ios-driver/src/main/resources && zip -r maestro-driver-ios.zip ./maestro-driver-ios.app)
-rm -r ./maestro-ios-driver/src/main/resources/*.app
+(cd ./maestro-ios-driver/src/main/resources/ios && zip -r maestro-driverUITests-Runner.zip ./maestro-driverUITests-Runner.app)
+(cd ./maestro-ios-driver/src/main/resources/tvos && zip -r maestro-driverUITests-Runner.zip ./maestro-driverUITests-Runner.app)
+(cd ./maestro-ios-driver/src/main/resources/ios && zip -r maestro-driver.zip ./maestro-driver.app)
+(cd ./maestro-ios-driver/src/main/resources/tvos && zip -r maestro-driver.zip ./maestro-driver.app)
+rm -r ./maestro-ios-driver/src/main/resources/ios/*.app
+rm -r ./maestro-ios-driver/src/main/resources/tvos/*.app
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/project.pbxproj b/maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/project.pbxproj
index 8096a1a12d..55fc1df878 100644
--- a/maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/project.pbxproj
+++ b/maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/project.pbxproj
@@ -3,7 +3,7 @@
archiveVersion = 1;
classes = {
};
- objectVersion = 55;
+ objectVersion = 70;
objects = {
/* Begin PBXBuildFile section */
@@ -14,12 +14,6 @@
32ECCB262980449200A1A0A0 /* TouchRequest.swift in Sources */ = {isa = PBXBuildFile; fileRef = 32ECCB252980449200A1A0A0 /* TouchRequest.swift */; };
32ECCB28298044C200A1A0A0 /* TouchRouteHandler.swift in Sources */ = {isa = PBXBuildFile; fileRef = 32ECCB27298044C200A1A0A0 /* TouchRouteHandler.swift */; };
52047F782A7A638E00BF982D /* StatusHandler.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52047F772A7A638E00BF982D /* StatusHandler.swift */; };
- 52049BD72935039F00807AA3 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52049BD62935039F00807AA3 /* AppDelegate.swift */; };
- 52049BD92935039F00807AA3 /* SceneDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52049BD82935039F00807AA3 /* SceneDelegate.swift */; };
- 52049BDB2935039F00807AA3 /* ViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52049BDA2935039F00807AA3 /* ViewController.swift */; };
- 52049BDE2935039F00807AA3 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 52049BDC2935039F00807AA3 /* Main.storyboard */; };
- 52049BE0293503A200807AA3 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 52049BDF293503A200807AA3 /* Assets.xcassets */; };
- 52049BE3293503A200807AA3 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 52049BE1293503A200807AA3 /* LaunchScreen.storyboard */; };
52049BF8293503A200807AA3 /* maestro_driver_iosUITests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52049BF7293503A200807AA3 /* maestro_driver_iosUITests.swift */; };
522785812A54410D008DBC0A /* AppError.swift in Sources */ = {isa = PBXBuildFile; fileRef = 522785802A54410D008DBC0A /* AppError.swift */; };
5279BFD62935ECE20056C609 /* FlyingFox in Frameworks */ = {isa = PBXBuildFile; productRef = 5279BFD52935ECE20056C609 /* FlyingFox */; };
@@ -65,12 +59,12 @@
/* End PBXBuildFile section */
/* Begin PBXContainerItemProxy section */
- 52049BF4293503A200807AA3 /* PBXContainerItemProxy */ = {
+ 44F995322C9D6FB500D15B50 /* PBXContainerItemProxy */ = {
isa = PBXContainerItemProxy;
containerPortal = 52049BCB2935039F00807AA3 /* Project object */;
proxyType = 1;
- remoteGlobalIDString = 52049BD22935039F00807AA3;
- remoteInfo = "maestro-driver-ios";
+ remoteGlobalIDString = 44F995232C9D6F8800D15B50;
+ remoteInfo = "maestro-driver";
};
/* End PBXContainerItemProxy section */
@@ -81,16 +75,9 @@
32762AF92966DC8300FB69BD /* SwipeRequest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SwipeRequest.swift; sourceTree = ""; };
32ECCB252980449200A1A0A0 /* TouchRequest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TouchRequest.swift; sourceTree = ""; };
32ECCB27298044C200A1A0A0 /* TouchRouteHandler.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TouchRouteHandler.swift; sourceTree = ""; };
+ 44F995242C9D6F8800D15B50 /* maestro-driver.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "maestro-driver.app"; sourceTree = BUILT_PRODUCTS_DIR; };
52047F772A7A638E00BF982D /* StatusHandler.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StatusHandler.swift; sourceTree = ""; };
- 52049BD32935039F00807AA3 /* maestro-driver-ios.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "maestro-driver-ios.app"; sourceTree = BUILT_PRODUCTS_DIR; };
- 52049BD62935039F00807AA3 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; };
- 52049BD82935039F00807AA3 /* SceneDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SceneDelegate.swift; sourceTree = ""; };
- 52049BDA2935039F00807AA3 /* ViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewController.swift; sourceTree = ""; };
- 52049BDD2935039F00807AA3 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = ""; };
- 52049BDF293503A200807AA3 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; };
- 52049BE2293503A200807AA3 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; };
- 52049BE4293503A200807AA3 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
- 52049BF3293503A200807AA3 /* maestro-driver-iosUITests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "maestro-driver-iosUITests.xctest"; sourceTree = BUILT_PRODUCTS_DIR; };
+ 52049BF3293503A200807AA3 /* maestro-driverUITests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "maestro-driverUITests.xctest"; sourceTree = BUILT_PRODUCTS_DIR; };
52049BF7293503A200807AA3 /* maestro_driver_iosUITests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = maestro_driver_iosUITests.swift; sourceTree = ""; };
522785802A54410D008DBC0A /* AppError.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppError.swift; sourceTree = ""; };
52E35D422A654F67001D97A8 /* RunningApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunningApp.swift; sourceTree = ""; };
@@ -134,8 +121,12 @@
F328D3E52A2A98E7000546D3 /* StringExtensions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StringExtensions.swift; sourceTree = ""; };
/* End PBXFileReference section */
+/* Begin PBXFileSystemSynchronizedRootGroup section */
+ 44F995252C9D6F8800D15B50 /* maestro-driver */ = {isa = PBXFileSystemSynchronizedRootGroup; explicitFileTypes = {}; explicitFolders = (); path = "maestro-driver"; sourceTree = ""; };
+/* End PBXFileSystemSynchronizedRootGroup section */
+
/* Begin PBXFrameworksBuildPhase section */
- 52049BD02935039F00807AA3 /* Frameworks */ = {
+ 44F995212C9D6F8800D15B50 /* Frameworks */ = {
isa = PBXFrameworksBuildPhase;
buildActionMask = 2147483647;
files = (
@@ -157,8 +148,8 @@
52049BCA2935039F00807AA3 = {
isa = PBXGroup;
children = (
- 52049BD52935039F00807AA3 /* maestro-driver-ios */,
52049BF6293503A200807AA3 /* maestro-driver-iosUITests */,
+ 44F995252C9D6F8800D15B50 /* maestro-driver */,
52049BD42935039F00807AA3 /* Products */,
5279BFD42935ECE20056C609 /* Frameworks */,
);
@@ -167,26 +158,12 @@
52049BD42935039F00807AA3 /* Products */ = {
isa = PBXGroup;
children = (
- 52049BD32935039F00807AA3 /* maestro-driver-ios.app */,
- 52049BF3293503A200807AA3 /* maestro-driver-iosUITests.xctest */,
+ 52049BF3293503A200807AA3 /* maestro-driverUITests.xctest */,
+ 44F995242C9D6F8800D15B50 /* maestro-driver.app */,
);
name = Products;
sourceTree = "";
};
- 52049BD52935039F00807AA3 /* maestro-driver-ios */ = {
- isa = PBXGroup;
- children = (
- 52049BD62935039F00807AA3 /* AppDelegate.swift */,
- 52049BD82935039F00807AA3 /* SceneDelegate.swift */,
- 52049BDA2935039F00807AA3 /* ViewController.swift */,
- 52049BDC2935039F00807AA3 /* Main.storyboard */,
- 52049BDF293503A200807AA3 /* Assets.xcassets */,
- 52049BE1293503A200807AA3 /* LaunchScreen.storyboard */,
- 52049BE4293503A200807AA3 /* Info.plist */,
- );
- path = "maestro-driver-ios";
- sourceTree = "";
- };
52049BF6293503A200807AA3 /* maestro-driver-iosUITests */ = {
isa = PBXGroup;
children = (
@@ -300,28 +277,31 @@
/* End PBXGroup section */
/* Begin PBXNativeTarget section */
- 52049BD22935039F00807AA3 /* maestro-driver-ios */ = {
+ 44F995232C9D6F8800D15B50 /* maestro-driver */ = {
isa = PBXNativeTarget;
- buildConfigurationList = 52049BFD293503A200807AA3 /* Build configuration list for PBXNativeTarget "maestro-driver-ios" */;
+ buildConfigurationList = 44F995312C9D6F8900D15B50 /* Build configuration list for PBXNativeTarget "maestro-driver" */;
buildPhases = (
- 52049BCF2935039F00807AA3 /* Sources */,
- 52049BD02935039F00807AA3 /* Frameworks */,
- 52049BD12935039F00807AA3 /* Resources */,
+ 44F995202C9D6F8800D15B50 /* Sources */,
+ 44F995212C9D6F8800D15B50 /* Frameworks */,
+ 44F995222C9D6F8800D15B50 /* Resources */,
);
buildRules = (
);
dependencies = (
);
- name = "maestro-driver-ios";
+ fileSystemSynchronizedGroups = (
+ 44F995252C9D6F8800D15B50 /* maestro-driver */,
+ );
+ name = "maestro-driver";
packageProductDependencies = (
);
- productName = "maestro-driver-ios";
- productReference = 52049BD32935039F00807AA3 /* maestro-driver-ios.app */;
+ productName = "maestro-driver";
+ productReference = 44F995242C9D6F8800D15B50 /* maestro-driver.app */;
productType = "com.apple.product-type.application";
};
- 52049BF2293503A200807AA3 /* maestro-driver-iosUITests */ = {
+ 52049BF2293503A200807AA3 /* maestro-driverUITests */ = {
isa = PBXNativeTarget;
- buildConfigurationList = 52049C03293503A200807AA3 /* Build configuration list for PBXNativeTarget "maestro-driver-iosUITests" */;
+ buildConfigurationList = 52049C03293503A200807AA3 /* Build configuration list for PBXNativeTarget "maestro-driverUITests" */;
buildPhases = (
52049BEF293503A200807AA3 /* Sources */,
52049BF0293503A200807AA3 /* Frameworks */,
@@ -330,14 +310,14 @@
buildRules = (
);
dependencies = (
- 52049BF5293503A200807AA3 /* PBXTargetDependency */,
+ 44F995332C9D6FB500D15B50 /* PBXTargetDependency */,
);
- name = "maestro-driver-iosUITests";
+ name = "maestro-driverUITests";
packageProductDependencies = (
5279BFD52935ECE20056C609 /* FlyingFox */,
);
productName = "maestro-driver-iosUITests";
- productReference = 52049BF3293503A200807AA3 /* maestro-driver-iosUITests.xctest */;
+ productReference = 52049BF3293503A200807AA3 /* maestro-driverUITests.xctest */;
productType = "com.apple.product-type.bundle.ui-testing";
};
/* End PBXNativeTarget section */
@@ -347,16 +327,16 @@
isa = PBXProject;
attributes = {
BuildIndependentTargetsInParallel = 1;
- LastSwiftUpdateCheck = 1340;
+ LastSwiftUpdateCheck = 1600;
LastUpgradeCheck = 1340;
TargetAttributes = {
- 52049BD22935039F00807AA3 = {
- CreatedOnToolsVersion = 13.4.1;
+ 44F995232C9D6F8800D15B50 = {
+ CreatedOnToolsVersion = 16.0;
};
52049BF2293503A200807AA3 = {
CreatedOnToolsVersion = 13.4.1;
LastSwiftMigration = 1430;
- TestTargetID = 52049BD22935039F00807AA3;
+ TestTargetID = 44F995232C9D6F8800D15B50;
};
};
};
@@ -376,20 +356,17 @@
projectDirPath = "";
projectRoot = "";
targets = (
- 52049BD22935039F00807AA3 /* maestro-driver-ios */,
- 52049BF2293503A200807AA3 /* maestro-driver-iosUITests */,
+ 44F995232C9D6F8800D15B50 /* maestro-driver */,
+ 52049BF2293503A200807AA3 /* maestro-driverUITests */,
);
};
/* End PBXProject section */
/* Begin PBXResourcesBuildPhase section */
- 52049BD12935039F00807AA3 /* Resources */ = {
+ 44F995222C9D6F8800D15B50 /* Resources */ = {
isa = PBXResourcesBuildPhase;
buildActionMask = 2147483647;
files = (
- 52049BE3293503A200807AA3 /* LaunchScreen.storyboard in Resources */,
- 52049BE0293503A200807AA3 /* Assets.xcassets in Resources */,
- 52049BDE2935039F00807AA3 /* Main.storyboard in Resources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
@@ -403,13 +380,10 @@
/* End PBXResourcesBuildPhase section */
/* Begin PBXSourcesBuildPhase section */
- 52049BCF2935039F00807AA3 /* Sources */ = {
+ 44F995202C9D6F8800D15B50 /* Sources */ = {
isa = PBXSourcesBuildPhase;
buildActionMask = 2147483647;
files = (
- 52049BDB2935039F00807AA3 /* ViewController.swift in Sources */,
- 52049BD72935039F00807AA3 /* AppDelegate.swift in Sources */,
- 52049BD92935039F00807AA3 /* SceneDelegate.swift in Sources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
@@ -470,33 +444,87 @@
/* End PBXSourcesBuildPhase section */
/* Begin PBXTargetDependency section */
- 52049BF5293503A200807AA3 /* PBXTargetDependency */ = {
+ 44F995332C9D6FB500D15B50 /* PBXTargetDependency */ = {
isa = PBXTargetDependency;
- target = 52049BD22935039F00807AA3 /* maestro-driver-ios */;
- targetProxy = 52049BF4293503A200807AA3 /* PBXContainerItemProxy */;
+ target = 44F995232C9D6F8800D15B50 /* maestro-driver */;
+ targetProxy = 44F995322C9D6FB500D15B50 /* PBXContainerItemProxy */;
};
/* End PBXTargetDependency section */
-/* Begin PBXVariantGroup section */
- 52049BDC2935039F00807AA3 /* Main.storyboard */ = {
- isa = PBXVariantGroup;
- children = (
- 52049BDD2935039F00807AA3 /* Base */,
- );
- name = Main.storyboard;
- sourceTree = "";
+/* Begin XCBuildConfiguration section */
+ 44F9952F2C9D6F8900D15B50 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES;
+ ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++20";
+ CODE_SIGN_STYLE = Automatic;
+ CURRENT_PROJECT_VERSION = 1;
+ DEVELOPMENT_ASSET_PATHS = "\"maestro-driver/Preview Content\"";
+ ENABLE_PREVIEWS = YES;
+ ENABLE_USER_SCRIPT_SANDBOXING = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu17;
+ GENERATE_INFOPLIST_FILE = YES;
+ INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES;
+ INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES;
+ INFOPLIST_KEY_UILaunchScreen_Generation = YES;
+ INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
+ INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
+ IPHONEOS_DEPLOYMENT_TARGET = 18.0;
+ LD_RUNPATH_SEARCH_PATHS = (
+ "$(inherited)",
+ "@executable_path/Frameworks",
+ );
+ LOCALIZATION_PREFERS_STRING_CATALOGS = YES;
+ MARKETING_VERSION = 1.0;
+ PRODUCT_BUNDLE_IDENTIFIER = "dev.mobile.maestro-driver";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SUPPORTED_PLATFORMS = "appletvos appletvsimulator iphoneos iphonesimulator";
+ SUPPORTS_MACCATALYST = NO;
+ SWIFT_ACTIVE_COMPILATION_CONDITIONS = "DEBUG $(inherited)";
+ SWIFT_EMIT_LOC_STRINGS = YES;
+ SWIFT_VERSION = 5.0;
+ TARGETED_DEVICE_FAMILY = "1,2,3";
+ };
+ name = Debug;
};
- 52049BE1293503A200807AA3 /* LaunchScreen.storyboard */ = {
- isa = PBXVariantGroup;
- children = (
- 52049BE2293503A200807AA3 /* Base */,
- );
- name = LaunchScreen.storyboard;
- sourceTree = "";
+ 44F995302C9D6F8900D15B50 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES;
+ ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++20";
+ CODE_SIGN_STYLE = Automatic;
+ CURRENT_PROJECT_VERSION = 1;
+ DEVELOPMENT_ASSET_PATHS = "\"maestro-driver/Preview Content\"";
+ ENABLE_PREVIEWS = YES;
+ ENABLE_USER_SCRIPT_SANDBOXING = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu17;
+ GENERATE_INFOPLIST_FILE = YES;
+ INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES;
+ INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES;
+ INFOPLIST_KEY_UILaunchScreen_Generation = YES;
+ INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
+ INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
+ IPHONEOS_DEPLOYMENT_TARGET = 18.0;
+ LD_RUNPATH_SEARCH_PATHS = (
+ "$(inherited)",
+ "@executable_path/Frameworks",
+ );
+ LOCALIZATION_PREFERS_STRING_CATALOGS = YES;
+ MARKETING_VERSION = 1.0;
+ PRODUCT_BUNDLE_IDENTIFIER = "dev.mobile.maestro-driver";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SUPPORTED_PLATFORMS = "appletvos appletvsimulator iphoneos iphonesimulator";
+ SUPPORTS_MACCATALYST = NO;
+ SWIFT_EMIT_LOC_STRINGS = YES;
+ SWIFT_VERSION = 5.0;
+ TARGETED_DEVICE_FAMILY = "1,2,3";
+ };
+ name = Release;
};
-/* End PBXVariantGroup section */
-
-/* Begin XCBuildConfiguration section */
52049BFB293503A200807AA3 /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
@@ -610,64 +638,6 @@
};
name = Release;
};
- 52049BFE293503A200807AA3 /* Debug */ = {
- isa = XCBuildConfiguration;
- buildSettings = {
- ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
- ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor;
- CODE_SIGN_STYLE = Automatic;
- CURRENT_PROJECT_VERSION = 1;
- DEVELOPMENT_TEAM = "";
- GENERATE_INFOPLIST_FILE = YES;
- INFOPLIST_FILE = "maestro-driver-ios/Info.plist";
- INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES;
- INFOPLIST_KEY_UILaunchStoryboardName = LaunchScreen;
- INFOPLIST_KEY_UIMainStoryboardFile = Main;
- INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
- INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
- IPHONEOS_DEPLOYMENT_TARGET = 14.0;
- LD_RUNPATH_SEARCH_PATHS = (
- "$(inherited)",
- "@executable_path/Frameworks",
- );
- MARKETING_VERSION = 1.0;
- PRODUCT_BUNDLE_IDENTIFIER = "dev.mobile.maestro-driver-ios";
- PRODUCT_NAME = "$(TARGET_NAME)";
- SWIFT_EMIT_LOC_STRINGS = YES;
- SWIFT_VERSION = 5.0;
- TARGETED_DEVICE_FAMILY = "1,2";
- };
- name = Debug;
- };
- 52049BFF293503A200807AA3 /* Release */ = {
- isa = XCBuildConfiguration;
- buildSettings = {
- ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
- ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor;
- CODE_SIGN_STYLE = Automatic;
- CURRENT_PROJECT_VERSION = 1;
- DEVELOPMENT_TEAM = "";
- GENERATE_INFOPLIST_FILE = YES;
- INFOPLIST_FILE = "maestro-driver-ios/Info.plist";
- INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES;
- INFOPLIST_KEY_UILaunchStoryboardName = LaunchScreen;
- INFOPLIST_KEY_UIMainStoryboardFile = Main;
- INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
- INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
- IPHONEOS_DEPLOYMENT_TARGET = 14.0;
- LD_RUNPATH_SEARCH_PATHS = (
- "$(inherited)",
- "@executable_path/Frameworks",
- );
- MARKETING_VERSION = 1.0;
- PRODUCT_BUNDLE_IDENTIFIER = "dev.mobile.maestro-driver-ios";
- PRODUCT_NAME = "$(TARGET_NAME)";
- SWIFT_EMIT_LOC_STRINGS = YES;
- SWIFT_VERSION = 5.0;
- TARGETED_DEVICE_FAMILY = "1,2";
- };
- name = Release;
- };
52049C04293503A200807AA3 /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
@@ -675,7 +645,7 @@
CLANG_ENABLE_MODULES = YES;
CODE_SIGN_STYLE = Automatic;
CURRENT_PROJECT_VERSION = 1;
- DEVELOPMENT_TEAM = 2P56S3D7L7;
+ DEVELOPMENT_TEAM = "";
GENERATE_INFOPLIST_FILE = YES;
LD_RUNPATH_SEARCH_PATHS = (
"$(inherited)",
@@ -683,14 +653,17 @@
"@loader_path/Frameworks",
);
MARKETING_VERSION = 1.0;
- PRODUCT_BUNDLE_IDENTIFIER = "dev.mobile.maestro-driver-iosUITests";
+ PRODUCT_BUNDLE_IDENTIFIER = "dev.mobile.maestro-driverUITests";
PRODUCT_NAME = "$(TARGET_NAME)";
+ SUPPORTED_PLATFORMS = "appletvos appletvsimulator iphoneos iphonesimulator";
+ SUPPORTS_MACCATALYST = YES;
SWIFT_EMIT_LOC_STRINGS = NO;
SWIFT_OBJC_BRIDGING_HEADER = "";
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
SWIFT_VERSION = 5.0;
- TARGETED_DEVICE_FAMILY = "1,2";
- TEST_TARGET_NAME = "maestro-driver-ios";
+ TARGETED_DEVICE_FAMILY = "1,2,3";
+ TEST_TARGET_NAME = "maestro-driver";
+ TVOS_DEPLOYMENT_TARGET = 14.0;
};
name = Debug;
};
@@ -701,7 +674,7 @@
CLANG_ENABLE_MODULES = YES;
CODE_SIGN_STYLE = Automatic;
CURRENT_PROJECT_VERSION = 1;
- DEVELOPMENT_TEAM = 2P56S3D7L7;
+ DEVELOPMENT_TEAM = "";
GENERATE_INFOPLIST_FILE = YES;
LD_RUNPATH_SEARCH_PATHS = (
"$(inherited)",
@@ -709,38 +682,41 @@
"@loader_path/Frameworks",
);
MARKETING_VERSION = 1.0;
- PRODUCT_BUNDLE_IDENTIFIER = "dev.mobile.maestro-driver-iosUITests";
+ PRODUCT_BUNDLE_IDENTIFIER = "dev.mobile.maestro-driverUITests";
PRODUCT_NAME = "$(TARGET_NAME)";
+ SUPPORTED_PLATFORMS = "appletvos appletvsimulator iphoneos iphonesimulator";
+ SUPPORTS_MACCATALYST = YES;
SWIFT_EMIT_LOC_STRINGS = NO;
SWIFT_OBJC_BRIDGING_HEADER = "";
SWIFT_VERSION = 5.0;
- TARGETED_DEVICE_FAMILY = "1,2";
- TEST_TARGET_NAME = "maestro-driver-ios";
+ TARGETED_DEVICE_FAMILY = "1,2,3";
+ TEST_TARGET_NAME = "maestro-driver";
+ TVOS_DEPLOYMENT_TARGET = 14.0;
};
name = Release;
};
/* End XCBuildConfiguration section */
/* Begin XCConfigurationList section */
- 52049BCE2935039F00807AA3 /* Build configuration list for PBXProject "maestro-driver-ios" */ = {
+ 44F995312C9D6F8900D15B50 /* Build configuration list for PBXNativeTarget "maestro-driver" */ = {
isa = XCConfigurationList;
buildConfigurations = (
- 52049BFB293503A200807AA3 /* Debug */,
- 52049BFC293503A200807AA3 /* Release */,
+ 44F9952F2C9D6F8900D15B50 /* Debug */,
+ 44F995302C9D6F8900D15B50 /* Release */,
);
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
- 52049BFD293503A200807AA3 /* Build configuration list for PBXNativeTarget "maestro-driver-ios" */ = {
+ 52049BCE2935039F00807AA3 /* Build configuration list for PBXProject "maestro-driver-ios" */ = {
isa = XCConfigurationList;
buildConfigurations = (
- 52049BFE293503A200807AA3 /* Debug */,
- 52049BFF293503A200807AA3 /* Release */,
+ 52049BFB293503A200807AA3 /* Debug */,
+ 52049BFC293503A200807AA3 /* Release */,
);
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
- 52049C03293503A200807AA3 /* Build configuration list for PBXNativeTarget "maestro-driver-iosUITests" */ = {
+ 52049C03293503A200807AA3 /* Build configuration list for PBXNativeTarget "maestro-driverUITests" */ = {
isa = XCConfigurationList;
buildConfigurations = (
52049C04293503A200807AA3 /* Debug */,
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/xcshareddata/xcschemes/maestro-driver-ios.xcscheme b/maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/xcshareddata/xcschemes/maestro-driver.xcscheme
similarity index 68%
rename from maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/xcshareddata/xcschemes/maestro-driver-ios.xcscheme
rename to maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/xcshareddata/xcschemes/maestro-driver.xcscheme
index 7a62ee81d2..a1555be14c 100644
--- a/maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/xcshareddata/xcschemes/maestro-driver-ios.xcscheme
+++ b/maestro-ios-xctest-runner/maestro-driver-ios.xcodeproj/xcshareddata/xcschemes/maestro-driver.xcscheme
@@ -1,10 +1,11 @@
+ LastUpgradeVersion = "1600"
+ version = "1.7">
+ buildImplicitDependencies = "YES"
+ buildArchitectures = "Automatic">
@@ -26,25 +27,16 @@
buildConfiguration = "Debug"
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
- shouldUseLaunchSchemeArgsEnv = "YES">
+ shouldUseLaunchSchemeArgsEnv = "YES"
+ shouldAutocreateTestPlan = "YES">
-
-
-
-
@@ -64,9 +56,9 @@
runnableDebuggingMode = "0">
@@ -81,9 +73,9 @@
runnableDebuggingMode = "0">
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios/AppDelegate.swift b/maestro-ios-xctest-runner/maestro-driver-ios/AppDelegate.swift
deleted file mode 100644
index ec3762c48a..0000000000
--- a/maestro-ios-xctest-runner/maestro-driver-ios/AppDelegate.swift
+++ /dev/null
@@ -1,36 +0,0 @@
-//
-// AppDelegate.swift
-// maestro-driver-ios
-//
-//
-//
-
-import UIKit
-
-@main
-class AppDelegate: UIResponder, UIApplicationDelegate {
-
-
-
- func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
- // Override point for customization after application launch.
- return true
- }
-
- // MARK: UISceneSession Lifecycle
-
- func application(_ application: UIApplication, configurationForConnecting connectingSceneSession: UISceneSession, options: UIScene.ConnectionOptions) -> UISceneConfiguration {
- // Called when a new scene session is being created.
- // Use this method to select a configuration to create the new scene with.
- return UISceneConfiguration(name: "Default Configuration", sessionRole: connectingSceneSession.role)
- }
-
- func application(_ application: UIApplication, didDiscardSceneSessions sceneSessions: Set) {
- // Called when the user discards a scene session.
- // If any sessions were discarded while the application was not running, this will be called shortly after application:didFinishLaunchingWithOptions.
- // Use this method to release any resources that were specific to the discarded scenes, as they will not return.
- }
-
-
-}
-
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios/Assets.xcassets/AppIcon.appiconset/Contents.json b/maestro-ios-xctest-runner/maestro-driver-ios/Assets.xcassets/AppIcon.appiconset/Contents.json
deleted file mode 100644
index 5a3257a7d0..0000000000
--- a/maestro-ios-xctest-runner/maestro-driver-ios/Assets.xcassets/AppIcon.appiconset/Contents.json
+++ /dev/null
@@ -1,93 +0,0 @@
-{
- "images" : [
- {
- "idiom" : "iphone",
- "scale" : "2x",
- "size" : "20x20"
- },
- {
- "idiom" : "iphone",
- "scale" : "3x",
- "size" : "20x20"
- },
- {
- "idiom" : "iphone",
- "scale" : "2x",
- "size" : "29x29"
- },
- {
- "idiom" : "iphone",
- "scale" : "3x",
- "size" : "29x29"
- },
- {
- "idiom" : "iphone",
- "scale" : "2x",
- "size" : "40x40"
- },
- {
- "idiom" : "iphone",
- "scale" : "3x",
- "size" : "40x40"
- },
- {
- "idiom" : "iphone",
- "scale" : "2x",
- "size" : "60x60"
- },
- {
- "idiom" : "iphone",
- "scale" : "3x",
- "size" : "60x60"
- },
- {
- "idiom" : "ipad",
- "scale" : "1x",
- "size" : "20x20"
- },
- {
- "idiom" : "ipad",
- "scale" : "2x",
- "size" : "20x20"
- },
- {
- "idiom" : "ipad",
- "scale" : "1x",
- "size" : "29x29"
- },
- {
- "idiom" : "ipad",
- "scale" : "2x",
- "size" : "29x29"
- },
- {
- "idiom" : "ipad",
- "scale" : "1x",
- "size" : "40x40"
- },
- {
- "idiom" : "ipad",
- "scale" : "2x",
- "size" : "40x40"
- },
- {
- "idiom" : "ipad",
- "scale" : "2x",
- "size" : "76x76"
- },
- {
- "idiom" : "ipad",
- "scale" : "2x",
- "size" : "83.5x83.5"
- },
- {
- "idiom" : "ios-marketing",
- "scale" : "1x",
- "size" : "1024x1024"
- }
- ],
- "info" : {
- "author" : "xcode",
- "version" : 1
- }
-}
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios/Base.lproj/LaunchScreen.storyboard b/maestro-ios-xctest-runner/maestro-driver-ios/Base.lproj/LaunchScreen.storyboard
deleted file mode 100644
index 865e9329f3..0000000000
--- a/maestro-ios-xctest-runner/maestro-driver-ios/Base.lproj/LaunchScreen.storyboard
+++ /dev/null
@@ -1,25 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios/Base.lproj/Main.storyboard b/maestro-ios-xctest-runner/maestro-driver-ios/Base.lproj/Main.storyboard
deleted file mode 100644
index 25a763858e..0000000000
--- a/maestro-ios-xctest-runner/maestro-driver-ios/Base.lproj/Main.storyboard
+++ /dev/null
@@ -1,24 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios/Info.plist b/maestro-ios-xctest-runner/maestro-driver-ios/Info.plist
deleted file mode 100644
index dd3c9afdae..0000000000
--- a/maestro-ios-xctest-runner/maestro-driver-ios/Info.plist
+++ /dev/null
@@ -1,25 +0,0 @@
-
-
-
-
- UIApplicationSceneManifest
-
- UIApplicationSupportsMultipleScenes
-
- UISceneConfigurations
-
- UIWindowSceneSessionRoleApplication
-
-
- UISceneConfigurationName
- Default Configuration
- UISceneDelegateClassName
- $(PRODUCT_MODULE_NAME).SceneDelegate
- UISceneStoryboardFile
- Main
-
-
-
-
-
-
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios/SceneDelegate.swift b/maestro-ios-xctest-runner/maestro-driver-ios/SceneDelegate.swift
deleted file mode 100644
index 1ebc053ed6..0000000000
--- a/maestro-ios-xctest-runner/maestro-driver-ios/SceneDelegate.swift
+++ /dev/null
@@ -1,52 +0,0 @@
-//
-// SceneDelegate.swift
-// maestro-driver-ios
-//
-//
-//
-
-import UIKit
-
-class SceneDelegate: UIResponder, UIWindowSceneDelegate {
-
- var window: UIWindow?
-
-
- func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) {
- // Use this method to optionally configure and attach the UIWindow `window` to the provided UIWindowScene `scene`.
- // If using a storyboard, the `window` property will automatically be initialized and attached to the scene.
- // This delegate does not imply the connecting scene or session are new (see `application:configurationForConnectingSceneSession` instead).
- guard let _ = (scene as? UIWindowScene) else { return }
- }
-
- func sceneDidDisconnect(_ scene: UIScene) {
- // Called as the scene is being released by the system.
- // This occurs shortly after the scene enters the background, or when its session is discarded.
- // Release any resources associated with this scene that can be re-created the next time the scene connects.
- // The scene may re-connect later, as its session was not necessarily discarded (see `application:didDiscardSceneSessions` instead).
- }
-
- func sceneDidBecomeActive(_ scene: UIScene) {
- // Called when the scene has moved from an inactive state to an active state.
- // Use this method to restart any tasks that were paused (or not yet started) when the scene was inactive.
- }
-
- func sceneWillResignActive(_ scene: UIScene) {
- // Called when the scene will move from an active state to an inactive state.
- // This may occur due to temporary interruptions (ex. an incoming phone call).
- }
-
- func sceneWillEnterForeground(_ scene: UIScene) {
- // Called as the scene transitions from the background to the foreground.
- // Use this method to undo the changes made on entering the background.
- }
-
- func sceneDidEnterBackground(_ scene: UIScene) {
- // Called as the scene transitions from the foreground to the background.
- // Use this method to save data, release shared resources, and store enough scene-specific state information
- // to restore the scene back to its current state.
- }
-
-
-}
-
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios/ViewController.swift b/maestro-ios-xctest-runner/maestro-driver-ios/ViewController.swift
deleted file mode 100644
index 5cfbe4d192..0000000000
--- a/maestro-ios-xctest-runner/maestro-driver-ios/ViewController.swift
+++ /dev/null
@@ -1,19 +0,0 @@
-//
-// ViewController.swift
-// maestro-driver-ios
-//
-//
-//
-
-import UIKit
-
-class ViewController: UIViewController {
-
- override func viewDidLoad() {
- super.viewDidLoad()
- // Do any additional setup after loading the view.
- }
-
-
-}
-
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Extensions/XCUIElement+Extensions.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Extensions/XCUIElement+Extensions.swift
index 5512cd0f4a..81b05aafae 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Extensions/XCUIElement+Extensions.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Extensions/XCUIElement+Extensions.swift
@@ -3,8 +3,11 @@ import XCTest
extension XCUIElement {
func setText(text: String, application: XCUIApplication) {
+ // TODO: Does this require a tvOS implementation?
+ #if !os(tvOS)
UIPasteboard.general.string = text
doubleTap()
application.menuItems["Paste"].tap()
+ #endif
}
}
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/PressButtonHandler.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/PressButtonHandler.swift
index 1732aa0ddf..96da7a34db 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/PressButtonHandler.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/PressButtonHandler.swift
@@ -17,10 +17,35 @@ struct PressButtonHandler: HTTPHandler {
}
switch requestBody.button {
- case .home:
- XCUIDevice.shared.press(.home)
- case .lock:
- XCUIDevice.shared.perform(NSSelectorFromString("pressLockButton"))
+ #if !os(tvOS)
+ case .home:
+ XCUIDevice.shared.press(.home)
+ case .lock:
+ XCUIDevice.shared.perform(NSSelectorFromString("pressLockButton"))
+ #else
+ case .volumeUp:
+ if #available(tvOS 14.3, *) {
+ XCUIRemote.shared.press(XCUIRemote.Button.pageUp)
+ }
+ case .volumeDown:
+ if #available(tvOS 14.3, *) {
+ XCUIRemote.shared.press(XCUIRemote.Button.pageDown)
+ }
+ case .remoteDpadUp:
+ XCUIRemote.shared.press(XCUIRemote.Button.up)
+ case .remoteDpadDown:
+ XCUIRemote.shared.press(XCUIRemote.Button.down)
+ case .remoteDpadLeft:
+ XCUIRemote.shared.press(XCUIRemote.Button.left)
+ case .remoteDpadRight:
+ XCUIRemote.shared.press(XCUIRemote.Button.right)
+ case .remoteDpadCenter:
+ XCUIRemote.shared.press(XCUIRemote.Button.select)
+ case .remoteMediaPlayPause:
+ XCUIRemote.shared.press(XCUIRemote.Button.playPause)
+ case .RemoteMenu:
+ XCUIRemote.shared.press(XCUIRemote.Button.menu)
+ #endif
}
return HTTPResponse(statusCode: .ok)
}
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/RunningAppRouteHandler.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/RunningAppRouteHandler.swift
index 6352c59ffa..6d1ad60518 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/RunningAppRouteHandler.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/RunningAppRouteHandler.swift
@@ -9,8 +9,12 @@ struct RunningAppRouteHandler: HTTPHandler {
category: String(describing: Self.self)
)
- private static let springboardBundleId = "com.apple.springboard"
-
+ #if os(tvOS)
+ private static let homescreenBundleId = "com.apple.HeadBoard"
+ #else
+ private static let homescreenBundleId = "com.apple.springboard"
+ #endif
+
func handleRequest(_ request: FlyingFox.HTTPRequest) async throws -> FlyingFox.HTTPResponse {
guard let requestBody = try? JSONDecoder().decode(RunningAppRequest.self, from: request.body) else {
return AppError(type: .precondition, message: "incorrect request body for getting running app id request").httpResponse
@@ -23,7 +27,7 @@ struct RunningAppRouteHandler: HTTPHandler {
return app.state == .runningForeground
}
- let response = ["runningAppBundleId": runningAppId ?? RunningAppRouteHandler.springboardBundleId]
+ let response = ["runningAppBundleId": runningAppId ?? RunningAppRouteHandler.homescreenBundleId]
let responseData = try JSONSerialization.data(
withJSONObject: response,
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/StatusHandler.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/StatusHandler.swift
index 3a1f91099e..478e437df1 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/StatusHandler.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/StatusHandler.swift
@@ -5,7 +5,11 @@ import os
@MainActor
struct StatusHandler: HTTPHandler {
- private static let springboardBundleId = "com.apple.springboard"
+ #if os(tvOS)
+ private static let homescreenBundleId = "com.apple.HeadBoard"
+ #else
+ private static let homescreenBundleId = "com.apple.springboard"
+ #endif
private let logger = Logger(
subsystem: Bundle.main.bundleIdentifier!,
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/ViewHierarchyHandler.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/ViewHierarchyHandler.swift
index 1d98932859..d297ac9677 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/ViewHierarchyHandler.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Handlers/ViewHierarchyHandler.swift
@@ -5,8 +5,12 @@ import os
@MainActor
struct ViewHierarchyHandler: HTTPHandler {
- private static let springboardBundleId = "com.apple.springboard"
- private let springboardApplication = XCUIApplication(bundleIdentifier: Self.springboardBundleId)
+ #if os(tvOS)
+ private static let homescreenBundleId = "com.apple.HeadBoard"
+ #else
+ private static let homescreenBundleId = "com.apple.springboard"
+ #endif
+ private let springboardApplication = XCUIApplication(bundleIdentifier: Self.homescreenBundleId)
private let snapshotMaxDepth = 60
private let logger = Logger(
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Helpers/ScreenSizeHelper.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Helpers/ScreenSizeHelper.swift
index 7d4c2c68b6..f4c8c9ce6d 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Helpers/ScreenSizeHelper.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Helpers/ScreenSizeHelper.swift
@@ -1,26 +1,46 @@
import XCTest
+// UIKit doesn't include UIDeviceOrientation on tvOS
+public enum DeviceOrientation: Int, @unchecked Sendable {
+ case unknown = 0
+ case portrait = 1 // Device oriented vertically, home button on the bottom
+ case portraitUpsideDown = 2 // Device oriented vertically, home button on the top
+ case landscapeLeft = 3 // Device oriented horizontally, home button on the right
+ case landscapeRight = 4 // Device oriented horizontally, home button on the left
+ case faceUp = 5 // Device oriented flat, face up
+ case faceDown = 6 // Device oriented flat, face down
+}
+
struct ScreenSizeHelper {
static func physicalScreenSize() -> (Float, Float) {
- let springboardBundleId = "com.apple.springboard"
- let springboardApp = XCUIApplication(bundleIdentifier: springboardBundleId)
+ #if os(tvOS)
+ let homescreenBundleId = "com.apple.PineBoard"
+ #else
+ let homescreenBundleId = "com.apple.springboard"
+ #endif
+ let springboardApp = XCUIApplication(bundleIdentifier: homescreenBundleId)
let screenSize = springboardApp.frame.size
return (Float(screenSize.width), Float(screenSize.height))
}
- private static func actualOrientation() -> UIDeviceOrientation {
- let orientation = XCUIDevice.shared.orientation
- if orientation == .unknown {
+ private static func actualOrientation() -> DeviceOrientation {
+ #if os(tvOS)
+ // Please don't rotate your AppleTV...
+ let orientation = Optional(DeviceOrientation.unknown)
+ #else
+ let orientation = DeviceOrientation(rawValue: XCUIDevice.shared.orientation.rawValue)
+ #endif
+
+ guard let unwrappedOrientation = orientation, orientation != .unknown else {
// If orientation is "unknown", we assume it is "portrait" to
// work around https://stackoverflow.com/q/78932288/7009800
- return UIDeviceOrientation.portrait
+ return DeviceOrientation.portrait
}
-
- return orientation
+ return unwrappedOrientation
}
/// Takes device orientation into account.
- static func actualScreenSize() throws -> (Float, Float, UIDeviceOrientation) {
+ static func actualScreenSize() throws -> (Float, Float, DeviceOrientation) {
let orientation = actualOrientation()
let (width, height) = physicalScreenSize()
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Helpers/SystemPermissionHelper.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Helpers/SystemPermissionHelper.swift
index 82d68d44df..06302e0351 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Helpers/SystemPermissionHelper.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Helpers/SystemPermissionHelper.swift
@@ -18,12 +18,17 @@ final class SystemPermissionHelper {
case .allow:
let allowButton = alert.buttons.element(boundBy: 1)
if allowButton.exists {
+ // TODO: Add a proper shim for tvOS
+ #if !os(tvOS)
allowButton.tap()
+ #endif
}
case .deny:
let dontAllowButton = alert.buttons.element(boundBy: 0)
if dontAllowButton.exists {
+ #if !os(tvOS)
dontAllowButton.tap()
+ #endif
}
case .unset, .unknown:
// do nothing
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Models/PressButtonRequest.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Models/PressButtonRequest.swift
index ce21609764..5144d24b6e 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Models/PressButtonRequest.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/Models/PressButtonRequest.swift
@@ -4,8 +4,34 @@ import XCTest
struct PressButtonRequest: Codable {
enum Button: String, Codable {
- case home
- case lock
+ #if !os(tvOS)
+ case home = "Home"
+ case lock = "Lock"
+ #else
+ case volumeUp = "Volume Up"
+ case volumeDown = "Volume Down"
+ case remoteDpadUp = "Remote Dpad Up"
+ case remoteDpadDown = "Remote Dpad Down"
+ case remoteDpadLeft = "Remote Dpad Left"
+ case remoteDpadRight = "Remote Dpad Right"
+ case remoteDpadCenter = "Remote Dpad Center"
+ case remoteMediaPlayPause = "Remote Media Play Pause"
+ /**
+ case remoteMediaNext = "Remote Media Next"
+ case remoteMediaPrevious = "Remote Media Previous"
+ case remoteMediaRewind = "Remote Media Rewind"
+ case remoteMediaFastForward = "Remote Media Fast Forward"
+ case RemoteSystemNavigationUp = "Remote System Navigation Up"
+ case RemoteSystemNavigationDown = "Remote System Navigation Down"
+ **/
+ case RemoteMenu = "Remote Menu"
+ /**
+ case tvInput = "TV Input"
+ case tvInputHDMIOne = "TV Input HDMI 1"
+ case tvInputHDMITwo = "TV Input HDMI 2"
+ case tvInputHDMIThree = "TV Input HDMI 3"
+ **/
+ #endif
}
let button: Button
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/XCTest/EventRecord.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/XCTest/EventRecord.swift
index b7437395ea..e34b61df48 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/XCTest/EventRecord.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/XCTest/EventRecord.swift
@@ -7,11 +7,11 @@ final class EventRecord: NSObject {
static let defaultTapDuration = 0.1
enum Style: String {
- case singeFinger = "Single-Finger Touch Action"
+ case singleFinger = "Single-Finger Touch Action"
case multiFinger = "Multi-Finger Touch Action"
}
- init(orientation: UIInterfaceOrientation, style: Style = .singeFinger) {
+ init(orientation: DeviceOrientation, style: Style = .singleFinger) {
eventRecord = objc_lookUpClass("XCSynthesizedEventRecord")?.alloc()
.perform(
NSSelectorFromString("initWithName:interfaceOrientation:"),
diff --git a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/XCTest/RunningApp.swift b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/XCTest/RunningApp.swift
index 75d068dbf0..5e9868c46b 100644
--- a/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/XCTest/RunningApp.swift
+++ b/maestro-ios-xctest-runner/maestro-driver-iosUITests/Routes/XCTest/RunningApp.swift
@@ -4,7 +4,11 @@ import os
struct RunningApp {
- private static let springboardBundleId = "com.apple.springboard"
+ #if os(tvOS)
+ private static let homescreenBundleId = "com.apple.HeadBoard"
+ #else
+ private static let homescreenBundleId = "com.apple.springboard"
+ #endif
private static let logger = Logger(
subsystem: Bundle.main.bundleIdentifier!,
category: String(describing: Self.self)
@@ -21,7 +25,7 @@ struct RunningApp {
let app = XCUIApplication(bundleIdentifier: appId)
return app.state == .runningForeground
- } ?? RunningApp.springboardBundleId
+ } ?? RunningApp.homescreenBundleId
}
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios/Assets.xcassets/AccentColor.colorset/Contents.json b/maestro-ios-xctest-runner/maestro-driver/Assets.xcassets/AccentColor.colorset/Contents.json
similarity index 100%
rename from maestro-ios-xctest-runner/maestro-driver-ios/Assets.xcassets/AccentColor.colorset/Contents.json
rename to maestro-ios-xctest-runner/maestro-driver/Assets.xcassets/AccentColor.colorset/Contents.json
diff --git a/maestro-ios-xctest-runner/maestro-driver/Assets.xcassets/AppIcon.appiconset/Contents.json b/maestro-ios-xctest-runner/maestro-driver/Assets.xcassets/AppIcon.appiconset/Contents.json
new file mode 100644
index 0000000000..2305880107
--- /dev/null
+++ b/maestro-ios-xctest-runner/maestro-driver/Assets.xcassets/AppIcon.appiconset/Contents.json
@@ -0,0 +1,35 @@
+{
+ "images" : [
+ {
+ "idiom" : "universal",
+ "platform" : "ios",
+ "size" : "1024x1024"
+ },
+ {
+ "appearances" : [
+ {
+ "appearance" : "luminosity",
+ "value" : "dark"
+ }
+ ],
+ "idiom" : "universal",
+ "platform" : "ios",
+ "size" : "1024x1024"
+ },
+ {
+ "appearances" : [
+ {
+ "appearance" : "luminosity",
+ "value" : "tinted"
+ }
+ ],
+ "idiom" : "universal",
+ "platform" : "ios",
+ "size" : "1024x1024"
+ }
+ ],
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ }
+}
diff --git a/maestro-ios-xctest-runner/maestro-driver-ios/Assets.xcassets/Contents.json b/maestro-ios-xctest-runner/maestro-driver/Assets.xcassets/Contents.json
similarity index 100%
rename from maestro-ios-xctest-runner/maestro-driver-ios/Assets.xcassets/Contents.json
rename to maestro-ios-xctest-runner/maestro-driver/Assets.xcassets/Contents.json
diff --git a/maestro-ios-xctest-runner/maestro-driver/ContentView.swift b/maestro-ios-xctest-runner/maestro-driver/ContentView.swift
new file mode 100644
index 0000000000..12e7117737
--- /dev/null
+++ b/maestro-ios-xctest-runner/maestro-driver/ContentView.swift
@@ -0,0 +1,24 @@
+//
+// ContentView.swift
+// maestro-driver
+//
+// Created by Max Phillips on 20/9/2024.
+//
+
+import SwiftUI
+
+struct ContentView: View {
+ var body: some View {
+ VStack {
+ Image(systemName: "globe")
+ .imageScale(.large)
+ .foregroundStyle(.tint)
+ Text("Hello, world!")
+ }
+ .padding()
+ }
+}
+
+#Preview {
+ ContentView()
+}
diff --git a/maestro-ios-xctest-runner/maestro-driver/Preview Content/Preview Assets.xcassets/Contents.json b/maestro-ios-xctest-runner/maestro-driver/Preview Content/Preview Assets.xcassets/Contents.json
new file mode 100644
index 0000000000..73c00596a7
--- /dev/null
+++ b/maestro-ios-xctest-runner/maestro-driver/Preview Content/Preview Assets.xcassets/Contents.json
@@ -0,0 +1,6 @@
+{
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ }
+}
diff --git a/maestro-ios-xctest-runner/maestro-driver/maestro_driverApp.swift b/maestro-ios-xctest-runner/maestro-driver/maestro_driverApp.swift
new file mode 100644
index 0000000000..5f0f81c593
--- /dev/null
+++ b/maestro-ios-xctest-runner/maestro-driver/maestro_driverApp.swift
@@ -0,0 +1,17 @@
+//
+// maestro_driverApp.swift
+// maestro-driver
+//
+// Created by Max Phillips on 20/9/2024.
+//
+
+import SwiftUI
+
+@main
+struct maestro_driverApp: App {
+ var body: some Scene {
+ WindowGroup {
+ ContentView()
+ }
+ }
+}
diff --git a/maestro-ios-xctest-runner/run-maestro-ios-runner.sh b/maestro-ios-xctest-runner/run-maestro-ios-runner.sh
index e771ef6b4d..fb4796ec58 100755
--- a/maestro-ios-xctest-runner/run-maestro-ios-runner.sh
+++ b/maestro-ios-xctest-runner/run-maestro-ios-runner.sh
@@ -12,7 +12,7 @@ if [ -z "$DEVICE" ]; then
echo "No device passed, will default to $DEVICE"
fi
-xctestrun_file="$(find ./build/Products -maxdepth 1 -name '*.xctestrun' -print)"
+xctestrun_file="$(find ./build/Products -maxdepth 1 -name '*iphone*.xctestrun' -print)"
file_count="$(echo "$xctestrun_file" | wc -l | tr -d '[:blank:]')"
if [ "$file_count" = 1 ]; then
echo "xctestrun file found: $xctestrun_file"
diff --git a/maestro-ios-xctest-runner/test-maestro-ios-runner.sh b/maestro-ios-xctest-runner/test-maestro-ios-runner.sh
index 3cbe3bf988..cd2cf35c3c 100755
--- a/maestro-ios-xctest-runner/test-maestro-ios-runner.sh
+++ b/maestro-ios-xctest-runner/test-maestro-ios-runner.sh
@@ -6,13 +6,13 @@ if [ "$(basename "$PWD")" != "maestro" ]; then
exit 1
fi
-if [ ! -d ./build/Products/Debug-iphonesimulator/maestro-driver-iosUITests-Runner.app ]; then
- echo "XCTest runner app not found in ./build/Products/Debug-iphonesimulator/maestro-driver-iosUITests-Runner.app"
+if [ ! -d ./build/Products/Debug-iphonesimulator/maestro-driver-UITests-Runner.app ]; then
+ echo "XCTest runner app not found in ./build/Products/Debug-iphonesimulator/maestro-driver-UITests-Runner.app"
exit 1
fi
-if [ ! -d ./build/Products/Debug-iphonesimulator/maestro-driver-ios.app ]; then
- echo "Dummy test app not found in ./build/Products/Debug-iphonesimulator/maestro-driver-ios.app"
+if [ ! -d ./build/Products/Debug-iphonesimulator/maestro-driver.app ]; then
+ echo "Dummy test app not found in ./build/Products/Debug-iphonesimulator/maestro-driver.app"
exit 1
fi