Skip to main content

Infrastructure to use construct Structs in robotframework

Project description

robotframework-construct

What is robotframework-construct?

Robot Framework library powered by construct.

A declarative and symmetrical parser and builder for binary data.

Aiming for :rocket: speed, :white_check_mark: reliability, and :microscope: visibility.

Ideally, your binary data becomes as accessible as numbers and strings are in Robot Framework.

Checkout the documentation at robotframework-construct

Use cases

  • Test your production construct specification against a reference implementation of the same protocol.
  • Test your production binary parser/generator against a construct implementation of your binary format.
  • Use your construct specification to:
    • Craft intentionally corrupted data.
    • Fuzz test your binary parsers.
  • Beautifuly access registers, for both reading and writing.

Relationships in the Ecosystem

The number of dependencies is kept low, with no transient dependencies.

This is important as it keeps coordination feasible. Construct is well-developed and not expected to change significantly soon. Robot Framework releases major updates annually, but these are well-managed and communicated.

Construct (https://github.com/construct/construct)

All parsing and generating capabilities come from Construct. No additional parsing/generating code is added; the only code added interfaces Construct with Robot Framework. The way Construct objects are created remains unchanged.

Construct has no non-optional dependencies.

Robot Framework (https://robotframework.org/)

This project connects Construct with Robot Framework. Only official APIs are used, and this project depends entirely on Robot Framework.

Robot Framework has no non-optional dependencies.

Rammbock (https://github.com/MarketSquare/Rammbock)

Rammbock inspired this project, as it was one of the reasons I started using Robot Framework.

Instead of maintaining Rammbock, we chose to integrate Construct.

Reasoning

Both Rammbock and Construct have limited engineering resources, but Construct is currently better supported. Construct also collaborates with Kaitai, engaging communities in C#, C++, and other ecosystems.

Using Construct provides a clear separation between parsing/generating logic and interface code, enabling expansion into other ecosystems.

Installation

The robotframework-construct keyword library is hosted on pypi and can be installed like any pypi hosted python dependency with pip.

pip install robotframework-construct

Limitations

To maintain reusability, Construct specifications must be written in .py files. There are no plans to integrate the Construct DSL into Robot Framework.

Quality Control Measures

Tested examples and acceptance tests using Robot Framework are provided. Unit tests are not a priority.

Mutation Testing

Since this project consists primarily of interface code, it is crucial to catch user errors and produce clear error messages. Mutation testing ensures that all code paths and error messages are tested, supporting efforts to make errors informative.

Project To-Do List

  • Parsing functionality demonstrated with an in-memory BSON object.
  • Parsing functionality demonstrated with a BSON file.
  • Generating functionality demonstrated with an in-memory BSON object.
  • Generating functionality demonstrated with a binary file.
  • Register read/write demonstrated with a mockup register.
  • Receive/transmit network example using DNS.
  • Reflector tool to allow to implement servers using clients.
  • Upload wheel to pypi.
  • Increase test coverage (Mutant killing) of the reflector
  • Segmentise mutation testing to speedup
  • Add real world example with binary interface to Readme
  • Have libdoc documentation online
  • Have libdoc documentation online for all keywords, not only the central ones
  • User guide and tutorials/Article for (https://medium.com/@RobotFramework/).
  • Example on how to breakout of the python ecosystem
  • Midway review with Robot Framework Foundation.
  • Final review with Robot Framework Foundation.

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

robotframework_construct-0.1.4.tar.gz (224.6 kB view details)

Uploaded Source

Built Distribution

robotframework_construct-0.1.4-py3-none-any.whl (13.2 kB view details)

Uploaded Python 3

File details

Details for the file robotframework_construct-0.1.4.tar.gz.

File metadata

File hashes

Hashes for robotframework_construct-0.1.4.tar.gz
Algorithm Hash digest
SHA256 55f7e02fa24af0bca5b0d9c423709ae66c3a23717de5860736fffde555b54ad5
MD5 11f88502e7564f93803b09625170e961
BLAKE2b-256 12783b9cda217b4d7524ac6c8193b6ba3454d6554e737a3b5514acb42c38fd08

See more details on using hashes here.

File details

Details for the file robotframework_construct-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for robotframework_construct-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 609acc2065eb7b1fb8b77366255a9ac81f8024c489fbe0c16df4589de6219234
MD5 f2d06968ed21e426fb12b3b5d8dedf8f
BLAKE2b-256 1b7cc596f07b34236125775be3fd8aca342a95b1552c6e4a74935ef634d42536

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