Skip to main content

Translate Gherkin feature files into RobotFramework tests

Project description

gherkin2robotframework

Description

This tool can be used to facilitate the usage of Cucumber feature files in a RobotFramework Test Automation solution. Although RobotFramework supports BDD style test cases, this support is limited to Given/When/Then keywords. Features like datatables and docstrings are not supported in RobotFramework. This tool will 'compile' Gherkin feature files into RobotFramework test cases and scaffolding for step definitions aka User Keywords.

Usage

Example feature

Feature: Examples

  As a tester
  I want to specify feature files and translate it to RobotFramework
  So I can use the best of both worlds

  Background:
    Given some background stuff

  Scenario: Greeter
    Given a greeter
    When greeting the following persons:
      | Name  | Greeting   |
      | Joe   | Hello      |
      | Mary  | Hi, there! |
    Then the wold is a better place

  @tag
  Scenario Outline: Repetitive stuff
    A nice description
    on multiple lines
    Given a thing with "<thingy>"
    When some action
    Then this happened: <stuff>

    @A
    Examples: A
      Documentation for
      example A
      | thingy  | stuff |
      | AAA     | 123   |
      | BBB     | 456   |

    @B
    Examples: B
      Documentation for example B
      | thingy  | stuff |
      | CCC     | 789   |
      | DDD     | 000   |

  @tag
  Scenario Outline: More stuff
    A nice description
    on multiple lines
    Given a thing with "<thingy>"
    When doing action <action>
    Then this happened: <stuff>

    @A
    Examples: A
      Documentation for
      example A
      | thingy  | action | stuff |
      | AAA     | take   | 123   |
      | BBB     | give   | 456   |

First time generation

After creating your feature files you can translate these into RobotFramework test scripts with the following command:

gherkin2robotframework example.feature

Two files will be generated: example.robot containing the test cases and example_step_definitions.robot containing the user keywords implement the steps. For the default english gherkins the Given/When/Then will be stripped from the keyword names.

*** Settings ***
Documentation    As a tester
...      I want to specify feature files and translate it to RobotFramework
...      So I can use the best of both worlds
Resource    ./examples_step_definitions.robot
Metadata    Feature    Examples
Metadata    Generated by    _gherkin2robotframework on 2020-01-31T13:23:34.958405_

*** Test Cases ***
Greeter
    Background
    Given a greeter
    ${DataTable}=    Create List
    FOR    ${Name}    ${Greeting}    IN
    ...    Joe    Hello
    ...    Mary    Hi, there!
        ${entry}=    Create Dictionary    Name=${Name}    Greeting=${Greeting}
        Append To List    ${DataTable}    ${entry}
    END
    When greeting the following persons:    @{DataTable}
    Then the wold is a better place

Repetitive stuff: A
    [Documentation]    Documentation for
    ...    example A
    [Tags]    tag    A
    [Template]    Scenario Outline Repetitive stuff
    AAA    123
    BBB    456

Repetitive stuff: B
    [Documentation]    Documentation for example B
    [Tags]    tag    B
    [Template]    Scenario Outline Repetitive stuff
    CCC    789
    DDD    000


*** Keywords ***
Background
    Given some background stuff

Scenario Outline Repetitive stuff
    [Documentation]    A nice description
    ...    on multiple lines
    [Arguments]    ${thingy}    ${stuff}
    Background
    Given a thing with "${thingy}"
    When some action
    Then this happened: ${stuff}

example_step_definitions.robot

*** Settings ***
Documentation    Generated by    _gherkin2robotframework on 2020-01-31T12:14:13.397524_
Library    Collections

*** Keywords ***
some background stuff
    Fail    Keyword "some background stuff" Not Implemented Yet

a greeter
    Fail    Keyword "a greeter" Not Implemented Yet

greeting the following persons:
    [Arguments]    @{DataTable}
    Fail    Keyword "greeting the following persons:" Not Implemented Yet

the wold is a better place
    Fail    Keyword "the wold is a better place" Not Implemented Yet

a thing with "${thingy}"
    Fail    Keyword "a thing with "${thingy}"" Not Implemented Yet

some action
    Fail    Keyword "some action" Not Implemented Yet

this happened: ${stuff}
    Fail    Keyword "this happened: ${stuff}" Not Implemented Yet

Regeneration

In case your feature file is changed the .robot files needs to be regenerated.

...
    Scenario: Greeter
        Given a greeter
        When greeting the following persons:
          | Name  | Greeting   |
          | Joe   | Hello      |
          | Mary  | Hi, there! |
        Then the wold is a better place
        And the sun will shine                    #  <-- New step
...

The files can be regenerated with the same command:

gherkin2robotframework example.feature

However, only the example.robot file will be generated (overwritten). The step definition will be parsed and missing keywords will be generated to the console.

Processing gherkin: E:\GitHubProjects\gherkin2robotframework\examples\examples.feature

Missing keywords for: E:\GitHubProjects\gherkin2robotframework\examples\examples_step_definitions.robot

the sun will shine
    Fail    Keyword "the sun will shine" Not Implemented Yet

Limitations and considerations

Background support

The Background keyword is generated to implement the background part of the feature file. Each test case will include this keyword. Using [Test setup] will not work for Scenario Outline with Examples. In Cucumber the Background is applied to each example and in RobotFramework the [Test setup] is only applied to the Test case and NOT to each line in the test case with [Test Template].

Language support

#language:xx is supported, but because the gherkin3 dependency is not recently updated on PyPI. Therefore some keywords (and aliases) are not included.

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

gherkin2robotframework-0.4.2.tar.gz (11.7 kB view details)

Uploaded Source

Built Distribution

gherkin2robotframework-0.4.2-py3-none-any.whl (11.1 kB view details)

Uploaded Python 3

File details

Details for the file gherkin2robotframework-0.4.2.tar.gz.

File metadata

File hashes

Hashes for gherkin2robotframework-0.4.2.tar.gz
Algorithm Hash digest
SHA256 3369f2cc0c0b115b857b86ff0a00b49fbe65255a7e07d56ecda12bcb2c07735b
MD5 2e82d1bbb3654bdc95204d3f2f014f11
BLAKE2b-256 17dbbe24bf6a77ae8de55113872827b0a32ef187ce41b141f98d0e661c138358

See more details on using hashes here.

Provenance

The following attestation bundles were made for gherkin2robotframework-0.4.2.tar.gz:

Publisher: release.yaml on mauricekoster/gherkin2robotframework

Attestations:

File details

Details for the file gherkin2robotframework-0.4.2-py3-none-any.whl.

File metadata

File hashes

Hashes for gherkin2robotframework-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c227ffc67a9ad6659da4f14f0caedbf1d4a8b4f1af8eab3a472628c6c23654ba
MD5 ebd2e44c2944dc4d77e2302a7557ab16
BLAKE2b-256 ce2c4d6ccf9fe295469ae0de5c5a741dcdc9ddd736d4e83da084f48953f1e482

See more details on using hashes here.

Provenance

The following attestation bundles were made for gherkin2robotframework-0.4.2-py3-none-any.whl:

Publisher: release.yaml on mauricekoster/gherkin2robotframework

Attestations:

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