Skip to main content

Python implementation of the SiLA 2 standard for lab automation

Project description

PyPI version License: MIT coverage report documentation

:warning: On 2021-11-15, this project replaced a legacy Python implementation of SiLA 2. That project can be found here and is still installable via pip install sila2lib.

SiLA 2 Python Implementation

SiLA Homepage https://sila-standard.com
Chat group Join the group on Slack
Maintainer Niklas Mertsch (@NMertsch)
Maintainer Mark Doerr (@markdoerr)

Getting started

Installation

Use pip install sila2 to install the latest release of the library.

On Raspberry Pi systems, run the following to fix some ImportErrors:

  • pip uninstall -y lxml grpcio grpcio-tools
  • sudo apt install -y python3-lxml python3-grpcio python3-grpc-tools

Documentation

A documentation on SiLA Server generation, feature implementation, and usage of SiLA Clients can be found here.

Example

The directory example_server contains an example SiLA Server application. example_client_scripts contains multiple SiLA Client programs that interact with the example server.

Implementation status

Missing parts from SiLA 2 specification

  • Lifetime handling for binary transfer
    • currently, large binaries are only deleted on request
  • Lifetime handling for observable commands
    • currently, no lifetime is reported and execution UUIDs stay valid indefinitely
  • Server-initiated connection (SiLA 2 v1.1)
    • currently, only client-initiated connections are supported

Deviations from SiLA 2 specification

Contributing

Contributions in the form of issues, feature requests and merge requests are welcome. To reduce duplicate work, please create an issue and state that you are working on it before you spend significant time on writing code for a merge request.

Development

Multi-stage build process

Because the sila2.features submodule is auto-generated using the code generator included in this library, the build process has multiple steps:

  1. Install the library without sila2.feature
  2. Use the script generate-feature-submodule.py to generate sila2.feature
  3. Install again

Development tools

This project uses the following tools to improve code quality:

The following Python scripts are provided to guide the development process:

To install all these tools, use pip install .[dev].

Documentation build process

To build the documentation, first install this library with pip install .[docs], the run docs/make-docs.py. The HTML documentation can then be found at docs/_build/html

Setup code

The full development setup using the setuptools development mode looks like this:

# clone repository
git clone --recurse-submodules https://gitlab.com/sila2/sila_python
cd sila2

# install sila2 in development mode
pip install -e .[full]  # install without sila2.feature submodule and all optional dependencies
python generate-feature-submodule.py  # generate sila2.feature code (generates src/sila2/feature/...)

# build documentation (generates docs/_build/html)
python docs/make-docs.py

# install example server in development mode (required for tests)
pip install -e example_server

# run test suite
python run-checks.py

# run code formatting
python run-formatting.py

# install git pre-commit hook (generates .git/hooks/pre-commit)
python install-pre-commit-hook.py

# build wheel and source distribution (generates build/ and dist/)
pip install build
python -m build -ws

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

sila2-0.9.0.tar.gz (95.8 kB view hashes)

Uploaded Source

Built Distribution

sila2-0.9.0-py3-none-any.whl (182.9 kB view hashes)

Uploaded Python 3

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