Skip to main content

ctreport-selenium is a simple, creative and customizable report for selenium automation testing using Python.

Project description

Logo

CT Report for Selenium

ctreport-selenium is a simple, creative and customizable report for selenium automation testing using Python.

Installation and Usage

pip install ctreport-selenium

Define Session

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": "MyApp1",
            "application version": "V1.04",
            "os": "Windows10",
            "browser": "Chrome"
        }

In report_options, below properties can be provided

  • 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 = {
           "title": "Test Report",
           "logo": r"D:\MYLOGO.PNG",
           "show_reference": True,
           "zip_if_screenshot": True
       }

Start the Session

driver = webdriver.Chrome(executable_path=r'chromedriver.exe')
Session.start(test_name="Smoke Test - MyApp1", 
              path="D:\\reports",
              driver=driver, 
              session_details=session_details, 
              report_options=report_options)

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

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for ctreport-selenium, version 1.1.1
Filename, size File type Python version Upload date Hashes
Filename, size ctreport_selenium-1.1.1-py3-none-any.whl (30.0 kB) File type Wheel Python version py3 Upload date Hashes View
Filename, size ctreport_selenium-1.1.1.tar.gz (21.6 kB) File type Source Python version None Upload date Hashes View

Supported by

Pingdom Pingdom Monitoring Google Google Object Storage and Download Analytics Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page