ctreport-selenium is a simple, creative and a customizable report for automation testing using Python. Best suitable for pytest, unit test and nose framework.
Project description
CT Report for Selenium
ctreport-selenium is a simple, creative and customizable report for selenium automation testing using Python.
Feature
- Different view of your test execution result
- Dashboard view with multiple graphs to understand the tests
- Test Detail view to show complete test
- Filter and Search any test
- Reference section for ctreport-selenium specific terminologies like Status, Priority, and Severity
- Customizable option through JSON file
- Screenshots better view
- Toast message for every endpoint of the report for the clear understanding
- Fairly mobile friendly
Installation and Usage
pip install ctreport-selenium
Define reportconfig.json file
First, you should define the session. While creating session session_details and report_options can be defined/modified.
In session_details, you can provide the current test session details
"session_details" : {
"Owner": "Naveen.S",
"application_name": "MyApp1",
"application_version": "V1.04",
"platform": "Windows10",
"additional_information":"Browser - Chrome 84"
},
In report_options, below properties can be provided
- theme (Default/Dark Angel) (Currently ctreport-selenium supports two theme 1. Default 2. Dark Angel)
- title (report title)
- logo (your company logo)
- show_reference (reference section)
- zip_if_screenshot (In case, the screenshot is created then you can select this option to create zip file- report+screenshot )
"report_options" :{
"theme": "Default",
"title": "Test Report",
"logo": "MYLOGO.PNG",
"show_reference": "True",
"zip_if_screenshot": "True"
}
Start the Session
driver = webdriver.Chrome(executable_path=r'chromedriver.exe')
Session.start(test_execution_name="Smoke Test - MyApp1",
path="D:\\reports",
driver=cls.driver,
config_file=r"D:\\reportconfig.json")
Create Test
For each test, you can create an object for the Test class. While creating the object for the Test class you can define the below parameters
- Name
- Id
- Description
- Priority (Refer below reference section)
test = Test("Search Fund links",
id=4574,
description="Search by search term- Fund",
priority=Priority.MEDIUM)
Methods in Session class
Method | Description |
---|---|
set_driver(driver) | In case of driver is not passes in Session.start() method later you can pass through this method |
Methods in Test class
Method | Description |
---|---|
log(self, *message) | Method to record the steps for your test in the report self.test.log("Navigate to search page") |
error(self, *message, exception=None, takescreenshot=False) | Method to record the error message in the report |
broken(self, *err) | Method to mark the current test as Broken and record the exceptions Broken - Test case stopped due to fatal errors(check the reference section) |
skip(self, message) | Method to skip the current test |
take_screenshot(self, message=None) | Method to take screenshot |
assert_are_equal(self, actual, expected, description=None, onfail_screenshot=False) | Mark the assertion steps and it supports asserting following types Number String Boolean Dictionary List Tuple Note: All assertions are treated as Blocker severity (check the reference section) |
verify_are_equal(self, actual, expected, description=None, severity=Severity.MAJOR, onfail_screenshot=False) | Mark the verification steps and it supports verifing the following types Number String Boolean Dictionary List Tuple (check the reference section) |
Finish Test
Every test should be finshed before next test start/before Session ends
test.finish()
End Sesion
Session should be end at end of your script
Session.end()
Reference
Status
Status: Test status after execution
Status | Description |
---|---|
Pass | Test case is passed without any verification/assertion/fatal errors |
Fail | Test case is failed due to verification/assertion errors |
Skip | Test case skipped due to blocker or critical issue in dependencies |
Broken | Test case stopped due to fatal errors |
Priority
Priority: Applies to test case
Priority | Description |
---|---|
High | Test case on the most important features of the application |
Medium | Test case on features of the application which is next to High priority test cases |
Low | Test case on features of the application which is considered to be executed rarely |
Severity
Severity: Applies to verification and assertion statements
Note: All assertions are treated as Blocker severity
Severity | Description |
---|---|
Blocker | The system or functionality is currently unavailable to continue working on the application because of this incident |
Critical | Essential functionality is not functioning and no acceptable workaround |
Major | Essential functionality is not functioning unless acceptable workaround is implemented |
Minor | Minor inconvenience in the functionality and application remains operational |
Issues
If you encounter any problems, please file an issue along with a detailed description.
Project details
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 ctreport_selenium-1.1.4.tar.gz
.
File metadata
- Download URL: ctreport_selenium-1.1.4.tar.gz
- Upload date:
- Size: 23.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7afb0c6acebeab0aefea2b977f0927775ff8072b86299aee95a9853fb6c44329 |
|
MD5 | 3429962bce6877c0c45b50d1bbe42fa8 |
|
BLAKE2b-256 | 3b70a46d43f06774eb23b55f016fdd61d6e25fb764f841d9dfc2ab08ed5501d2 |
File details
Details for the file ctreport_selenium-1.1.4-py3-none-any.whl
.
File metadata
- Download URL: ctreport_selenium-1.1.4-py3-none-any.whl
- Upload date:
- Size: 31.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 44f7dff25e4c057752ea812da8944b952faa8f7ae1aa8f6acfb1de8acefdead8 |
|
MD5 | e0dc3bd8989b72e059768736afab9d50 |
|
BLAKE2b-256 | 4c996db98fb0b6a6b249a99aa56fd7149c57c2f02cf0a21db2d98e5be129a31a |