This starter pack provides a basic setup for writing Selenium tests using Python, Selenium, and Pytest framework.
- Tools & Frameworks
- Directory Structure
- Getting Started
- Environment Variables
- Miscellaneous
- Download Links
- Important Documentations
Selenium is a popular open-source automation testing framework primarily used for web applications. It provides a set of tools and libraries to automate web browser actions, such as clicking buttons, entering text, navigating through pages, and verifying expected behaviors.
Python is a popular programming language for Selenium automation for several reasons:
- Simplicity and readability
- Large ecosystem
- Cross-platform compatibility
- Integration with Selenium
- Third-party packages
Pytest is a testing framework for Python that simplifies the process of writing and executing tests. It offers simplicity, a fixture model, powerful assertions, console output, HTML report generation, and failure hooks.
The project follows a modular structure to separate concerns and improve maintainability. Here's an example of the directory structure:
project_root/
│
├── tests/
│ ├── init.py
│ ├── test_module1.py
│ └── test_module2.py
│
├── pages/
│ ├── init.py
│ ├── base_page.py
│ └── other_page.py
│
├── locators/
│ ├── init.py
│ ├── base_page_locators.py
│ └── other_page_locators.py
│
├── configs/
│ ├── init.py
│ └── config.py
│
├── utils/
│ ├── init.py
│ └── helper_functions.py
│
│
├── drivers/
│ └── chromedriver.exe (or other WebDriver executables)
│
├── reports/
│
├── screenshots/
│
├── requirements.txt
├── conftest.py
└── pytest.ini
Folder Structure Explanation
- tests/: Contains test files with test cases.
- pages/: Contains page objects representing web pages.
- locators/: Contains files defining locators for web elements.
- configs/: Contains configuration files.
- utils/: Contains utility functions and configuration files.
- drivers/: Contains WebDriver executables for browsers.
- reports/: Contains test reports, generated automatically on each execution.
- screenshots/: Contains screenshots generated upon test failure.
- requirements.txt: Lists Python dependencies.
- conftest.py: Fixture setup and teardown.
- pytest.ini: Configuration options for Pytest.
-
Install Python, if not already installed.
- Go to the official Python Website and download the latest version suitable for your operating system.
- Make sure to check the option ‘Add Python to PATH’ during installation.
-
Choose an IDE.
- Go to the official websites of PyCharm or Visual Studio Code and download the version compatible with your operating system
- Clone the repository
- Open the Bitbucket Repository
- Click on the "Clone" option located in the top right corner.
- Copy the command provided.
-
Clone the Repository using Terminal or IDE Command Line.
- Open your terminal (Command Prompt on Windows or Terminal on Mac/Linux) or the command line interface within your IDE.
- Use the command you copied earlier to clone the repository.
- This command will download a copy of the repository to your local machine.
-
Open the Cloned Repository.
- Navigate to the directory where the repository was cloned using the cd command followed by the directory path.
- Alternatively, open your IDE and use the "Open Folder" option to navigate to the cloned repository directory.
-
Checkout to branch release/version-1.0.
- Use the command
git checkout origin release/version-1.0
to switch to the specified branch.
Remove-Item -Recurse -Force .git
To confirm the git is removed, use
Get-ChildItem -Hidden
If .git is not present, git is successfully removed. Now, to initialize a new git repository, use the commandgit init
- Use the command
-
Install Dependencies.
-
Use the command
pip install -r requirements.txt
to install all dependencies listed in therequirements.txt
file. -
For mac devices, use the
pip3
command, instead ofpip
.- Workaround 01: If the above command is not working, try installing dependencies separately.
pip install pytest
pip install selenium
pip install python-dotenv
pip install barnum
pip install pytest-html
pip install pytest-failed-screenshot
- Workaround 01: If the above command is not working, try installing dependencies separately.
-
-
Create and activate a virtual environment (optional but recommended).
python -m venv venv source venv/bin/activate # On Linux/Mac venv\Scripts\activate # On Windows
-
Download WebDriver Executables.
- Download ChromeDriver, GeckoDriver, or EdgeDriver depending on the browsers you intend to test.
- Place these executables in the drivers/ directory of your project.
-
Install Pending Dependencies from configs/config.py.
- Check the config.py file imports for any additional dependencies that need to be installed
-
Execute Tests.
- Run your tests using the command
pytest tests/test_filename.py
. - Replace test_filename.py with the name of the test file you want to execute.
- Eg.:
pytest test_login.py
- Eg.:
- Run your tests using the command
By following these steps, you should be able to set up your pytest environment, clone the repository, install dependencies, and run tests with ease.
Here's an example of how to write a test case:
# tests/test_example.py
import pytest
from locators import base_page_locators
from pages.base_page import BasePage
@pytest.fixture
def base_page(setup_driver):
return BasePage(setup_driver)
def test_example(base_page):
base_page.open()
assert "Example Domain" in base_page.get_title()
base_page.input_text(base_page_locators.BasePageLocators.search_input)
This project uses environment variables for configuration. Sensitive data like emails, passwords, etc. are stored in
a .env
file.
- Create a .env file at the project root.
- Add required values to the file
Here's a sample of what the .env file should look like in this project:
EMAIL = "[email protected]"
PASSWORD = "your-password"
Executing tests using the command line with the pytest command offers several advantages:
- Simplicity: Running tests from the command line with pytest is straightforward and requires minimal setup.
- Customization: The pytest command provides various options and flags that allow us to customize test execution behavior.
- Parallel Execution: pytest supports parallel test execution, allowing us to run tests concurrently across multiple processes or threads.
- Output Formats: pytest can generate test reports in different formats, such as plain text, JUnit XML, HTML, etc.
- Plugin Integration: pytest has a rich ecosystem of plugins that extend its functionality and integrate with other tools.