Skip to main content

Client library for easy scripting against Modelon Impact

Project description

Modelon-impact-client

Client library for easy scripting against Modelon Impact

Installation

For installation instructions and requirements, please refer to the documentation.

Develop

Devcontainer

If you are developing with VS Code you can use the devcontainer which gives gives you a ready to use environment for development. Just click the "Reopen in Container" button after opening the project in VS Code.

Tips and tricks

It is possible to run the 'make' commands listed bellow using the devcontainer. It will detect being in a container and bypass Docker parts of the commands.

You can open a project with the dev-container directly without having to open and then re-load. Standing in the project directory you can run:

devcontainer open .

Note that this requires the devcontainer-cli.

You can add your own extensions to devcontainers. These extensions will be added for all devcontainers. First open your 'settings' as JSON. Then, to add for example the "GitLens" extension, put the following at the bottom of the settings:

    ...
    "remote.containers.defaultExtensions": ["eamodio.gitlens"]
}

VS Code also have a 'Install Local Extensions in 'Remote' command, but it must be repeated for each devcontainer and everytime a devcontainer is re-built.

Creating a shell

Modelon-impact-client is developed using a Docker container for all build tools. You can get a shell into said container by running:

make shell

Manage dependencies

Dependencies are managed by poetry. Add dependencies by running poetry add <package> or poetry add <package> --dev inside the shell

Running tests

Tests are executed by running make test. You can also run make test-watch to get a watcher that continuously re-runs the tests.

Running lint

make lint

Build

Building modelon-impact-client is done by running

make wheel

Test

The tests for modelon-impact-client could be run by executing

make test

VCR test

Vcrpy(https://vcrpy.readthedocs.io/en/latest/) is used to mock the http requests and responses for some of the tests. VCR.py records all HTTP interactions that take place in a flat file called a 'cassette'. These files could are stored in the impact-client-python/tests/fixtures/vcr_cassettes folder. When an API response/request body is updated on MI, these files need to be regenerated. To regenerate these file, follow the following steps:

  1. Start Modelon impact cloud - https://impact.modelon.cloud.
  2. Generate an MI api key and JH token and store them in secrets folder. See Readme for more information.
  3. Delete the cassette file you wish to regenerate from impact-client-python/tests/fixtures/vcr_cassettes folder.
  4. The file could now be regenrated by executing
make regenerate-cassette

Release

The modelon-impact-client build process is a fully automated using Semantic-release.

Automation is enabled for:

  • Bumping version
  • Generate changelog

This is done based on git commit semantics as described here: https://semantic-release.gitbook.io/semantic-release/

To make a new release simply run:

make publish

This command will detect what branch you are on and your git history and make a appropriate release.

Current configuration can be found in .releaserc and specifies that commits to branch master should be released and commits to branch beta should be released as a pre-release.

This workflow make sure that no administrative time needs to be put into managing the release workflow.

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

modelon_impact_client-4.5.0b1.tar.gz (71.0 kB view details)

Uploaded Source

Built Distribution

modelon_impact_client-4.5.0b1-py3-none-any.whl (109.3 kB view details)

Uploaded Python 3

File details

Details for the file modelon_impact_client-4.5.0b1.tar.gz.

File metadata

  • Download URL: modelon_impact_client-4.5.0b1.tar.gz
  • Upload date:
  • Size: 71.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.9.6 Linux/3.10.0-1160.42.2.el7.x86_64

File hashes

Hashes for modelon_impact_client-4.5.0b1.tar.gz
Algorithm Hash digest
SHA256 004ce7de2d6bceac919dbe13d366ecb17f3c98fe2065888815c4837d4ccf15f8
MD5 3691b4c771fd5005ef7d608df7cac3eb
BLAKE2b-256 eff8688595e17ab08c1f367fde01c93c533235dbe7a3fdc00929cdab32269e5c

See more details on using hashes here.

File details

Details for the file modelon_impact_client-4.5.0b1-py3-none-any.whl.

File metadata

File hashes

Hashes for modelon_impact_client-4.5.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 e49a41e7f4bacbf7716a5b0fa0c23c1f10ea773ff854c5f4112d9900bfb5aa80
MD5 4a2ff809fbdb41f56c27c951fa542b59
BLAKE2b-256 02eb2fcb215087e86d4784881fd0ec6d8ef456e8321a28a1f975e3c33eab674b

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