A Playwright-based testing framework with customer-specific configurations
Project description
Bugster Framework
Bugster is a powerful, flexible testing framework built on top of Playwright and pytest. It's designed to simplify the process of writing and managing end-to-end tests for web applications, with a focus on supporting multiple client configurations.
Features
- Built on Playwright for robust, cross-browser testing
- Seamless integration with pytest
- Support for client-specific configurations and login strategies
- Custom
@login
decorator for easy test marking - Flexible page object model with
BugsterPage
Installation
You can install Bugster using pip:
pip install bugster
This will install Bugster and its dependencies (including pytest and playwright).
After installation, you need to install the Playwright browsers:
playwright install
Usage
Basic Setup
- Create a client configuration repository with the following structure:
customer-configs/
├── customer1/
│ ├── config.py
│ └── login_strategy.py
├── customer2/
│ ├── config.py
│ └── login_strategy.py
└── ...
- In your test files, use the
@login
decorator to mark tests that require login:
from bugster.decorators import login
@login
def test_requires_login(page):
assert page.is_visible("text=Welcome")
def test_does_not_require_login(page):
assert page.is_visible("text=Login")
@login
class TestLoggedInFeatures:
def test_feature_1(self, page):
assert page.is_visible("text=Feature 1")
Running Tests
To run your tests, use pytest with the --customer-id
option:
pytest --customer-id customer1 /path/to/your/tests
Writing Client Configurations
In each client's config.py
:
from bugster.config.base_config import BaseConfig
from .login_strategy import CustomLoginStrategy
class CustomerConfig(BaseConfig):
LOGIN_STRATEGY = CustomLoginStrategy
CREDENTIALS = {
"username": "customeruser",
"password": "customerpass"
}
# Add any other customer-specific configuration here
In each client's login_strategy.py
:
from bugster.login.base_login_strategy import BaseLoginStrategy
class CustomLoginStrategy(BaseLoginStrategy):
def login(self, page, credentials):
page.goto("https://customer.example.com/login")
page.fill("#username", credentials["username"])
page.fill("#password", credentials["password"])
page.click("#login-button")
page.wait_for_selector("#welcome-message")
Advanced Usage
Bugster provides a BugsterPage
class that wraps Playwright's Page
object, providing additional functionality. You can extend this class for custom page objects:
from bugster.core.bugster_page import BugsterPage
class MyCustomPage(BugsterPage):
def custom_action(self):
# Implement custom action here
pass
Contributing
We welcome contributions to Bugster! Please see our CONTRIBUTING.md file for details on how to contribute.
License
Bugster is released under the MIT License. See the LICENSE file for details.
Changelog
See the CHANGELOG.md file for details on what has changed in each version of Bugster.
Support
If you encounter any issues or have questions, please file an issue on the GitHub issue tracker.
Acknowledgements
Bugster is built on top of the excellent Playwright and pytest projects. We're grateful to the maintainers and contributors of these projects for their fantastic work.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file bugster-0.1.0.tar.gz
.
File metadata
- Download URL: bugster-0.1.0.tar.gz
- Upload date:
- Size: 2.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bd211d2efd79f975078ed6610fd0af17eb8d558d071e3d5b882802923c908e52 |
|
MD5 | dc33f77da25f273c9942958af926f014 |
|
BLAKE2b-256 | 649744b90a0434bc4a0030bb976668e492bd7fab5575d2ba784c4e755b4d71dc |
File details
Details for the file bugster-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: bugster-0.1.0-py3-none-any.whl
- Upload date:
- Size: 2.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6c93e464c4bf8d65f22c5e6d82409afb2c5f07c8e21e84c34b4ced3958858432 |
|
MD5 | bbae9317c0088a06013d4017bb7e3e16 |
|
BLAKE2b-256 | f603a8c4a407ab2a5543d0c10ca0003509def6742c397133ccad64c31b56d38b |