Robot Framework Libdoc extension that generates imbus TestBench Enterprise import formats. It can be used to generate Testbench interactions and datatypes from Robotframework libraries.
To install this package you can use the following pip
command:
pip install robotframework-libdoc2testbench
Notice: This extension requires Robot Framework 5.0.0 or later and does not work with earlier versions.
There are three main use cases:
- Import official Robot Framework librarys
- Import custom Robot Framework librarys
- Import Robot Framework resource files
For the most basic usage you just have to pass a Robot Framework library as an argument to the Libdoc2TestBench
command.
Libdoc2TestBench
will create a zip-file with the name of the library in the current working directory. This zip-file can be imported to TestBench in order to use Robot Framework keywords from within TestBench.
Libdoc2TestBench <LIBRARY>
The <LIBRARY>
argument corresponds to the Robot Framework library name that you would use to import the library in the *** Settings ***
of a robot/resource file.
The second positional argument can be used to specify the name of the generated zip-file:
Libdoc2TestBench <LIBRARY> <output.zip>
The generated zip-file can be imported via the Import Project...
command in the Project Management view of the imbus TestBench:
Afterwards you'll find your imported RF library, the different interactions and the datatypes in the Test Elements view:
The imported Testelements can be copied into another testbench project. When copying, it is important that the test elements remain in the same subdivisions.
Libdoc2Testbench can also be used to import custom Robot Framework librarys.
Example for a custom library:
class mycustomlibrary(object):
def print_hello_world(self):
print("Hello World")
Example Libdoc2Testbench usage:
Libdoc2TestBench mycustomlibrary.py
Libdoc2Testbench can also be used to import Robot Framework resource files.
Example for a resource file:
*** Keywords ***
print hello world
log Hello World
Example Libdoc2Testbench usage:
Libdoc2TestBench path/to/keywords.resource
Libdoc2Testbench can be used to import multiple librarys and resource files at once. A special robot framework section is used for this use case.
Example for a import List:
*** Import List ***
BrowserLibrary
BuiltIn
mycustomlibrary.py
myresource.resource
Example Libdoc2Testbench usage:
Libdoc2TestBench importlist.robot
There are several optional arguments, that follow the structure of the robot.libdoc module. When generating imports from a RF library, these values should already be set up correctly. You may overwrite the docformat and other meta data by setting the associated arguments written below.
Arguments | Description | Allowed Values |
---|---|---|
-h , --help |
Show the help message and exit | |
-a , --attachment |
Defines if the resource file, which has been used to generate the interactions, will be attached to those interactions. | |
-F FORMAT , --docformat FORMAT |
Specifies the source documentation format. Possible values are Robot Framework's documentation format, HTML, plain text, and reStructuredText. The default value can be specified in library source code and the initial default value is ROBOT . |
ROBOT HTML TEXT REST |
--libraryroot LIBRARYROOT |
Defines the subdivision name which contains the imported Robot Framework libraries. Default is RF . |
|
--resourceroot RESOURCEROOT |
Defines the subdivision name which contains the imported Robot Framework resources. Default is Resource . |
|
--libversion LIBVERSION |
Sets the version of the documented library or resource written in the description. | |
--libname |
Sets the name of the documented library or resource. | |
-r REPOSITORY , --repository REPOSITORY |
Sets the repository id of the TestBench import. The default is iTB_RF . |
|
-s SPECFORMAT , --specdocformat SPECFORMAT |
Specifies the documentation format used with XML and JSON spec files. RAW means preserving the original documentation format and HTML means converting documentation to HTML. The default is HTML . |
HTML RAW |
--version , --info |
Writes the Libdoc2TestBench, Robot Framework and Python version to console. | |
--library_name_extension |
Adds an extension to the name of an Robot Framework library subdivision in TestBench. Often used in combination with the rfLibraryRegex in testbench2robotframework . Default is [Robot-Library] . |
|
--resource_name_extension |
Adds an extension to the name of an Robot Framework resource subdivision in TestBench. Often used in combination with the rfResourceRegex in testbench2robotframework . Default is [Robot-Resource] . |
|
--created_datatypes |
Option to specify if all Robot Framework datatypes should be created in TestBench (ALL ), only the enum types (ENUM ) or if no datatype should be created and only generic parameters are used (NONE ). The default is ALL . |
- 1.2
- Added library keyword return types with RobotFramework version >= 7
- Added datatype creation options with default values
- Removed
--xml
cli option - Removed
--temp
cli option
- 1.1
- Added TestBench datatypes
- Added default values
- 1.0rc2
- ADDED optional arguments for:
- xml-file output (instead of zip-file)
- custom temporary directory
- changing the repository id in the xml-header
- custom primary key enumeration start
- info command for printing Libdoc2TestBench/Robot Framework/Python version to console
- support for resource-files (attachment support coming soon)
- FIX:
- only create
_Datatype
subdivison in libraries when data types are present Resource
subdivison is now in the correct parent subdivision- Updated README.md / package help-messages to reflect changes
- only create
- ADDED optional arguments for:
- 1.0rc1
- first release candidate
Distributed under the Apache-2.0 license. See LICENSE for more information.
- python >= 3.8
- robotframework >= 5.0.0