Skip to main content

Support for programmatic creation of resources in the CognitiveScale Cortex Cognitive Platform

Project description

Programmatic Building of Cortex Resources

The Cortex Python Builders module provides tools to programmatically build Cortex resources (e.g. Skill, Actions, Datasets, etc.) using Python. Refer to the Cortex documentation for details on how to use the library:

Installation

To install:

  > pip install cortex-python-builders

or from source code:

  > git clone git@github.com:CognitiveScale/cortex-python-builders.git
  > cd cortex-python-builders
  > pip install -e .

Development

Setup

When developing, it's a best practice to work in a virtual environment. Create and activate a virtual environment:

  > virtualenv --python=python3.6 _venv
  > source _venv/bin/activate

Install developer dependencies:

  > git clone git@github.com:CognitiveScale/cortex-python-builders.git
  > cd cortex-python-builders
  > make dev.install

There's a convenience Makefile that has commands to common tasks, such as build, test, etc. Use it!

Testing

Unit Tests

Follow above setup instructions (making sure to be in the virtual environment and having the necessary dependencies)

  • make test to run test suite

To run an individual file or class method, use pytest. Example tests shown below:

  • file: pytest test/unit/ames_test.py
  • class method: pytest test/unit/ames_test.py::TestLocal::test_analysis

Publishing an alpha build

Suppose you want to release new functionality so it can be installed without releasing a new official version. We need to use an alpha version in PyPi.

  • we need to create and publish an alpha release:
  • get credentials to the cortex-python-builders pypi CognitiveScale account (via lastpass)
  • run make dev.push. The alpha pre-release number (the N in X.Y.ZaN) with be determined automatically.

Contribution

After contributing to the library, and before you submit changes as a PR, please do the following

  1. Run unit tests via make test
  2. Manual verification (i.e. try the new changes out in Cortex) to make sure everything is going well. Not required, but highly encouraged.
  3. Bump up setup.py version and update the CHANGELOG.md

Documentation

The package documentation is built with Sphinx. To build the documentation:

> make docs

The documentation will be rendered in HTML format under the docs/_build/html directory.

Activate your virtual environment:

> source _venv/bin/activate

Setup your environment, if you have not done so:

> make dev.install 

Pre-release to staging

  1. Create and push an alpha release:
    > make dev.push TAG=1
    
    This will build an alpha-tagged package.
  2. Merge develop to staging branch:
    > make stage
    
  3. In GitHub, create a pull request from staging to master.

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

cortex-python-builders-1.1.0a1.tar.gz (30.7 kB view details)

Uploaded Source

Built Distribution

cortex_python_builders-1.1.0a1-py3-none-any.whl (46.6 kB view details)

Uploaded Python 3

File details

Details for the file cortex-python-builders-1.1.0a1.tar.gz.

File metadata

  • Download URL: cortex-python-builders-1.1.0a1.tar.gz
  • Upload date:
  • Size: 30.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.20.1 setuptools/20.8.0 requests-toolbelt/0.9.1 tqdm/4.36.0 CPython/2.7.14

File hashes

Hashes for cortex-python-builders-1.1.0a1.tar.gz
Algorithm Hash digest
SHA256 6c373a9e7ba19e47be77d7fbb3750d1def33588cd91e585b268ddf29c2e2a877
MD5 884343accd80ddda417cc07ade8168b5
BLAKE2b-256 6528e5d9951c47aff4c00a8d3e6bdf17238f0eda24fb2c490cc5672eb6a566f5

See more details on using hashes here.

File details

Details for the file cortex_python_builders-1.1.0a1-py3-none-any.whl.

File metadata

  • Download URL: cortex_python_builders-1.1.0a1-py3-none-any.whl
  • Upload date:
  • Size: 46.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.20.1 setuptools/20.8.0 requests-toolbelt/0.9.1 tqdm/4.36.0 CPython/2.7.14

File hashes

Hashes for cortex_python_builders-1.1.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 00e2076074cecb970c72779133e38252050ec4113b9f42f24df4152967ed04d7
MD5 f985b6c0108d216ca598919cd803ec07
BLAKE2b-256 1bbc5eb68ce080f6f2b8f4de94bd8be82a685462bc2d937ee8d3dd8f5229f8b8

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