📢 Are you a TestProject user looking to migrate to an open source alternative?

Learn more
Selenium with Python Tutorial: Getting started with Test Automation

Selenium with Python Tutorial: Getting started with Test Automation

Developers prioritize implementing changes rapidly in an agile environment. When updating a front-end component, they must perform cross-browser testing. Web apps’ technological and functional capabilities have continuously increased over the years. Automated testing is necessary to ensure that these functionalities and the UI are functioning properly. 

Python is ranked third among programming languages in the Stack Overflow Developer Survey of 2021, after JavaScript and HTML/CSS. With Selenium being the most used tool for automated testing, the combined capabilities of Selenium and Python aid in automating interactions with Web Elements in the Document Object Model.

Let us learn more about the Selenium Python binding with integrated Python Selenium examples for a better understanding. Transform your automation solution with the extensive Selenium Python tutorial below!

What is Selenium?

Selenium is a lightweight, open-source automation testing framework for web applications. It supports a number of browsers, including Safari, Firefox, Chrome, and Internet Explorer. Additionally, it may mimic behaviors like clicking links, completing forms, and making purchases on a website.

To test online applications, Selenium can automate web browser interaction. Selenium is frequently used with other software testing tools like JUnit or TestNG to generate thorough automated tests for online applications.

Selenium can also automatically test web applications for functionality and performance. Furthermore, Selenium can produce reports or automatically scrape data from websites. The fact that Selenium is an open-source technology gives it a significant edge over other testing tools in that there are no license fees.

Additional elements influencing Selenium’s growing popularity include –

  • You can develop a test script in any programming language: Python, Java, Ruby, C#, Perl, PHP, and .Net.
  • Windows, Mac, and Linux are the three supported operating platforms for testing.
  • It provides continuous testing through the use of Jenkins, Maven, and Docker.

What is Python?

Python is a versatile programming language that has become increasingly popular in recent years. Unlike some other languages, Python is relatively easy to learn and can be used for a wide variety of tasks. For example, Python is often used for web development, scientific computing, artificial intelligence, and even video games. 

Despite its flexibility, Python remains a concise and readable language that programmers of all levels of experience admire. In addition, the Python community is large and supportive, making it an ideal choice for those just starting in the programming world. Whether you’re looking to build a new website or create the next blockbuster game, Python is worth considering as your go-to language.

Python is a widely used high-level interpreted language. Known for its ease of use and readability, Python has recently gained popularity for its Selenium bindings, which allow WebDrivers to be controlled by Python code. You can find Python Selenium example code easily online. 

Selenium Python bindings provide a convenient API to access Selenium WebDrivers like Firefox, Chrome, Edge, etc. These bindings enable you to create concise and reliable tests with little code. As a result, Python has become a popular choice for automating web browser testing.

Why do we use Selenium and Python for automation testing?

Selenium has a powerful toolkit that firmly supports the rapid development of test automation for online applications. It provides a selection of testing features that meet the needs of web application testing. Python, on the other hand, is an object-based, high-level scripting language designed specifically for simple interpretation.

Some of the reasons why Selenium Python automation testing is more convenient are –

  • It is easy to read, easy to code, and runs rapidly.

  • The Python API makes it easier to connect to the browser using Selenium. Python Selenium bonding provides straightforward APIs for conducting practical and functional tests on Selenium WebDriver effectively.

  • Python is a computer language that is extremely user-friendly and less verbose than other programming languages. The Python API enables you to use Selenium to communicate with the browser. Regardless of how a browser is designed, Selenium can easily communicate common Python commands to many browsers.

  • Selenium Python is a relatively easy library to use.

  • Selenium with Python has a wide range of tools to extend it. As a result, the WebDriver is a strong binding for Python.

Why choose Python over Java in Selenium?

Java is a versatile and powerful programming language that enables developers to create sophisticated applications. Java is used in various settings, from Android apps to server-side web applications. One of the key advantages of Java is its portability, which means that Java programs can run on any platform that supports the Java Virtual Machine. 

Additionally, Java is well-suited for creating embedded systems and large-scale enterprise applications. As a result, Java is one of the most popular programming languages in use today. While Java is an excellent choice for many applications, it is not the only option available. However, based on the key criteria for choosing a programming language on the basis of simplicity, Python is the most used language, according to this survey, after HTML.

With Selenium automation testing with Java, there are several advantages, like –

  • Given that Java is a more popular and well-liked programming language, combining Java with Selenium automation testing becomes simpler.
  • With big community support, you can write test cases simply.
  • Because Java applications run more quickly, testing execution can be done more adaptively.

Now, why do programmers choose Selenium WebDriver Python over Java programming language?

Compared to other programming languages, it has the least complicated grammar. Thus, the Selenium Python ChromeDriver is the easiest and safest choice over complicated automation testing.

Using Python instead of Java for Selenium testing has several benefits. They are –

  • Python is an easy and productive language.
  • Python is relatively simple, easy to install, and runs faster than Java.
  • Selenium facilitates the Python API’s connection to the browser. By judiciously employing Selenium WebDriver Python, the Python and Selenium intersection provides a simple API for writing functional tests.
  • Python is supported on almost all platforms, including Windows, Linux, and Mac. This suggests that there is a very low learning curve, and thus makes it easier to write Selenium automation scripts.
  • The most popular Python automation testing framework is PyTest. Like other Python frameworks, it is used for end-to-end testing, integration and system testing, and unit testing. It has been improved with extra capabilities to assist parameterized testing. The PyTest framework extension’s plugin aids in parallel testing, among many other things.
  • The Python syntax command makes Python codes highly legible and clear.
  • Testers can create effective automation scripts for the automated test suite by using the extensive standards provided by the Python libraries.

Prerequisites to run Selenium tests with Python

Selenium libraries are not installed as a default when you install Python. The pip installer is the simplest method for installing Selenium in Python. Open a command line, go to the location where Python is installed, and type “pip list” to see if Selenium libraries are already installed in your Python. This command will list the libraries that are presently available in the Python installation.

PIP stands for Preferred Installer Program. PIP and Python are installed by default. We need to run a command – pip install Selenium in order to bind/install all of the necessary Selenium libraries with Python.

Once the command is executed, the following will download and install the Selenium libraries.

Now use the pip list command to check the Selenium libraries.

While Selenium’s installation makes the feature accessible, extra drivers are required to communicate with a particular web browser. You may find the links to get the drivers for Microsoft Edge, Google Chrome, Firefox, and Safari according to your device compatibility.

It should be sufficient to download the installation package and plugins if you simply intend to test Selenium locally. However, you would also be required to download the Selenium Server and install it if you want to set up Selenium Python automation on a distant server.

How to run your first Selenium tests with Python

Once you complete the prerequisites to run Selenium tests with Python, let us start with the first test in Python Selenium automation.

Step 1 – To begin, import the Selenium classes for WebDriver and Keys.

You can connect to a browser instance using the WebDriver class, which we’ll discuss in more detail later. You may simulate keyboard keystrokes, including those for specific keys like “Return” and “Shift” using the Keys class.

Step 2 – Create a Chrome instance using the driver’s path that you downloaded from the corresponding browser’s website. In this case, we’ll assume that the Python script you’ll run and the driver are both located in the same directory.

This launches a local Chrome instance for testing purposes on the local computer. This command allows you to test it till you deploy the .close() method to seize the connection to the browser.

Step 3 – Next, load a website using the driver.get() method. Alternatively, you can launch a local development site by opening a Chrome window on your computer, entering the URL, and pressing Use. The .get() method waits until a website has finished rendering before continuing it to the next stage in addition to starting the loading process.

Step 4 – Using the .title attribute, you can obtain the textual title of the webpage once the page has loaded properly. You can use assert and if statements to check if a particular substring appears in the title.

Example – For printing the title of the page, 

The output would be –

In the case of Python interpreters, the Google Chrome browser window will still be open while running the test. Additionally, Chrome displays a notification stating that automatic software is currently in charge of it.

Step 5 – In case of submitting a query in the search bar, pick the component from the HTML DOM, type a value in it, and then simulate pressing the Return key to submit the form. You can choose the element based on its CSS class, ID, name attribute, or tag name. If you look at the query search bar’s source, you’ll see that this DOM element’s name attribute is “q.” As a result, to choose the element, use the .find_element_by_name method, as shown below.

Step 6 – With the DOM element selected, use .clear() to clear the contents, .send_keys() to send a string as the value, and Keys.RETURN to emulate pressing the Return key.

Moreover, these actions change the URL in a specific way. To confirm the ongoing URL, use the given command – print(driver.current_url)

To stop the ongoing session, simply use .close() to disconnect the browser link.

Using the Python Selenium example above, we have learned how to run the first test using Selenium and Python.

Navigate through HTML DOM Elements

After successfully completing our initial Selenium WebDriver Python test, let’s examine the various choices for selecting and interacting with DOM elements.

Let us take an example with a search bar queried for a specific string.

The HTML shows as – <input id=”id-search-field” name=”q” type=”search” role=”textbox” class=”search-field” placeholder=”Search” value=”” tabindex=”1″>

In the above example, we used the .find_element_by_name() method to search for the attribute name within the HTML tag input. However, you can also use other relevant methods like

  • CSS ID: .find_element_by_id(“id-search-field”)
  • DOM Path: .find_element_by_xpath(“//input[@id=’id-search-field’]”)
  • CSS class: .find_element_by_class_name(“search-field”)

Although every element has a unique CSS ID by design, searching by class name may return more than one result. Additionally, you can be sure of what you are looking for when you search along the element’s DOM route.

Navigate through Windows and Frames

When using your web application, you might need to interact with several windows and frames. Working on separate windows is frequently used for file uploads and social logins. You can switch to a new window and perform different operations by using the driver’s .switch to window() method.

The code required to open a new window goes as – driver.switch_to_window(‘window_name’)

A window handle, which is used to identify each open window in your driver specifically, might be used if the value is not kept in the specific target attribute. Run these commands to see the list of the window handles –

In the same way, you can switch your focus to a frame within an open window by using .switch_to_frame(). Following the completion of relevant actions, run the given command to switch back to the primary window.

Work with Idle Time During a Test

While you have examined many tests in static web apps, there may be situations in which you must wait a certain amount of time before acting in a single-page application.

Primarily, Selenium possesses two types of waits – implicit waits and explicit waits. An implicit wait allows the driver to wait for a particular time, while an explicit wait makes the driver wait for a specific action until completion.

It is necessary to employ a try-finally block when using an explicit wait since, in the worst-case situation, it can make your test stuck. Essentially, you give the driver a time limit and a specific element to wait for before completion.

To start with, use WebDriverWait() function to command your driver to halt for a specific amount of time. Through the By.ID method of the expected_conditions class, one can query for the presence of a new element.

How to integrate Selenium with Python Unit Tests

Let’s look at how Selenium tests can be integrated into Python units. In this case, we will deploy Python’s unit test module –

(Code is for reference only)

In this, you need to begin the unit test class using the .Chrome() method and arrange for the driver object. In the single unit test we demonstrate, we enter the identical text into the search field and compare the obtained URL with the URL observed previously. Separate test modules can also be written for different browsers, so you can use the same functionality again.

Examples of Test Scripts in Selenium with Python

Selenium Python Example 1 – Automation for ‘Facebook log-in page’ using Selenium Python ChromeDriver.

(Image is for reference only)

Output –

(Image is for reference only)

Selenium Python Example 2 – Login into Facebook & Inspect Title

(Image is for reference only)


The Selenium Python automation framework is only as strong as the tests being designed, regardless of how much knowledge you have of how it works. During a test, automating the process can save a great deal of time, so it is important to create tests that cover all the possible scenarios. Detecting errors in the earlier testing phase is always better than ending customer complaints later.

The Testsigma platform is a free, open-source tool that can help with your test automation needs. By utilizing free maintenance tests and limitless flexibility, you can easily create automated tests without time-consuming setups, integrations, or programming. Use cloud-based solutions like Testsigma cloud to create an automation framework with the best user experience.

To provide a smooth cross-platform experience, conduct accurate and automated cross-browser testing on a real device. Since monitoring on Python Selenium automation network considers actual user circumstances, it assists in locating bottlenecks and delivering a smooth and uniform user experience across various platforms, devices, and browsers.

Frequently asked questions:

How do I write a Selenium script?

Selenium scripts are written in a special scripting language, which allows users to create custom test scenarios. To write a Selenium script, users need to have a basic understanding of the scripting language. Additionally, users should be familiar with the structure of the web application being tested.

Once these two requirements are met, writing a Selenium script is simply a matter of following the scripting language’s proper syntax and grammar rules. With a little practice, anyone can become an expert at writing Selenium scripts.

Why is Selenium mostly used?

Selenium WebDriver is a tool used for automating web application testing. It simulates how a user interacts with a website. Selenium WebDriver can be used for functional, regression, and end-to-end testing.

Selenium WebDriver is mostly used because it supports multiple browsers, is open source, and has good community support. In addition, Selenium can be integrated with other tools, such as Jenkins and TestNG, for better results. Therefore, Selenium is the tool of choice for many software testing professionals.

Which language is best for Selenium?

While you can use several languages for Selenium WebDrivers, there are some clear advantages to using Python. First, Python is a very concise and readable language, which makes it easy to write Selenium tests.

Second, Python has a large and active community of developers, which means that many resources are available for learning the language and troubleshooting any problems you may encounter. Finally, Python is widely used in the field of test automation. For all these reasons, Python is an excellent choice for Selenium web development.

Test automation made easy

Start your smart continuous testing journey today with Testsigma.