From b7d75bec7623efa03b19ffc52f35ebb25ef3b1ac Mon Sep 17 00:00:00 2001 From: Eason <291028775@qq.com> Date: Mon, 19 Aug 2024 14:56:51 +0000 Subject: [PATCH 1/4] commmit --- .../cloud/sonic/agent/bridge/ios/SibTool.java | 204 ++++++++---------- 1 file changed, 93 insertions(+), 111 deletions(-) diff --git a/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java b/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java index 7cdeca8d..a7e3cb84 100755 --- a/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java +++ b/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java @@ -62,7 +62,7 @@ import static org.cloud.sonic.agent.tools.BytesTool.sendText; -@DependsOn({"iOSThreadPoolInit"}) +@DependsOn({ "iOSThreadPoolInit" }) @Component @Order(value = Ordered.HIGHEST_PRECEDENCE) public class SibTool implements ApplicationListener { @@ -101,9 +101,11 @@ public void init() { String system = System.getProperty("os.name").toLowerCase(); try { if (system.contains("win")) { - listenProcess = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib)}); + listenProcess = Runtime.getRuntime() + .exec(new String[] { "cmd", "/c", String.format(commandLine, sib) }); } else if (system.contains("linux") || system.contains("mac")) { - listenProcess = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib)}); + listenProcess = Runtime.getRuntime() + .exec(new String[] { "sh", "-c", String.format(commandLine, sib) }); } } catch (Exception e) { e.printStackTrace(); @@ -113,7 +115,8 @@ public void init() { String s; while (true) { try { - if ((s = stdInput.readLine()) == null) break; + if ((s = stdInput.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -144,8 +147,7 @@ public void init() { new IOSBatteryThread(), IOSBatteryThread.DELAY, IOSBatteryThread.DELAY, - IOSBatteryThread.TIME_UNIT - ); + IOSBatteryThread.TIME_UNIT); logger.info("iOS devices listening..."); } @@ -208,80 +210,14 @@ public static String getName(String udId) { } public static int[] startWda(String udId) throws IOException, InterruptedException { - List processList; - if (IOSProcessMap.getMap().get(udId) != null) { - processList = IOSProcessMap.getMap().get(udId); - for (Process p : processList) { - if (p != null) { - p.children().forEach(ProcessHandle::destroy); - p.destroy(); - } - } - } Socket wda = PortTool.getBindSocket(); Socket mjpeg = PortTool.getBindSocket(); int wdaPort = PortTool.releaseAndGetPort(wda); int mjpegPort = PortTool.releaseAndGetPort(mjpeg); - Process wdaProcess = null; - String commandLine = "%s run wda -u %s -b %s --mjpeg-remote-port 9100" + - " --server-remote-port 8100 --mjpeg-local-port %d --server-local-port %d"; - String system = System.getProperty("os.name").toLowerCase(); - if (system.contains("win")) { - wdaProcess = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, bundleId, mjpegPort, wdaPort)}); - } else if (system.contains("linux") || system.contains("mac")) { - wdaProcess = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, bundleId, mjpegPort, wdaPort)}); - } - InputStreamReader inputStreamReader = new InputStreamReader(wdaProcess.getInputStream()); - BufferedReader stdInput = new BufferedReader(inputStreamReader); - Semaphore isFinish = new Semaphore(0); - Thread wdaThread = new Thread(() -> { - String s; - while (true) { - try { - if ((s = stdInput.readLine()) == null) break; - } catch (IOException e) { - logger.info(e.getMessage()); - break; - } - logger.info(s); - if (s.contains("WebDriverAgent server start successful")) { - try { - Thread.sleep(1000); - } catch (InterruptedException e) { - throw new RuntimeException(e); - } - isFinish.release(); - } - } - try { - stdInput.close(); - } catch (IOException e) { - e.printStackTrace(); - } - try { - inputStreamReader.close(); - } catch (IOException e) { - e.printStackTrace(); - } - logger.info("WebDriverAgent print thread shutdown."); - }); - wdaThread.start(); - int wait = 0; - while (!isFinish.tryAcquire()) { - Thread.sleep(500); - wait++; - if (wait >= 120) { - logger.info(udId + " WebDriverAgent start timeout!"); - return new int[]{0, 0}; - } - } - processList = new ArrayList<>(); - processList.add(wdaProcess); - IOSProcessMap.getMap().put(udId, processList); - return new int[]{wdaPort, mjpegPort}; + startWda(udId, wdaPort, mjpegPort); } - public static void startWda(String udId, int wdaPort, int mjpegPort) throws IOException, InterruptedException { + public static int[] startWda(String udId, int wdaPort, int mjpegPort) throws IOException, InterruptedException { List processList; if (IOSProcessMap.getMap().get(udId) != null) { processList = IOSProcessMap.getMap().get(udId); @@ -295,13 +231,24 @@ public static void startWda(String udId, int wdaPort, int mjpegPort) throws IOEx wdaPort = (wdaPort == 0) ? PortTool.getPort() : wdaPort; mjpegPort = (mjpegPort == 0) ? PortTool.getPort() : mjpegPort; Process wdaProcess = null; - String commandLine = "%s run wda -u %s -b %s --mjpeg-remote-port 9100" + - " --server-remote-port 8100 --mjpeg-local-port %d --server-local-port %d"; + Process iProxyProcess = null; + String commandLine = ""; + + // ios17 support, but mac only + if (SibTool.isUpperThanIos17(udId)) { + commandLine = String.format( + "xcodebuild -project WebDriverAgent/WebDriverAgent.xcodeproj -scheme WebDriverAgentRunner -destination 'id=%s' test", + udId); + } else { + commandLine = String.format( + "%s run wda -u %s -b %s --mjpeg-remote-port 9100 --server-remote-port 8100 --mjpeg-local-port %d --server-local-port %d", + sib, udId, bundleId, mjpegPort, wdaPort); + } String system = System.getProperty("os.name").toLowerCase(); if (system.contains("win")) { - wdaProcess = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, bundleId, mjpegPort, wdaPort)}); + wdaProcess = Runtime.getRuntime().exec(new String[] { "cmd", "/c", commandLine }); } else if (system.contains("linux") || system.contains("mac")) { - wdaProcess = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, bundleId, mjpegPort, wdaPort)}); + wdaProcess = Runtime.getRuntime().exec(new String[] { "sh", "-c", commandLine }); } InputStreamReader inputStreamReader = new InputStreamReader(wdaProcess.getInputStream()); BufferedReader stdInput = new BufferedReader(inputStreamReader); @@ -310,13 +257,19 @@ public static void startWda(String udId, int wdaPort, int mjpegPort) throws IOEx String s; while (true) { try { - if ((s = stdInput.readLine()) == null) break; + if ((s = stdInput.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; } logger.info(s); - if (s.contains("WebDriverAgent server start successful")) { + if (s.contains("ServerURLHere->")) { + if (SibTool.isUpperThanIos17(udId)) { + iProxyProcess = Runtime.getRuntime().exec( + new String[] { "sh", "-c", String.format("iproxy -u %s %d:8100 %d:9100 -s 0.0.0.0", + udId, wdaPort, mjpegPort) }); + } try { Thread.sleep(1000); } catch (InterruptedException e) { @@ -344,11 +297,16 @@ public static void startWda(String udId, int wdaPort, int mjpegPort) throws IOEx wait++; if (wait >= 120) { logger.info(udId + " WebDriverAgent start timeout!"); + return new int[] { 0, 0 }; } } processList = new ArrayList<>(); processList.add(wdaProcess); + if (iProxyProcess != null) { + processList.add(iProxyProcess); + } IOSProcessMap.getMap().put(udId, processList); + return new int[] { wdaPort, mjpegPort }; } public static void reboot(String udId) { @@ -386,9 +344,9 @@ public static void getSysLog(String udId, String filter, Session session) { } try { if (system.contains("win")) { - ps = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId)}); + ps = Runtime.getRuntime().exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId) }); } else if (system.contains("linux") || system.contains("mac")) { - ps = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId)}); + ps = Runtime.getRuntime().exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId) }); } } catch (Exception e) { e.printStackTrace(); @@ -400,7 +358,8 @@ public static void getSysLog(String udId, String filter, Session session) { String s; while (true) { try { - if ((s = stdInput.readLine()) == null) break; + if ((s = stdInput.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -441,9 +400,9 @@ public static void orientationWatcher(String udId, Session session) { String commandLine = "%s orientation -w -u %s"; try { if (system.contains("win")) { - ps = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId)}); + ps = Runtime.getRuntime().exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId) }); } else if (system.contains("linux") || system.contains("mac")) { - ps = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId)}); + ps = Runtime.getRuntime().exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId) }); } } catch (Exception e) { e.printStackTrace(); @@ -455,7 +414,8 @@ public static void orientationWatcher(String udId, Session session) { String s; while (true) { try { - if ((s = stdInput.readLine()) == null) break; + if ((s = stdInput.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -489,7 +449,7 @@ public static void orientationWatcher(String udId, Session session) { } public static List getAppList(String udId) { - return getAppList(udId, null).stream().map(e->e.getString("bundleId")).collect(Collectors.toList()); + return getAppList(udId, null).stream().map(e -> e.getString("bundleId")).collect(Collectors.toList()); } public static List getAppList(String udId, Session session) { @@ -499,9 +459,11 @@ public static List getAppList(String udId, Session session) { String system = System.getProperty("os.name").toLowerCase(); try { if (system.contains("win")) { - appListProcess = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId)}); + appListProcess = Runtime.getRuntime() + .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId) }); } else if (system.contains("linux") || system.contains("mac")) { - appListProcess = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId)}); + appListProcess = Runtime.getRuntime() + .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId) }); } } catch (Exception e) { e.printStackTrace(); @@ -511,7 +473,8 @@ public static List getAppList(String udId, Session session) { String s; while (true) { try { - if (StringUtils.isEmpty(s = stdInput.readLine())) break; + if (StringUtils.isEmpty(s = stdInput.readLine())) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -550,9 +513,11 @@ public static void getProcessList(String udId, Session session) { String system = System.getProperty("os.name").toLowerCase(); try { if (system.contains("win")) { - appProcess = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId)}); + appProcess = Runtime.getRuntime() + .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId) }); } else if (system.contains("linux") || system.contains("mac")) { - appProcess = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId)}); + appProcess = Runtime.getRuntime() + .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId) }); } } catch (Exception e) { e.printStackTrace(); @@ -562,7 +527,8 @@ public static void getProcessList(String udId, Session session) { String s; while (true) { try { - if ((s = stdInput.readLine()) == null) break; + if ((s = stdInput.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -641,9 +607,11 @@ public static int startWebInspector(String udId) { try { String system = System.getProperty("os.name").toLowerCase(); if (system.contains("win")) { - ps = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, port)}); + ps = Runtime.getRuntime() + .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId, port) }); } else if (system.contains("linux") || system.contains("mac")) { - ps = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, port)}); + ps = Runtime.getRuntime() + .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId, port) }); } } catch (Exception e) { e.printStackTrace(); @@ -657,7 +625,8 @@ public static int startWebInspector(String udId) { String s; while (true) { try { - if ((s = stdInputErr.readLine()) == null) break; + if ((s = stdInputErr.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -683,7 +652,8 @@ public static int startWebInspector(String udId) { String s; while (true) { try { - if ((s = stdInput.readLine()) == null) break; + if ((s = stdInput.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -741,9 +711,11 @@ public static void proxy(String udId, int local, int target) { try { String system = System.getProperty("os.name").toLowerCase(); if (system.contains("win")) { - ps = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, local, target)}); + ps = Runtime.getRuntime() + .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId, local, target) }); } else if (system.contains("linux") || system.contains("mac")) { - ps = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, local, target)}); + ps = Runtime.getRuntime() + .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId, local, target) }); } } catch (Exception e) { e.printStackTrace(); @@ -756,7 +728,8 @@ public static void proxy(String udId, int local, int target) { String s; while (true) { try { - if ((s = stdInputErr.readLine()) == null) break; + if ((s = stdInputErr.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -780,7 +753,8 @@ public static void proxy(String udId, int local, int target) { String s; while (true) { try { - if ((s = stdInput.readLine()) == null) break; + if ((s = stdInput.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -853,8 +827,8 @@ public static List getWebView(String udId) { } HttpHeaders headers = new HttpHeaders(); headers.add("Content-Type", "application/json"); - ResponseEntity responseEntity = - restTemplate.exchange("http://localhost:" + port + "/json/list", HttpMethod.GET, new HttpEntity(headers), JSONArray.class); + ResponseEntity responseEntity = restTemplate.exchange("http://localhost:" + port + "/json/list", + HttpMethod.GET, new HttpEntity(headers), JSONArray.class); if (responseEntity.getStatusCode() == HttpStatus.OK) { return responseEntity.getBody().toJavaList(JSONObject.class); } else { @@ -879,9 +853,11 @@ public static void startPerfmon(String udId, String bundleId, Session session, L String tail = bundleId.length() == 0 ? "" : (" --proc-cpu --proc-mem -b " + bundleId); try { if (system.contains("win")) { - ps = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, interval, udId, tail)}); + ps = Runtime.getRuntime() + .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, interval, udId, tail) }); } else if (system.contains("linux") || system.contains("mac")) { - ps = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, interval, udId, tail)}); + ps = Runtime.getRuntime() + .exec(new String[] { "sh", "-c", String.format(commandLine, sib, interval, udId, tail) }); } } catch (Exception e) { e.printStackTrace(); @@ -894,7 +870,8 @@ public static void startPerfmon(String udId, String bundleId, Session session, L String s; while (true) { try { - if ((s = stdInputErr.readLine()) == null) break; + if ((s = stdInputErr.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -918,7 +895,8 @@ public static void startPerfmon(String udId, String bundleId, Session session, L String s; while (true) { try { - if ((s = stdInput.readLine()) == null) break; + if ((s = stdInput.readLine()) == null) + break; } catch (IOException e) { logger.info(e.getMessage()); break; @@ -974,9 +952,11 @@ public static void startShare(String udId, Session session) { Process ps = null; int port = PortTool.getPort(); if (system.contains("win")) { - ps = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, port)}); + ps = Runtime.getRuntime() + .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId, port) }); } else if (system.contains("linux") || system.contains("mac")) { - ps = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, port)}); + ps = Runtime.getRuntime() + .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId, port) }); } GlobalProcessMap.getMap().put(processName, ps); shareJSON.put("port", port); @@ -996,9 +976,11 @@ public static void startShare(String udId, int port) { String system = System.getProperty("os.name").toLowerCase(); Process ps = null; if (system.contains("win")) { - ps = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, port)}); + ps = Runtime.getRuntime() + .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId, port) }); } else if (system.contains("linux") || system.contains("mac")) { - ps = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, port)}); + ps = Runtime.getRuntime() + .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId, port) }); } GlobalProcessMap.getMap().put(processName, ps); } catch (Exception e) { From cae491707f85f53f3bc8f7b0c42223e86a72329b Mon Sep 17 00:00:00 2001 From: Eason <291028775@qq.com> Date: Tue, 20 Aug 2024 02:11:57 +0000 Subject: [PATCH 2/4] fix return --- src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java b/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java index a7e3cb84..fd9ed95b 100755 --- a/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java +++ b/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java @@ -214,7 +214,7 @@ public static int[] startWda(String udId) throws IOException, InterruptedExcepti Socket mjpeg = PortTool.getBindSocket(); int wdaPort = PortTool.releaseAndGetPort(wda); int mjpegPort = PortTool.releaseAndGetPort(mjpeg); - startWda(udId, wdaPort, mjpegPort); + return startWda(udId, wdaPort, mjpegPort); } public static int[] startWda(String udId, int wdaPort, int mjpegPort) throws IOException, InterruptedException { From 82c7d55a465da948d1355692edb2bfac6e4bd751 Mon Sep 17 00:00:00 2001 From: ZhouYixun <291028775@qq.com> Date: Tue, 20 Aug 2024 21:40:53 +0800 Subject: [PATCH 3/4] update_app_operate --- .../cloud/sonic/agent/bridge/ios/SibTool.java | 103 +++++++++++------- .../sonic/agent/websockets/IOSWSServer.java | 28 ++++- 2 files changed, 90 insertions(+), 41 deletions(-) diff --git a/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java b/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java index fd9ed95b..65f8f1ec 100755 --- a/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java +++ b/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java @@ -62,17 +62,23 @@ import static org.cloud.sonic.agent.tools.BytesTool.sendText; -@DependsOn({ "iOSThreadPoolInit" }) +@DependsOn({"iOSThreadPoolInit"}) @Component @Order(value = Ordered.HIGHEST_PRECEDENCE) public class SibTool implements ApplicationListener { private static final Logger logger = LoggerFactory.getLogger(SibTool.class); @Value("${modules.ios.wda-bundle-id}") private String getBundleId; + + @Value("${modules.ios.wda-xcode-project-path}") + private String getXcodeProjectPath; + private static String bundleId; + private static String xcodeProjectPath; private static File sibBinary = new File("plugins" + File.separator + "sonic-ios-bridge"); private static String sib = sibBinary.getAbsolutePath(); private static RestTemplate restTemplate; + @Autowired private RestTemplate restTemplateBean; private static Map webViewMap = new HashMap<>(); @@ -80,6 +86,7 @@ public class SibTool implements ApplicationListener { @Bean public void setEnv() { bundleId = getBundleId; + xcodeProjectPath = getXcodeProjectPath; } @Override @@ -102,10 +109,10 @@ public void init() { try { if (system.contains("win")) { listenProcess = Runtime.getRuntime() - .exec(new String[] { "cmd", "/c", String.format(commandLine, sib) }); + .exec(new String[]{"cmd", "/c", String.format(commandLine, sib)}); } else if (system.contains("linux") || system.contains("mac")) { listenProcess = Runtime.getRuntime() - .exec(new String[] { "sh", "-c", String.format(commandLine, sib) }); + .exec(new String[]{"sh", "-c", String.format(commandLine, sib)}); } } catch (Exception e) { e.printStackTrace(); @@ -231,14 +238,14 @@ public static int[] startWda(String udId, int wdaPort, int mjpegPort) throws IOE wdaPort = (wdaPort == 0) ? PortTool.getPort() : wdaPort; mjpegPort = (mjpegPort == 0) ? PortTool.getPort() : mjpegPort; Process wdaProcess = null; - Process iProxyProcess = null; - String commandLine = ""; + final Process[] iProxyProcess = {null}; + String commandLine; // ios17 support, but mac only - if (SibTool.isUpperThanIos17(udId)) { + if (isUpperThanIos17(udId)) { commandLine = String.format( - "xcodebuild -project WebDriverAgent/WebDriverAgent.xcodeproj -scheme WebDriverAgentRunner -destination 'id=%s' test", - udId); + "xcodebuild -project %s -scheme WebDriverAgentRunner -destination 'id=%s' test", + xcodeProjectPath, udId); } else { commandLine = String.format( "%s run wda -u %s -b %s --mjpeg-remote-port 9100 --server-remote-port 8100 --mjpeg-local-port %d --server-local-port %d", @@ -246,13 +253,17 @@ public static int[] startWda(String udId, int wdaPort, int mjpegPort) throws IOE } String system = System.getProperty("os.name").toLowerCase(); if (system.contains("win")) { - wdaProcess = Runtime.getRuntime().exec(new String[] { "cmd", "/c", commandLine }); + wdaProcess = Runtime.getRuntime().exec(new String[]{"cmd", "/c", commandLine}); } else if (system.contains("linux") || system.contains("mac")) { - wdaProcess = Runtime.getRuntime().exec(new String[] { "sh", "-c", commandLine }); + wdaProcess = Runtime.getRuntime().exec(new String[]{"sh", "-c", commandLine}); } InputStreamReader inputStreamReader = new InputStreamReader(wdaProcess.getInputStream()); BufferedReader stdInput = new BufferedReader(inputStreamReader); Semaphore isFinish = new Semaphore(0); + + int finalWdaPort = wdaPort; + int finalMjpegPort = mjpegPort; + Thread wdaThread = new Thread(() -> { String s; while (true) { @@ -266,9 +277,13 @@ public static int[] startWda(String udId, int wdaPort, int mjpegPort) throws IOE logger.info(s); if (s.contains("ServerURLHere->")) { if (SibTool.isUpperThanIos17(udId)) { - iProxyProcess = Runtime.getRuntime().exec( - new String[] { "sh", "-c", String.format("iproxy -u %s %d:8100 %d:9100 -s 0.0.0.0", - udId, wdaPort, mjpegPort) }); + try { + iProxyProcess[0] = Runtime.getRuntime().exec( + new String[]{"sh", "-c", String.format("iproxy -u %s %d:8100 %d:9100 -s 0.0.0.0", + udId, finalWdaPort, finalMjpegPort)}); + } catch (IOException e) { + logger.info(e.getMessage()); + } } try { Thread.sleep(1000); @@ -297,16 +312,16 @@ public static int[] startWda(String udId, int wdaPort, int mjpegPort) throws IOE wait++; if (wait >= 120) { logger.info(udId + " WebDriverAgent start timeout!"); - return new int[] { 0, 0 }; + return new int[]{0, 0}; } } processList = new ArrayList<>(); processList.add(wdaProcess); - if (iProxyProcess != null) { - processList.add(iProxyProcess); + if (iProxyProcess[0] != null) { + processList.add(iProxyProcess[0]); } IOSProcessMap.getMap().put(udId, processList); - return new int[] { wdaPort, mjpegPort }; + return new int[]{wdaPort, mjpegPort}; } public static void reboot(String udId) { @@ -320,8 +335,13 @@ public static void shutdown(String udId) { } public static void install(String udId, String path) { - String commandLine = "%s app install -u %s -p %s"; - ProcessCommandTool.getProcessLocalCommand(String.format(commandLine, sib, udId, path)); + String commandLine; + if (isUpperThanIos17(udId)) { + commandLine = String.format("ideviceinstaller -u %s -i %s", udId, path); + } else { + commandLine = String.format("%s app install -u %s -p %s", sib, udId, path); + } + ProcessCommandTool.getProcessLocalCommand(commandLine); } public static void stopSysLog(String udId) { @@ -344,9 +364,9 @@ public static void getSysLog(String udId, String filter, Session session) { } try { if (system.contains("win")) { - ps = Runtime.getRuntime().exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId) }); + ps = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId)}); } else if (system.contains("linux") || system.contains("mac")) { - ps = Runtime.getRuntime().exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId) }); + ps = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId)}); } } catch (Exception e) { e.printStackTrace(); @@ -400,9 +420,9 @@ public static void orientationWatcher(String udId, Session session) { String commandLine = "%s orientation -w -u %s"; try { if (system.contains("win")) { - ps = Runtime.getRuntime().exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId) }); + ps = Runtime.getRuntime().exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId)}); } else if (system.contains("linux") || system.contains("mac")) { - ps = Runtime.getRuntime().exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId) }); + ps = Runtime.getRuntime().exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId)}); } } catch (Exception e) { e.printStackTrace(); @@ -460,10 +480,10 @@ public static List getAppList(String udId, Session session) { try { if (system.contains("win")) { appListProcess = Runtime.getRuntime() - .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId) }); + .exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId)}); } else if (system.contains("linux") || system.contains("mac")) { appListProcess = Runtime.getRuntime() - .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId) }); + .exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId)}); } } catch (Exception e) { e.printStackTrace(); @@ -514,10 +534,10 @@ public static void getProcessList(String udId, Session session) { try { if (system.contains("win")) { appProcess = Runtime.getRuntime() - .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId) }); + .exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId)}); } else if (system.contains("linux") || system.contains("mac")) { appProcess = Runtime.getRuntime() - .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId) }); + .exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId)}); } } catch (Exception e) { e.printStackTrace(); @@ -581,8 +601,13 @@ public static void kill(String udId, String pkg) { } public static void uninstall(String udId, String pkg) { - String commandLine = "%s app uninstall -u %s -b %s"; - ProcessCommandTool.getProcessLocalCommand(String.format(commandLine, sib, udId, pkg)); + String commandLine; + if (isUpperThanIos17(udId)) { + commandLine = String.format("ideviceinstaller -u %s -U %s", udId, pkg); + } else { + commandLine = String.format("%s app uninstall -u %s -b %s", sib, udId, pkg); + } + ProcessCommandTool.getProcessLocalCommand(commandLine); } public static int battery(String udId) { @@ -608,10 +633,10 @@ public static int startWebInspector(String udId) { String system = System.getProperty("os.name").toLowerCase(); if (system.contains("win")) { ps = Runtime.getRuntime() - .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId, port) }); + .exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, port)}); } else if (system.contains("linux") || system.contains("mac")) { ps = Runtime.getRuntime() - .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId, port) }); + .exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, port)}); } } catch (Exception e) { e.printStackTrace(); @@ -712,10 +737,10 @@ public static void proxy(String udId, int local, int target) { String system = System.getProperty("os.name").toLowerCase(); if (system.contains("win")) { ps = Runtime.getRuntime() - .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId, local, target) }); + .exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, local, target)}); } else if (system.contains("linux") || system.contains("mac")) { ps = Runtime.getRuntime() - .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId, local, target) }); + .exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, local, target)}); } } catch (Exception e) { e.printStackTrace(); @@ -854,10 +879,10 @@ public static void startPerfmon(String udId, String bundleId, Session session, L try { if (system.contains("win")) { ps = Runtime.getRuntime() - .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, interval, udId, tail) }); + .exec(new String[]{"cmd", "/c", String.format(commandLine, sib, interval, udId, tail)}); } else if (system.contains("linux") || system.contains("mac")) { ps = Runtime.getRuntime() - .exec(new String[] { "sh", "-c", String.format(commandLine, sib, interval, udId, tail) }); + .exec(new String[]{"sh", "-c", String.format(commandLine, sib, interval, udId, tail)}); } } catch (Exception e) { e.printStackTrace(); @@ -953,10 +978,10 @@ public static void startShare(String udId, Session session) { int port = PortTool.getPort(); if (system.contains("win")) { ps = Runtime.getRuntime() - .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId, port) }); + .exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, port)}); } else if (system.contains("linux") || system.contains("mac")) { ps = Runtime.getRuntime() - .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId, port) }); + .exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, port)}); } GlobalProcessMap.getMap().put(processName, ps); shareJSON.put("port", port); @@ -977,10 +1002,10 @@ public static void startShare(String udId, int port) { Process ps = null; if (system.contains("win")) { ps = Runtime.getRuntime() - .exec(new String[] { "cmd", "/c", String.format(commandLine, sib, udId, port) }); + .exec(new String[]{"cmd", "/c", String.format(commandLine, sib, udId, port)}); } else if (system.contains("linux") || system.contains("mac")) { ps = Runtime.getRuntime() - .exec(new String[] { "sh", "-c", String.format(commandLine, sib, udId, port) }); + .exec(new String[]{"sh", "-c", String.format(commandLine, sib, udId, port)}); } GlobalProcessMap.getMap().put(processName, ps); } catch (Exception e) { diff --git a/src/main/java/org/cloud/sonic/agent/websockets/IOSWSServer.java b/src/main/java/org/cloud/sonic/agent/websockets/IOSWSServer.java index f8c7147d..4e8f7775 100755 --- a/src/main/java/org/cloud/sonic/agent/websockets/IOSWSServer.java +++ b/src/main/java/org/cloud/sonic/agent/websockets/IOSWSServer.java @@ -285,8 +285,32 @@ public void onMessage(String message, Session session) { sendText(session, proxy.toJSONString()); } case "installCert" -> SibTool.launch(udId, "com.apple.mobilesafari"); - case "launch" -> SibTool.launch(udId, msg.getString("pkg")); - case "kill" -> SibTool.kill(udId, msg.getString("pkg")); + case "launch" -> { + if (SibTool.isUpperThanIos17(udId)) { + if (iosDriver != null) { + try { + iosDriver.appActivate(msg.getString("pkg")); + } catch (SonicRespException e) { + log.info(e.fillInStackTrace().toString()); + } + } + } else { + SibTool.launch(udId, msg.getString("pkg")); + } + } + case "kill" -> { + if (SibTool.isUpperThanIos17(udId)) { + if (iosDriver != null) { + try { + iosDriver.appTerminate(msg.getString("pkg")); + } catch (SonicRespException e) { + log.info(e.fillInStackTrace().toString()); + } + } + } else { + SibTool.kill(udId, msg.getString("pkg")); + } + } case "uninstallApp" -> SibTool.uninstall(udId, msg.getString("detail")); case "debug" -> { switch (msg.getString("detail")) { From 0ba5757779771368480053271d0bff4ce21984b8 Mon Sep 17 00:00:00 2001 From: ZhouYixun <291028775@qq.com> Date: Tue, 20 Aug 2024 21:48:17 +0800 Subject: [PATCH 4/4] update_app_operate --- config/application-sonic-agent.yml | 4 +++- src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java | 2 +- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/config/application-sonic-agent.yml b/config/application-sonic-agent.yml index 8fadd29d..4a08dbf5 100755 --- a/config/application-sonic-agent.yml +++ b/config/application-sonic-agent.yml @@ -16,4 +16,6 @@ sonic: modules: ios: # Replace with the bundleId of wda. If there is no. xcrunner suffix, it will be automatically completed. | 替换为wda的bundleId,如果没有.xctrunner后缀会自动补全 - wda-bundle-id: com.sonic.WebDriverAgentRunner \ No newline at end of file + wda-bundle-id: com.sonic.WebDriverAgentRunner + # (mac only) Replace with the xcode project path of wda. | 替换为wda的xcode project目录 + wda-xcode-project-path: WebdriverAgent/WebDriverAgent.xcodeproj \ No newline at end of file diff --git a/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java b/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java index 65f8f1ec..d49ac22e 100755 --- a/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java +++ b/src/main/java/org/cloud/sonic/agent/bridge/ios/SibTool.java @@ -70,7 +70,7 @@ public class SibTool implements ApplicationListener { @Value("${modules.ios.wda-bundle-id}") private String getBundleId; - @Value("${modules.ios.wda-xcode-project-path}") + @Value("${modules.ios.wda-xcode-project-path:default}") private String getXcodeProjectPath; private static String bundleId;