What is the difference between Selenium Webdriver and GeckoDriver? - java

I use Selenium every 5 years or so and everytime it has changed beyond recognition. I just started a new Selenium project, googled some quickstart guides such as https://www.toolsqa.com/selenium-webdriver/run-selenium-test/ (written in September 2020) and https://www.guru99.com/first-webdriver-script.html (© 2020) and both seem to use WebDriver, e.g., by initiating their examples with WebDriver driver = new FirefoxDriver(); although the latter has a disclaimer saying that from Firefox 35 (I have 82) and up you should use Geckodriver.
I use Selenium for Java 3.141.59 downloaded from https://www.selenium.dev/downloads/ but it only has two references to Geckodriver (at least that is all that is displayed when it enter Ge and autocomplete in my IDE), GeckoDriverInfo and GeckoDriverService (as a comparison, there are nine references to WebDriver).
I have read the information here https://github.com/mozilla/geckodriver but it didn't make me any wiser, nor did https://en.wikipedia.org/wiki/Selenium_(software)#Selenium_WebDriver (Geckodriver isn't even mentioned on this Wikipedia page).
What is the difference between Webdriver and Geckodriver?
Why, if one download the newest/current version of everything, isn't Geckodriver included if that is the recommended tool since several (?) years?
Why are guides that are written recently use Webdriver if Geckodriver is the way to go?
I think I have done a reasonably amount of research before asking this question but feel free to suggest improvements because I am genuinely confused.

WebDriver is a specification. It defines the way how UI interfaces can be automated. GeckoDriver is the implementation of such specification - it is the WebDriver implementation for Firefox browser.
So basically a WebDriver is a server that exposes REST API to one side and that knows how to control browser on another side.
Here is short explanation of E2E flow (for Firefox and Java):
You download Selenium java library. It provides Java client for interacting with web drivers
You download GeckoDriver
In your Java code you call WebDriver driver = new FirefoxDriver();
Selenium library starts GeckoDriver executable in OS native manner
In your Java code you call driver.get("http://my.url")
Selenium library forms REST call to the server that is started with GeckoDriver. It invokes the endpoint according to this section of specification.
GeckoDriver then translates this command to somewhat that Firefox understands so that the browser navigates to required page.
So basically you need 3 things to make everything work:
Selenium Java library that is basically a Java client for WebDriver REST API
GeckoDriver (that implements REST API according to WebDriver specification and translates it to commands which Firefox browse can understand)
Firefox browser

webdriver, is the parent of ChromeDriver ( from chrome ), GeckoDriver ( FireFox ), IEDriver and RemoteDriver. Possibly even more if they are supported. So, the GeckoDriver is used to control a FireFox Browser instance, but it implements the methods mentioned in the WebDriver interface.
GeckoDriver is not included as it is specific to FireFox only, other users may want to use other browsers.
To keep the flexibility of swapping out the implementations for different browsers. :)

Related

Headless Chrome - getting blank page source

I'm trying to load a website with Chrome browser in headless mode using Selenium web driver. I face an issue with some specific websites. The page is loading, in the first 2-3 seconds it shows a page with "please enable javascript..." and after 3 seconds, page source goes blank.
I'm using Selenium and especially Chrome for long time and I am familiar with the platform. For the purpose of this case, I'm using Chrome Version 73.0.3683.86 , ChromeDriver 2.46.628411 (which is compatible according to Which ChromeDriver version is compatible with which Chrome Browser version?) on a Mac OS. selenium java version is latest - 3.141.59
I suspect that headless Chrome cannot handle specific content-type such as "svg" and any other GUI related HTTP response.
ChromeOptions chromeOptions = new ChromeOptions();
chromeOptions.addArguments("--headless");
WebDriver driver = new ChromeDriver(chromeOptions);
driver.get("https://identity.tescobank.com/login");
Thread.sleep(3000);
System.out.println(driver.getPageSource());
driver.quit();
Expected result is to have the page source same as it is showing in non-headless mode.
Headless Chrome should be able to handle everything the normal Chrome can do:
It brings all modern web platform features provided by Chromium and the Blink rendering engine to the command line.
(see https://developers.google.com/web/updates/2017/04/headless-chrome)
Since only the login page of a bank causes you trouble, my guess is that the security of the page detects an anomaly and decides not to serve you.
One way they can do that is by looking at the User Agent string which contains HeadlessChrome.
That said, unless you're writing integration tests for the bank, your behavior is at least suspicious. If you have a valid and legal concern, clear it with the bank first. They might take actions against you, otherwise. Blocking your IP address (which could affect many people) or asking the police to have a word with you.
I was facing similar issue in my script, after login. Somehow refreshing the page resolved the issue.
driver.navigate().refresh();

Selenium WebDriver Safari (11.0) TypeError: Value is not a sequence

I'm trying to automate some regression tests for a site using Selenium but get the below console errors in Safari 11.0 whenever the WebDriver extension is active (not there when disabled):
TypeError: Value is not a sequence
TypeError: Not enough arguments
Looks like the same issue this user was seeing:
Value is not a sequence Safari exception
But in my case I need the extension in order to run my test build.
(Right? Or can I somehow disable it and still run automated tests?)
I use BrowserStack for my test browsers (I can see the TypeErrors by using their "Live" environment and opening the dev tools there) but need a way to test the site in "Automate" without the extension breaking the sections I'm trying to test.
When I execute my actual automated test I get the error "Expected condition failed: waiting for presence of element" because the needed section of the site entirely fails to load. The test works in other browsers and even older versions of Safari.
I'm new to Selenium and Java so any suggestions on how to get this test running in Safari 11.0 would be greatly appreciated.
My automated test uses Java (Java(TM) SE Runtime Environment (build 9.0.1+11), Selenium 3.7.1 and Eclipse.
Safari provides native support for the WebDriver API starting Safari 10. Source: https://webkit.org/blog/6900/webdriver-support-in-safari-10/. Safari 11 uses the same native Safari toolkit for supporting automation using Selenium and no longer needs the WebDriver extension. This option can be enabled for Safari 11 from Develop > Allow Remote Automation.
The errors you highlighted are due to the WebDriver extension and it should be removed/disabled when running Selenium tests on Safari 11. You should connect with their support team and check if they provide an additional capability to disable this.

Selenium Chrome Driver Limitations Web Scraping at Scale

I'm planning to use Selenium Chrome Driver for my project which will be used to do web scraping to multiple public websites (something like kayak or skyscanner). So there will be a REST GET endpoint where my backend would launch headless Chrome to scrape multiple websites, and eventually return a manipulated JSON.
I want to know how scalable is Chrome Driver as it sounds like a headless Chrome instance needs to be launched whenever a request comes in.
Updated: Question using Google Chrome Headless
Please find the pros and cons of phantom js which I noticed during implementation .Hope this helps.
Cons:
1)It will fail to recognize the browser elements like id,xpath,csselector
when compared to chrome driver.
2)If you have login mechanism ,redirects won't work as you expect when compared to chrome driver.
3)You need to manually implement the custom logic for screen shots for the test failures if you need it.
4)If you want to switch between multiple drivers like chrome,html etc then it is very difficult
Pros:
1)Test case execution is faster when compared to chrome driver
2)No browser is required it will run without GUI.
3)No much configurations are needed when compared to chromedriver.
You can go with html driver also which is quite faster then phantom but even it has its own limitations that you need take care of before implementation.
I am not sure that you really need to use PhantomJS.
Chrome implemented "headless" mode couple of months ago.
"Headless Chrome" does the same job that PhantomJS, and does it better.
I heard that PhantomJS authors even said that they will not support it anymore.
You can enable headless mode in Selenide with just on line:
Configuration.headless = true;
Did you think about headless chrome?
Headless Chrome

Selenium WebDriver Multi-Threading & Browser Hiding using Java

I'm using the Java API of the Selenium WebDriver:
Is it possible to create multiple instances of the Selenium WebDriver from different threads simultaneously without conflict?
How do I change the path of the firefox installation directory that WebDriver uses if I installed firefox in a different directory?
How can I hide all the instances of the browsers(e.g firefox) that those threads started?
Thank you.
I can give you an answer to your first question.
Yes, you can run multiple driver instances simultaneously. However it is not recommended to run more than 5 or so instances at once in a single selenium server. Selenium Grid was designed specifically for this (it is bundled with the Selenium Server).

Supported browsers for Selenium2 (WebDriver)

Does anyone know what browsers are supported by WebDriver?
The official documents doesn't explicitly state it yet urging us to work with Selenium2.0 instead of 1.0.
Since Selenium has merged with WebDriver, there are a number of specific drivers that have been developed. If you look at the javadoc for the WebDriver interface you can see them. I count so far (in no particular order):
Chrome
Android
iPhone (iOS?)
Firefox
Internet Explorer
Opera (on github, thanks Martin)
This list will no doubt change as more browsers become supported.
Chrome Driver
Firefox Driver
Internet Explorer driver
HtmlUnit driver
Opera driver
iPhone driver
Android driver
Safari also will be available by year’s end

Categories

Resources