Skip to main content

GRPC python binding for the ArmoniK orchestrator API

Project description

ArmoniK.Api Python package

This folder contains the necessary scripts to generate the ArmoniK.Api Python package. Please note that while the package generation is platform dependent, the generated package should be compatible with Linux and Windows.

Install the Python Package from PyPI

At each release, we provide a prepackaged version of ArmoniK.Api available on PyPI here : https://pypi.org/project/armonik. To install the package to your current Python environment, you can use pip :

pip install armonik

Linux / WSL

How to generate

Requirements :

  • Python >= 3.7
  • Python3-venv
  • Pip3
  • Bash

If the python command doesn't link to python3 on your system, you may be able to install the package python-is-python3, which links python to python3.

To generate the package from sources, run the proto2python.sh script from its folder. You need to specify a directory where the virtual environment used for the build will be located. For example the following command will generate the packages and will create the build environment "pyvenv" in the current user's home directory:

./proto2python.sh ~/pyvenv

3 folders will be created :

  • generated : contains the source files used to create the package
  • build : contains the source files used to create the wheel package
  • pkg : contains the sdist and wheel packages

Instead of running the script you can install the armonik package in "editable" mode, allowing you to make changes to the source code, and the changes will be reflected immediately without reinstalling the package.

pip install -e ./packages/python

How to install the generated package

From this directory, use the following command:

pip install pkg/armonik*.whl

The generated package will be installed to your current python environment

Windows

Coming soon

Tests

Test Environment Setup

Before running tests, ensure the following setup steps are completed:

  1. Install Dependencies:
sudo apt install dotnet-sdk-6.0 jq
  1. Launch the Mock Server:

Verify that port 5000 is available (Armonik and the mock server communicate on the same port, uninstall armonik if necessary):

lsof -i :5000
  1. Launch the server from the project's root directory in a separate terminal:
cd packages/csharp/ArmoniK.Api.Mock
dotnet run

Test Environment Summary

The test environment utilizes a mock endpoint to assert if the ArmoniK service has been triggered. It leverages the requests library to query the /calls.json endpoint, examining the JSON response to validate the count of remote procedure calls made to specific services and methods

curl localhost:5000/calls.json | jq

In prevision of the API test, run the following command:

curl localhost:5000/calls.json | jq '.Tasks'

You should have as output:

{
  "GetTask": 0,
  "ListTasks": 0,
  "GetResultIds": 0,
  "CancelTasks": 0,
  "CountTasksByStatus": 0,
  "ListTasksDetailed": 0,
  "SubmitTasks": 0
}

Configure gRPC channel and test API calls

Once the endpoint runs, you can initiate a gRPC channel to it with a Python client.

Below is an example using a Tasks client and calling the list_tasks method:

import grpc
import armonik.client
with grpc.insecure_channel("localhost:5001") as channel:
    tasks_client = ArmoniKTasks(channel)
    tasks.client.list_tasks()

Port 5001 is actually ArmoniK's control-plane endpoint.

For the sake of simplicity, the example gRPC channel here is an insecure one. You should never do that in production environment.

Check if API call was successful

Execute the Python code snippet above and re-run command:

curl localhost:5000/calls.json | jq '.Tasks'

You should have as output:

{
  "GetTask": 0,
  "ListTasks": 0,
  "GetResultIds": 0,
  "CancelTasks": 0,
  "CountTasksByStatus": 0,
  "ListTasksDetailed": 1,
  "SubmitTasks": 0
}

You can see that attribute ListTasksDetailed was incremented, meaning that the API effectively handled your call !

WARNING

Note for Users

Starting from gRPC version 1.57 and onward, it is necessary to explicitly specify the default authority when creating the gRPC channel. more details

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

armonik-3.29.0.tar.gz (90.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

armonik-3.29.0-py3-none-any.whl (149.2 kB view details)

Uploaded Python 3

File details

Details for the file armonik-3.29.0.tar.gz.

File metadata

  • Download URL: armonik-3.29.0.tar.gz
  • Upload date:
  • Size: 90.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for armonik-3.29.0.tar.gz
Algorithm Hash digest
SHA256 d6af212f93a828c5cad8963a1e5e2fd838f8d9143b0a011d6fb76c4204a942e8
MD5 ccbbe24b20b99ca07d1016836dba27e1
BLAKE2b-256 b6587eb5a770e623146ee1668cde3f9235722b766edf081f372ef238a6bef9b7

See more details on using hashes here.

File details

Details for the file armonik-3.29.0-py3-none-any.whl.

File metadata

  • Download URL: armonik-3.29.0-py3-none-any.whl
  • Upload date:
  • Size: 149.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for armonik-3.29.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1b7f9b68d2aa3dee00f288d9c18b0ccfdd45daabe79062ff55d895437df5c9d3
MD5 7ba372cd97124b994ded6a4154a00068
BLAKE2b-256 eb46eb7e77f2c42efda283d5c731cdf4ead1eb96d66cc9e35cb3f54a9233f64f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page