From 9a491b040d5c9d11e227acfdecfa867e5d7cf7d2 Mon Sep 17 00:00:00 2001 From: Henri Sara Date: Fri, 11 Aug 2017 11:09:58 +0300 Subject: Make CurrentTimeMillisTest more stable (#9812) Sometimes Chrome reports 1ms for very short times to thwart timing attacks, and sometimes Firefox seems to report 0ms. Make the test accept these special cases. Add support for PhantomJS 2 which does support high res time. --- .../test/java/com/vaadin/tests/CurrentTimeMillisTest.java | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) (limited to 'uitest') diff --git a/uitest/src/test/java/com/vaadin/tests/CurrentTimeMillisTest.java b/uitest/src/test/java/com/vaadin/tests/CurrentTimeMillisTest.java index b703a3b2a5..2bfa1f9ad4 100644 --- a/uitest/src/test/java/com/vaadin/tests/CurrentTimeMillisTest.java +++ b/uitest/src/test/java/com/vaadin/tests/CurrentTimeMillisTest.java @@ -40,8 +40,9 @@ public class CurrentTimeMillisTest extends MultiBrowserTest { setDebug(true); openTestURL(); - boolean highResTimeSupported = !BrowserUtil - .isPhantomJS(getDesiredCapabilities()) + boolean phantomJs1 = BrowserUtil.isPhantomJS(getDesiredCapabilities()) + && "1".equals(getDesiredCapabilities().getVersion()); + boolean highResTimeSupported = !phantomJs1 && !BrowserUtil.isSafari(getDesiredCapabilities()); String time = getJsonParsingTime(); @@ -51,13 +52,15 @@ public class CurrentTimeMillisTest extends MultiBrowserTest { time = time.substring(0, time.length() - 2); } if (highResTimeSupported) { - if (BrowserUtil.isChrome(getDesiredCapabilities())) { + if (BrowserUtil.isChrome(getDesiredCapabilities()) + || BrowserUtil.isFirefox(getDesiredCapabilities())) { // Chrome (version 33 at least) sometimes doesn't use high res - // time if number of ms is less then 1 + // time for very short times Assert.assertTrue( "High resolution time is not used in " + "JSON parsing mesurement. Time=" + time, - time.equals("0") || time.indexOf('.') > 0); + time.equals("0") || time.equals("1") + || time.indexOf('.') > 0); } else { Assert.assertTrue( "High resolution time is not used in " -- cgit v1.2.3