Ashot - Невозможно сделать скриншот определенного элемента в Chrome

Когда я использую Ashot с селеном для захвата снимка экрана для определенного веб-элемента, он не работает. У меня также прикрепил логи для ознакомления.

Скриншот для полной страницы работает.

Примечание. Я обновил последнюю банку, как указано в комментарии.

Я использую драйвер Chrome, отдельную банку selenium 3.8.1, банку Ashot 1.5.2.

 @Test

public void launchBrowser() 
{        

   System.setProperty("webdriver.chrome.driver","/Applications/webdriver/chromedriver");

driver = new ChromeDriver();

    }
@Test
public void openApplication() throws IOException, InterruptedException
{

driver.get("https://myurl");

driver.manage().window().maximize();

 WebDriverWait wait = new WebDriverWait(driver, 50);
  wait.until(ExpectedConditions.visibilityOfElementLocated(By.id("commonuileftpanel")));
WebElement portal =driver.findElement(By.id("commonuileftpanel"));                                        
Screenshot myScreenshot = new AShot().takeScreenshot(driver,portal); 

BufferedImage original = myScreenshot.getImage();
BufferedImage expected = ImageIO.read(new File("/Applications/webdriver/results.png"));
ImageDiff diff = new ImageDiffer().makeDiff(original, expected);
BufferedImage difffullImage = diff.getMarkedImage();
File outputfile = new File("/Applications/webdriver/diffImage.png");
ImageIO.write(difffullImage, "PNG", outputfile);

Boolean diffval = diff.hasDiff();
Assert.assertFalse(diffval);

driver.quit();

}

@Test
public void closeDriver() 
{
if(driver!=null) 
{
driver.close();
}

Добавлен снимок экрана:
введите здесь описание изображения

Сообщение об ошибке :

Starting ChromeDriver 2.34.522932 (4140ab217e1ca1bec0c4b4d1b148f3361eb3a03e) on port 3753
Only local connections are allowed.
Jan 12, 2018 4:02:52 PM org.openqa.selenium.remote.ProtocolHandshake createSession
INFO: Detected dialect: OSS
ChromeDriver: chrome on MAC (d1a7d84c06ae31e76c872e6be1a61824)

PASSED: closeDriver
PASSED: launchBrowser
FAILED: openApplication
org.openqa.selenium.WebDriverException: unknown error: Cannot read property 'offset' of null
  (Session info: chrome=63.0.3239.132)
  (Driver info: chromedriver=2.34.522932 (4140ab217e1ca1bec0c4b4d1b148f3361eb3a03e),platform=Mac OS X 10.13.1 x86_64) (WARNING: The server did not provide any stacktrace information)
Command duration or timeout: 0 milliseconds
Build info: version: '3.8.1', revision: '6e95a6684b', time: '2017-12-01T19:05:32.194Z'
System info: host: 'test', ip: '', os.name: 'Mac OS X', os.arch: 'x86_64', os.version: '10.13.1', java.version: '1.8.0_152'
Driver info: org.openqa.selenium.chrome.ChromeDriver
Capabilities {acceptSslCerts: true, applicationCacheEnabled: false, browserConnectionEnabled: false, browserName: chrome, chrome: {chromedriverVersion: 2.34.522932 (4140ab217e1ca1..., userDataDir: /var/folders/j_/f03djz4n2bv...}, cssSelectorsEnabled: true, databaseEnabled: false, handlesAlerts: true, hasTouchScreen: false, javascriptEnabled: true, locationContextEnabled: true, mobileEmulationEnabled: false, nativeEvents: true, networkConnectionEnabled: false, pageLoadStrategy: normal, platform: MAC, platformName: MAC, rotatable: false, setWindowRect: true, takesHeapSnapshot: true, takesScreenshot: true, unexpectedAlertBehaviour: , unhandledPromptBehavior: , version: 63.0.3239.132, webStorageEnabled: true}
Session ID: d1a7d84c06ae31e76c872e6be1a61824
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at org.openqa.selenium.remote.ErrorHandler.createThrowable(ErrorHandler.java:214)
    at org.openqa.selenium.remote.ErrorHandler.throwIfResponseFailed(ErrorHandler.java:166)
    at org.openqa.selenium.remote.http.JsonHttpResponseCodec.reconstructValue(JsonHttpResponseCodec.java:40)
    at org.openqa.selenium.remote.http.AbstractHttpResponseCodec.decode(AbstractHttpResponseCodec.java:80)
    at org.openqa.selenium.remote.http.AbstractHttpResponseCodec.decode(AbstractHttpResponseCodec.java:44)
    at org.openqa.selenium.remote.HttpCommandExecutor.execute(HttpCommandExecutor.java:164)
    at org.openqa.selenium.remote.service.DriverCommandExecutor.execute(DriverCommandExecutor.java:83)
    at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:601)
    at org.openqa.selenium.remote.RemoteWebDriver.executeScript(RemoteWebDriver.java:537)
    at ru.yandex.qatools.ashot.util.JsCoords.findCoordsWithJquery(JsCoords.java:30)
    at ru.yandex.qatools.ashot.coordinates.JqueryCoordsProvider.ofElement(JqueryCoordsProvider.java:13)
    at ru.yandex.qatools.ashot.coordinates.CoordsProvider.ofElements(CoordsProvider.java:21)
    at ru.yandex.qatools.ashot.AShot.takeScreenshot(AShot.java:115)
    at ru.yandex.qatools.ashot.AShot.takeScreenshot(AShot.java:132)
    at ExampleSel3.screenshotParticularTag(ExampleSel3.java:187)
    at ExampleSel3.openApplication(ExampleSel3.java:96)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:124)
    at org.testng.internal.Invoker.invokeMethod(Invoker.java:571)
    at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:707)
    at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:979)
    at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:125)
    at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:109)
    at org.testng.TestRunner.privateRun(TestRunner.java:648)
    at org.testng.TestRunner.run(TestRunner.java:505)
    at org.testng.SuiteRunner.runTest(SuiteRunner.java:455)
    at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:450)
    at org.testng.SuiteRunner.privateRun(SuiteRunner.java:415)
    at org.testng.SuiteRunner.run(SuiteRunner.java:364)
    at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
    at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:84)
    at org.testng.TestNG.runSuitesSequentially(TestNG.java:1187)
    at org.testng.TestNG.runSuitesLocally(TestNG.java:1116)
    at org.testng.TestNG.runSuites(TestNG.java:1028)
    at org.testng.TestNG.run(TestNG.java:996)
    at org.testng.remote.AbstractRemoteTestNG.run(AbstractRemoteTestNG.java:132)
    at org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:236)
    at org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:81)

person sasikumar    schedule 11.01.2018    source источник


Ответы (1)


Ошибка говорит сама за себя:

org.openqa.selenium.WebDriverException: unknown error: Cannot read property 'offset' of null

Не похоже, что ваша казнь дошла до new AShot().takeScreenshot(driver,portal);

Ваша основная проблема заключается в совместимости версий между используемыми вами двоичными файлами следующим образом:

  • Вы используете java.version: '1.8.0_77'
  • Вы используете chromedriver=2.34.522932
  • Вы используете chrome=63.0.3239.132
  • Но вы используете Selenium v2.52.0 из '2016-02-11 19:06:42'

Решение

  • Обновите JDK до последних уровней Version 8 Update 151.
  • Оставьте ChromeDriver на уровне ChromeDriver v2.34.
  • Оставьте Chrome на уровне Chrome v63.x.
  • Обновите Selenium до текущих уровней Version 3.8.1.
  • Выполните свой Test.

Подробное обсуждение ошибки sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) вы можете увидеть в этом Discussion

person DebanjanB    schedule 11.01.2018
comment
Спасибо за комментарий . Я пробовал, как вы сказали, но та же ошибка, org.openqa.selenium.WebDriverException: неизвестная ошибка: невозможно прочитать свойство «смещение» нуля (информация о драйвере: chromedriver = 2.34.522932 (4140ab217e1ca1bec0c4b4d1b148f3361eb3a03e), платформа = Mac OS X 10.13.1 x86_64 ) (ВНИМАНИЕ: сервер не предоставил никакой информации о трассировке стека) Продолжительность или время ожидания команды: 0 миллисекунд Информация о сборке: версия: «3.8.1», ревизия: «6e95a6684b», время: «2017-12-01T19:05:32.194Z». ' Информация о системе: хост: 'test', ip: '', os.name: 'Mac OS X', os.arch: 'x86_64', os.version: '10.13.1', java.version: '1.8. 0_152' - person sasikumar; 11.01.2018
comment
4 дополнительных шага: 1) Clean Project из вашего IDE и Build рабочего пространства вашего проекта. 2) Запустите инструмент CCleaner, чтобы стереть все хлопоты ОС. 3) Если ваша базовая версия Chrome слишком старая, с uninstall Chrome до Revo Uninstaller установите последнюю общедоступную версию Chrome. 4) Запустите Test. - person DebanjanB; 11.01.2018
comment
Пожалуйста, обновите вопрос, указав полный блок кода и полную трассировку стека ошибок. - person DebanjanB; 11.01.2018
comment
Я сделал все, кроме пункта 2, вместо этого перезагрузил свою машину. Опять та же ошибка. - person sasikumar; 11.01.2018
comment
Все пункты №1, №2 и №3 имеют решающее значение. Регулярное использование пункта № 2 избавит вас от всех нежелательных ошибок. Сделайте это один раз и дайте мне знать статус. - person DebanjanB; 11.01.2018
comment
Сделал все та же проблема! - person sasikumar; 12.01.2018
comment
@sasikumar Можете ли вы обновить вопрос свежим набором журналов, чтобы проанализировать, что происходит не так? - person DebanjanB; 12.01.2018
comment
Я до сих пор не верю в ошибку, выходящую из aShot(). Можете ли вы обновить вопрос со всеми аннотациями @Test для PASSED: closeDriver PASSED: launchBrowser and FAILED: openApplication - person DebanjanB; 12.01.2018
comment
любые подсказки для выше! - person sasikumar; 22.01.2018
comment
Я все еще не думаю, что проблема (By.id("commonuileftpanel")) решается. Можете ли вы поделиться соответствующей HTML? - person DebanjanB; 22.01.2018
comment
Я уже добавил скриншот! вы хотите, чтобы я добавил больше HTML - person sasikumar; 22.01.2018