Robot Framework Libdoc Extension that generates imbus TestBench Library import formats.
Project description
Libdoc2TestBench
Libdoc2TestBench is a Robot Framework Libdoc extension that generates import formats compatible with imbus TestBench. It can be used to generate TestBench interactions and datatypes from Robot Framework libraries.
Installation:
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.
Usage:
There are three main use cases:
- Import official Robot Framework libraries
- Import custom Robot Framework libraries
- Import Robot Framework resource files
Import Official Robot Framework Libraries
For the most basic usage, simply 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 into TestBench to use Robot Framework keywords 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 ***
section 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>
Import the generated TestBench zip file
The generated zip file can be imported via the Import Project...
menu entry in the Project Management view of imbus TestBench:
Afterwards, you'll find your imported Robot Framework library, the different interactions and the datatypes in the Test Elements view:
The imported test elements can be copied to any other TestBench project.
Import custom robotframework librarys
Libdoc2TestBench can also be used to import custom Robot Framework libraries or resource files. For that purpose, you can specify the path to your Python or resource file or to a directory containing multiple libraries. If a directory is given as an input argument, Libdoc2TestBench searches all subdirectories recursively and creates the same subdirectory structure in TestBench.
Example Libdoc2Testbench usage:
Libdoc2TestBench path/to/mycustomlibrary.py
Importing multiple librarys and resource files at once
Libdoc2TestBench can be used to import multiple libraries and resource files at once. This can be achieved by specifying a special Robot Framework section called *** Import List ***
and passing the file that contains this section as the input argument to Libdoc2TestBench.
Example for a import List:
*** Import List ***
BrowserLibrary
BuiltIn
mycustomlibrary.py
myresource.resource
Example Libdoc2Testbench usage:
Libdoc2TestBench import_list.libdoc
Support for pyproject.toml configuration
The options specified in the Command line arguments section can also be used in a pyproject.toml
file. By simply adding a new section in your TOML file called [tool.libdoc2testbench]
, you can specify the libdoc2testbench options by using their full names."
[tool.libdoc2testbench]
created_datatypes = "ENUMS"
library_root = "Robot"
resource_root = "Robot"
library_name_extension = "[Robot-Library]"
resource_name_extension = "[Robot-Resource]"
excluded_paths = [
"**/*.py",
]
Exclude single keywords from the import
Sometimes we don't want to import every single keyword of a custom library or resource file into TestBench. To mark those keywords that should not be imported into TestBench, we can add a tag to those keywords. For that purpose, we can either use the Robot Framework built-in tag robot:private
or tb:ignore
.
Link a Robot Framework keyword to an already existing TestBench interaction
In case an interaction is already created in TestBench which should, in a next step, be implemented in Robot Framework, the UID of the already existing interaction needs to be linked to the new keyword. Otherwise, the keyword will be imported into TestBench as a new interaction. For that purpose, the tb:uid:<unique_id>
tag can be added to the keyword to set the specific unique ID with which it should be imported.
Command line arguments
There are several optional arguments that follow the structure of the robot.libdoc
module. When generating imports from a Robot Framework library, these values should already be set up correctly. You may overwrite the docformat
and other metadata by setting the associated arguments written below.
Arguments | Description | Allowed Values |
---|---|---|
-h , --help |
Provides information on how to use Libdoc2TestBench. | |
--version , --info |
Writes the Libdoc2TestBench, Robot Framework and Python version to console. | |
-a , --attachment |
Specifies whether the resource file, which has been used to generate the interactions, will be attached to those interactions. | |
-F <FORMAT> , --documentation-format <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 the library source code, and the initial default value is ROBOT . |
ROBOT HTML TEXT REST |
--library-root <LIBRARYROOT> |
Defines the subdivision name that contains the imported Robot Framework libraries. Default is RF . |
|
--resource-root <RESOURCEROOT> |
Defines the subdivision name that contains the imported Robot Framework resources. Default is Resource . |
|
-r <REPOSITORY> , --repository <REPOSITORY> |
Sets the repository ID of the TestBench import. The default is iTB_RF . |
|
-s <SPECFORMAT> , --specification-format <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 |
--library-name-extension |
Adds an extension to the name of all Robot Framework library subdivisions in TestBench. Often used in combination with the rfLibraryRegex in testbench2robotframework . The default is [Robot-Library] . |
|
--resource-name-extension |
Adds an extension to the name of all Robot Framework resource subdivisions 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 (ENUMS ), or if no datatype should be created and only generic parameters are used (NONE ). The default is ENUMS . |
ALL ENUMS NONE |
--excluded-paths |
Option to specify paths that will be ignored when generating the TestBench import. It can contain paths or glob patterns relative to the current working directory. |
Change log
- 1.3
- Added the possibility to specify the path to a directory containing different library files. Libdoc2TestBench will create the test element structure analogously to the structure of the specified directory.
- Added support for
pyproject.toml
files. - Removed legacy options
libname
andlibversion
.
- 1.2
- Added library keyword return types with Robot Framework version >= 7.
- Added datatype creation options with default values.
- Removed the
--xml
cli option - Removed the
--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 datatypes 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
License
Distributed under the Apache-2.0 license. See LICENSE for more information.
Dependencies
- python >= 3.8
- robotframework >= 5.0.0
Project details
Release history Release notifications | RSS feed
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 robotframework-libdoc2testbench-1.3b1.tar.gz
.
File metadata
- Download URL: robotframework-libdoc2testbench-1.3b1.tar.gz
- Upload date:
- Size: 39.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cf0c478348b04d139c976359f03d3f44f8b3ec2cb3da794b0045d38164dfc10f |
|
MD5 | e4a91fa846ab8f226bca1680ab69d804 |
|
BLAKE2b-256 | e806dee44435e8d2f60407750002607c05c1dd7593d865c489a2efcb54757c44 |
File details
Details for the file robotframework_libdoc2testbench-1.3b1-py3-none-any.whl
.
File metadata
- Download URL: robotframework_libdoc2testbench-1.3b1-py3-none-any.whl
- Upload date:
- Size: 90.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a80916bbb9a3c702ec204af1cb9e68bdca3ec1d03e670a4655b8c41acb0a6701 |
|
MD5 | 68cc45f114552dbb86362598e2bc5ce8 |
|
BLAKE2b-256 | 0b387663343e2542dd79d3ca7c16c2a5c29decd551db0a112142961829455045 |