How to use startAgentProcess method of com.testsigma.agent.launcher.Launcher class

Best Testsigma code snippet using com.testsigma.agent.launcher.Launcher.startAgentProcess

Source:Launcher.java Github

copy

Full Screen

...82 //Commenting out restart option dues continuous restart when web server config fetch fails83 //this.restart();84 });85 command = launcher.agentStartCommand(launcher.wrapperServer.getLocalPort());86 launcher.agentProcess = launcher.startAgentProcess(command);87 log.debug("Waiting for Agent to start...");88 int agentStartupChecks = 60;89 while (agentStartupChecks > 0) {90 try {91 log.debug("Waiting for Agent to start");92 TimeUnit.SECONDS.sleep(1L);93 } catch (Exception e) {94 log.error(e.getMessage(), e);95 }96 if (!launcher.agentProcess.isAlive()) {97 log.error("Agent exited unexpectedly with exit code - " + launcher.agentProcess.exitValue());98 break;99 }100 if (launcher.ipcSocket != null) break;101 agentStartupChecks--;102 }103 if (launcher.ipcSocket != null) {104 log.info("Agent started successfully with process - " + agentProcess.pid());105 setStatus(AgentStatus.STARTED);106 } else {107 log.error("Failed to start agent....");108 }109 } catch (Exception e) {110 launcher.completableFuture.completeExceptionally(e);111 } finally {112 handleFailedStart();113 }114 });115 }116 private void restart() {117 if (this.running) {118 if (this.restart) {119 log.info("Agent restart requested");120 this.restart = false;121 }122 if (this.agentProcess != null && this.agentProcess.exitValue() != 0) {123 log.info("Agent exit was not clean. Exit code - " + this.agentProcess.exitValue());124 this.shutdown();125 return;126 }127 log.info("Starting Agent again....");128 this.start();129 }130 }131 private void shutdownLauncher() {132 Thread.currentThread().setName("shutdown-hook");133 this.running = false;134 shutdown();135 waitForAgentToStop();136 this.completableFuture.complete(null);137 log.info("Shutting down Launcher");138 }139 private void shutdown() {140 if (this.agentStatus.equals(AgentStatus.STOPPING) || this.agentStatus.equals(AgentStatus.STOPPED))141 return;142 log.info("Agent shutdown initiated");143 Process process = this.agentProcess;144 setStatus(AgentStatus.STOPPING);145 shutdownAgent();146 setStatus(AgentStatus.STOPPED);147 Executors.newSingleThreadScheduledExecutor().schedule(() -> {148 try {149 if (process.isAlive()) {150 log.info("Stopping agent process forcibly since agent process didn't exit normally");151 process.destroyForcibly();152 }153 } catch (Exception exception) {154 log.error(exception.getMessage(), exception);155 }156 }, 10L, TimeUnit.SECONDS);157 }158 private void shutdownAgent() {159 stopIpcSocket();160 stopWrapperServer();161 stopFuture();162 stopIpcSocketExecutorService();163 }164 private void waitForAgentToStop() {165 while (this.agentProcess != null && this.agentProcess.isAlive()) {166 log.info("Agent is still running, waiting");167 try {168 TimeUnit.SECONDS.sleep(1L);169 } catch (InterruptedException ignored) {170 }171 }172 }173 private void setStatus(AgentStatus agentStatus) {174 this.agentStatus = agentStatus;175 log.info("Changed Agent status to - " + agentStatus);176 if (this.background)177 return;178 this.systemTray.setStatus(String.format("Testsigma Agent - %s", agentStatus));179 }180 private List<String> agentStartCommand(int wrapperPort) throws URISyntaxException {181 RuntimeMXBean runtimeMXBean = ManagementFactory.getRuntimeMXBean();182 List<String> list = runtimeMXBean.getInputArguments();183 List<String> commandLineParameters = new ArrayList<>();184 for (String listStr : list) {185 if (!listStr.startsWith("-agentlib")) {186 commandLineParameters.add(listStr);187 }188 }189 List<String> command = new ArrayList<>();190 command.add(getJavaPath());191 command.addAll(commandLineParameters);192 command.add("-cp");193 command.add(getAgentClassPath());194 command.add("-Dagent.wrapper.port=" + wrapperPort);195 command.add("-Dagent.wrapper.background=" + this.background);196 command.add("com.testsigma.agent.TestsigmaAgent");197 return command;198 }199 private void sendFlare() {200 String alertMessage = "Unknown Error";201 try {202 client = HttpClients.createDefault();203 HttpGet getRequest = new HttpGet("http://localhost:8383/agent/api/v1/flare");204 HttpResponse response = client.execute(getRequest);205 if (response.getEntity() != null) {206 alertMessage = EntityUtils.toString(response.getEntity());207 }208 log.info("Response from flare request - " + response.getStatusLine() + " - " + alertMessage);209 } catch (Exception e) {210 alertMessage = e.getMessage();211 log.error(e.getMessage(), e);212 } finally {213 showMessageDialog(null, alertMessage);214 HttpClientUtils.closeQuietly(client);215 }216 }217 private void configureSystemTrayIcon() {218 if (GraphicsEnvironment.isHeadless()) {219 log.info("No Graphics environment available - headless mode.");220 this.background = true;221 }222 if (!this.background) {223 log.info("Loading System Tray icon");224 this.systemTray = SystemTray.get();225 InputStream inputStream = Launcher.class.getClassLoader().getResourceAsStream("icons/tray_icon.png");226 systemTray.setImage(inputStream);227 setStatus(AgentStatus.STOPPED);228 systemTray.getMenu().add((Entry) new dorkbox.systemTray.MenuItem("Send Flare Request", (ActionEvent actionEvent) -> {229 log.info("Agent send flare request menu action triggered");230 MenuItem menuItem = ((MenuItem) actionEvent.getSource());231 menuItem.setEnabled(false);232 sendFlare();233 menuItem.setEnabled(true);234 }));235// systemTray.getMenu().add((Entry) new dorkbox.systemTray.MenuItem("Restart", (ActionEvent actionEvent) -> {236// log.info("Agent restart menu action triggered");237// this.restart = true;238// shutdown();239// }));240 systemTray.getMenu().add((Entry) new MenuItem("Quit", (ActionEvent actionEvent) -> {241 log.info("Agent quit menu action triggered");242 Runtime.getRuntime().removeShutdownHook(this.shutdownHookThread);243 shutdownLauncher();244 if (!this.background) {245 this.systemTray.shutdown();246 }247 }));248 this.setupFrame();249 }250 }251 public void handleFailedStart() {252 if (this.ipcSocket == null) {253 if ((this.agentProcess != null) && agentProcess.isAlive()) {254 this.agentProcess.destroyForcibly();255 }256 this.shutdownAgent();257 }258 }259 private String getJavaPath() {260 String rootDir = System.getProperty("TS_ROOT_DIR");261 if (StringUtils.isNotBlank(rootDir)) {262 System.setProperty("java.home", rootDir + File.separator + "jre");263 }264 return System.getProperty("java.home") + File.separator + "bin" + File.separator + "java";265 }266 private String getAgentClassPath() throws URISyntaxException {267 String classPath = System.getProperty("TS_AGENT_JAR") + File.separator + "lib" + File.separator + "*";268 String additionalClassPath = Config.getDataDir() + File.separator + "additional_libs" + File.separator + "*";269 String agentJarPath = getAgentJarPath();270 return agentJarPath + classPathSeparator + classPath + classPathSeparator + additionalClassPath;271 }272 private String getAgentJarPath() throws URISyntaxException {273 String agentJarDir = System.getProperty("TS_AGENT_JAR");274 if (StringUtils.isNotBlank(agentJarDir)) {275 return agentJarDir + File.separator + "agent.jar";276 }277 URL uRL = Launcher.class.getProtectionDomain().getCodeSource().getLocation();278 Path path = (new File(uRL.toURI())).toPath().getParent();279 return Paths.get(path.toAbsolutePath().toString(), "agent.jar").toAbsolutePath().toString();280 }281 private void startIpcSocket() {282 log.info("Accepting connection to the launcher socket....");283 try {284 this.ipcSocket = this.wrapperServer.accept();285 log.info("Agent connected to IPC socket...");286 } catch (Exception e) {287 log.error(e.getMessage(), e);288 }289 if (this.ipcSocket != null) {290 try {291 int data = this.ipcSocket.getInputStream().read();292 while (data != -1) {293 data = this.ipcSocket.getInputStream().read();294 }295 } catch (Exception e) {296 log.info("Agent disconnected from IPC socket");297 }298 } else {299 log.error("Agent not connected to IPC socket");300 }301 }302 private void stopIpcSocket() {303 if (this.ipcSocket != null) {304 try {305 this.ipcSocket.close();306 } catch (IOException e) {307 log.error(e.getMessage(), e);308 }309 this.ipcSocket = null;310 }311 }312 private void startWrapperServer() throws IOException {313 this.wrapperServer = new ServerSocket(0);314 log.info("Agent wrapper server started on port " + this.wrapperServer.getLocalPort());315 this.socketExecutorService = Executors.newSingleThreadExecutor();316 }317 private void stopWrapperServer() {318 if (this.wrapperServer != null) {319 try {320 this.wrapperServer.close();321 } catch (Exception e) {322 log.error(e.getMessage(), e);323 }324 this.wrapperServer = null;325 }326 }327 private void stopFuture() {328 try {329 if (this.future != null && !this.future.isDone()) {330 this.future.get(10L, TimeUnit.SECONDS);331 }332 } catch (Exception e) {333 log.error(e.getMessage(), e);334 this.future.cancel(true);335 }336 }337 private void stopIpcSocketExecutorService() {338 if (this.socketExecutorService != null && !this.socketExecutorService.isTerminated()) {339 try {340 this.socketExecutorService.shutdown();341 if (!this.socketExecutorService.awaitTermination(10L, TimeUnit.SECONDS)) {342 log.warn("Failed to stop socketExecutorService in timely manner, force stopping...");343 this.socketExecutorService.shutdownNow();344 }345 } catch (Exception e) {346 log.error(e.getMessage(), e);347 this.socketExecutorService.shutdownNow();348 }349 }350 }351 private void cleanupAgentProcess() {352 if (this.agentProcess != null) {353 try {354 if (this.agentProcess.waitFor(20L, TimeUnit.SECONDS)) {355 log.info("Agent process stopped. Exit code - " + this.agentProcess.exitValue());356 } else {357 log.error("Agent process is taking too long to exit. Forcing agent to shutdown forcefully....");358 this.agentProcess.destroyForcibly();359 }360 } catch (Exception e) {361 log.error(e.getMessage(), e);362 this.agentProcess.destroyForcibly();363 }364 }365 }366 private Process startAgentProcess(List<String> command) throws IOException {367 log.debug("Starting Agent using command: " + String.join(" ", command));368 ProcessBuilder processBuilder = new ProcessBuilder(command);369 processBuilder.environment().put("JAVA_HOME", System.getProperty("java.home"));370 processBuilder.environment().put("PATH", System.getenv("PATH") + File.pathSeparator + System.getProperty("java.home"));371 processBuilder.redirectInput(ProcessBuilder.Redirect.INHERIT);372 processBuilder.redirectOutput(ProcessBuilder.Redirect.INHERIT);373 processBuilder.redirectError(ProcessBuilder.Redirect.INHERIT);374 return processBuilder.start();375 }376 private void setupFrame() {377 try {378 final Toolkit defaultToolkit = Toolkit.getDefaultToolkit();379 final URL imageResource = Launcher.class.getClassLoader().getResource("icons/dock_icon.png");380 final Image image = defaultToolkit.getImage(imageResource);...

Full Screen

Full Screen

startAgentProcess

Using AI Code Generation

copy

Full Screen

1import com.testsigma.agent.launcher.Launcher;2import com.testsigma.agent.launcher.LauncherException;3public class StartAgentProcess {4 public static void main(String[] args) {5 try {6 Launcher.startAgentProcess();7 } catch (LauncherException e) {8 e.printStackTrace();9 }10 }11}

Full Screen

Full Screen

startAgentProcess

Using AI Code Generation

copy

Full Screen

1import com.testsigma.agent.launcher.Launcher;2import com.testsigma.agent.launcher.LauncherFactory;3import com.testsigma.agent.launcher.LauncherConfig;4public class AgentLauncher {5 public static void main(String[] args) throws Exception {6 LauncherConfig config = new LauncherConfig();7 config.setAgentId("agent1");8 config.setAgentName("agent1");9 config.setAgentType("desktop");10 config.setAgentVersion("1.0");11 config.setProjectName("MyProject");12 config.setSeleniumGridBrowser("chrome");13 config.setSeleniumGridBrowserVersion("latest");14 config.setSeleniumGridPlatform("windows");15 config.setSeleniumGridMaxInstances(1);16 config.setSeleniumGridMaxSessions(1);17 config.setSeleniumGridBrowserTimeout(120);18 config.setSeleniumGridBrowserTimeoutWait(30);19 config.setSeleniumGridBrowserTimeoutRetry(3);20 config.setSeleniumGridBrowserTimeoutRetryInterval(3);21 config.setSeleniumGridBrowserTimeoutRetryOnFailure(true);22 config.setSeleniumGridBrowserTimeoutRetryOnTimeout(true);23 config.setSeleniumGridBrowserTimeoutRetryOnSessionFailure(true);24 config.setSeleniumGridBrowserTimeoutRetryOnSessionTimeout(true);25 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotCreated(true);26 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotStarted(true);27 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotConnected(true);28 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotReachable(true);29 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotAvailable(true);30 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotConnected(true);31 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotReachable(true);32 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotAvailable(true);33 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotConnected(true);34 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotReachable(true);35 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotAvailable(true);36 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotConnected(true);37 config.setSeleniumGridBrowserTimeoutRetryOnSessionNotReachable(true);

Full Screen

Full Screen

startAgentProcess

Using AI Code Generation

copy

Full Screen

1import com.testsigma.agent.launcher.Launcher;2Launcher.startAgentProcess(“agent.config”);3Launcher.startAgentProcess(“agent.config”, “agent.log”);4Launcher.startAgentProcess(“agent.config”, “agent.log”, “agent.pid”);5Launcher.startAgentProcess(“agent.config”, “agent.log”, “agent.pid”, “agent.out”);6Launcher.startAgentProcess(“agent.config”, “agent.log”, “agent.pid”, “agent.out”, “agent.err”);7Launcher.startAgentProcess(“agent.config”, “agent.log”, “agent.pid”, “agent.out”, “agent.err”, “agent.status”);8Launcher.startAgentProcess(“agent.config”, “agent.log”, “agent.pid”, “agent.out”, “agent.err”, “agent.status”, “agent.port”);9Launcher.startAgentProcess(“agent.config”, “agent.log”, “agent.pid”, “agent.out”, “agent.err”, “agent.status”, “agent.port”, “agent.host”);10Launcher.startAgentProcess(“agent.config”, “agent.log”, “agent.pid”, “agent.out”, “agent.err”, “agent

Full Screen

Full Screen

Automation Testing Tutorials

Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful