From 9f05eaef216596d04f468da515c4594499f6a088 Mon Sep 17 00:00:00 2001 From: Alexey Andreev Date: Sun, 11 Oct 2015 12:09:00 +0300 Subject: [PATCH] Reconnect to webdriver after 100 test runs --- .../main/java/org/teavm/maven/SeleniumRunStrategy.java | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/tools/maven/plugin/src/main/java/org/teavm/maven/SeleniumRunStrategy.java b/tools/maven/plugin/src/main/java/org/teavm/maven/SeleniumRunStrategy.java index 721f60b35..ad09d1953 100644 --- a/tools/maven/plugin/src/main/java/org/teavm/maven/SeleniumRunStrategy.java +++ b/tools/maven/plugin/src/main/java/org/teavm/maven/SeleniumRunStrategy.java @@ -39,6 +39,7 @@ public class SeleniumRunStrategy implements TestRunStrategy { private URL url; private File directory; private ThreadLocal webDriver = new ThreadLocal<>(); + private ThreadLocal commandsSent = new ThreadLocal<>(); public SeleniumRunStrategy(URL url, File directory) { this.url = url; @@ -49,6 +50,7 @@ public class SeleniumRunStrategy implements TestRunStrategy { public void beforeThread() { RemoteWebDriver driver = new RemoteWebDriver(url, DesiredCapabilities.firefox()); webDriver.set(driver); + commandsSent.set(0); } @Override @@ -59,6 +61,13 @@ public class SeleniumRunStrategy implements TestRunStrategy { @Override public String runTest(Log log, String runtimeScript, TestCase testCase) throws IOException { + commandsSent.set(commandsSent.get() + 1); + if (commandsSent.get().equals(100)) { + commandsSent.set(0); + webDriver.get().close(); + webDriver.set(new RemoteWebDriver(url, DesiredCapabilities.firefox())); + } + webDriver.get().manage().timeouts().setScriptTimeout(2, TimeUnit.SECONDS); JavascriptExecutor js = (JavascriptExecutor) webDriver.get(); try {