Skip to main content

Basic classes to ease BDD evidence creation

Project description

Eai BAT

latest update to be seen in documentation

Quick overview

Basic automation tool is mainly a python class which holds various data.

It aims to ease the test's evidence creation by recording steps definition and content in an ordered way.

One goal is that class may be subclassed so that your automaton fits your needs.

What's in?

  • EaiBat class with few properties and methods.
  • folder_file_name_cleaning package function which cleans a string from spaces and some special characters.

Properties

  • url : yes it's designed to test APIs or Web application. Allow http, https and ftp scheme, ASCII letters, digits and +, . and : characters
  • history : your tests records in an ordered dictionary.
  • step : your current test step. It's a length two tuple containing int or string. It might be constructed using a Behave's Step.
  • evidence_location : where you store the evidence as a string.

Methods

  • push_event: takes one event argument
    • a request's Response object,
    • a string
    • a dictionary
    • a length 2 tuple for file event. First part is the filename (relative to the evidence_folder) and the second part is the file type. Currently, only three types are managed: img, txt or sql.
  • clear_history: without argument.
  • create_evidence: takes two arguments
    • filename: the evidence filename
    • evidence_type: either markdown or word. Please note markdown generator is not as complete as word generator.

How to use it?

As a standalone...

Well, I don't use it as a standalone.

You could create an instance of EaiBat, feed the history and then create the evidence.

It may look like something as below

from eaiBat import EaiBat

my_reporter = EaiBat()

# Set first where evidence should be stored
my_reporter.evidence_location = 'path_to_evidence_location'
# Set the step. Mind that Behave's step do the job
my_reporter.step = ('First step', 'my action')
# Set the history content for the step
my_reporter.push_event("I describe what I do")
# Another step
my_reporter.step = ('Second step', 'another action')
# Another content. Mind the file will be search in the 'evidence_location'
my_reporter.push_event(('screenshot.png', 'img'))
my_reporter.push_event(('sql_file_i_processed.sql', 'sql'))
# Create the evidence
my_reporter.create_evidence("my_evidence.docx", "word")
# Clear the history for a new run
my_reporter.clear_history()

Part of Behave framework

I prefer using this package as part of Behave test automation framework.

Here is my usage:

from helpers.model import MyModel
from eaiBat import folder_file_name_cleaning

def before_all(context):
    context.model = MyModel()
    context.model.url = 'http://my.test.environment.com'


def before_step(context, step):
    context.model.step = step


def before_scenario(context, scenario):
    context.model.evidence_location = f'evidence/{folder_file_name_cleaning(scenario.name)}'

def after_scenario(context, scenario):
    evidence_name = f"{scenario.name}-{scenario.status}.docx"
    context.model.create_evidence(folder_file_name_cleaning(evidence_name), "word")
    context.model.clear_history()
  • In the helpers.model package (homemade package for the test automation) assuming I test a GUI application and I have a take_a_screeshot function which return the picture's filename
from eaiBat import EaiBat


class MyModel(EaiBat):
    def some_action(self):
        # Action I want to reuse in my steps
        self.push_event((take_a_screenshot(), 'img'))
  • In the steps definitions
from behave import Given
from shutil import copy

@Given('I set "{user}" user')
def set_user_in_db(context, user):
    try:
        execute_sql_script(f'resources/script/{user}.sql')  # Assuming you have a function executing sql scripts
        context.model.push_event(f"The {user} is in the database")
        copy(f'resources/script/{user}.sql', f'{context.model.evidence_location}/{user}.sql')
        context.model.push_event((f'{user}.sql', 'sql'))
    except Exception as exception:
        context.model.push_event(f"The step has failed due to {exception.args}")

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

eaibat-0.0.11.tar.gz (12.2 kB view details)

Uploaded Source

Built Distribution

eaibat-0.0.11-py3-none-any.whl (30.2 kB view details)

Uploaded Python 3

File details

Details for the file eaibat-0.0.11.tar.gz.

File metadata

  • Download URL: eaibat-0.0.11.tar.gz
  • Upload date:
  • Size: 12.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.3

File hashes

Hashes for eaibat-0.0.11.tar.gz
Algorithm Hash digest
SHA256 2e7a6170493694a6a7f5d1dc4ca1636e15544499e1f8d3a221bce113ab7d07b1
MD5 9f3fe66ed1a371b72cbd63b2ae2c220f
BLAKE2b-256 4da01c0541c37913240852d6ba8b01264871e56a31d93364c0f12ee6506a052a

See more details on using hashes here.

File details

Details for the file eaibat-0.0.11-py3-none-any.whl.

File metadata

  • Download URL: eaibat-0.0.11-py3-none-any.whl
  • Upload date:
  • Size: 30.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.3

File hashes

Hashes for eaibat-0.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 2bdedab018e42ff497f221089f0b1d3a5dfdfd1c085a5590f78a5fddbdb86dde
MD5 f7995d858a05febb1a6c92dca24dd1df
BLAKE2b-256 87be7eb9d61a47cda5a15d1376b664036ed138a40aa7d92755436569b001d578

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page