Skip to main content

Profile of 1 Extension for the Base Python Module of the Cortex Cognitive Platform

Project description

Profile of 1 Extension for the Base Python Module of the Cortex Cognitive Platform

[cortex-python][https://github.com/CognitiveScale/cortex-python] The Cortex Python Profiles module extends the Base Python Module of the Cortex Cognitive Platform with Profile of 1 related functionality.

Refer to the Cortex documentation for details on how to use the library:

Installation

To install:

  > pip install cortex-python-profiles

or from source code:

  > git clone git@github.com:CognitiveScale/cortex-python-profiles.git
  > cd cortex-python-profiles
  > 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.8 _venv
  > source _venv/bin/activate

Install developer dependencies:

  > git clone git@github.com:CognitiveScale/cortex-python-profiles.git
  > cd cortex-python-profiles
  > 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/profiles_test.py
  • class method: pytest test/unit/profiles_test.py::TestProfile::test_list_schemas_with_client

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 pypi CognitiveScale account (via lastpass)
  • run make dev.push TAG=<alpha release number>. Example: make dev.push TAG=1

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. Manually 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

Activate your virtual environment:

> source _venv/bin/activate

Setup your environment, if you have not done so:

> make dev.install 

The package documentation is built with Sphinx and generates versioned documentation for all tag matching the release/X.Y.Z pattern and for the master branch. To build the documentation:

> make docs.multi

The documentation will be rendered in HTML format under the docs/_build/${VERSION} directory.

Pre-release to staging

  1. Create and push an alpha release:
    > make dev.push TAG=1
    
    Where TAG is the alpha version number. 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


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

cortex-python-profiles-1.3.0a1.tar.gz (40.0 kB view details)

Uploaded Source

Built Distribution

cortex_python_profiles-1.3.0a1-py3-none-any.whl (62.7 kB view details)

Uploaded Python 3

File details

Details for the file cortex-python-profiles-1.3.0a1.tar.gz.

File metadata

  • Download URL: cortex-python-profiles-1.3.0a1.tar.gz
  • Upload date:
  • Size: 40.0 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.50.2 CPython/2.7.14

File hashes

Hashes for cortex-python-profiles-1.3.0a1.tar.gz
Algorithm Hash digest
SHA256 88625adea3a476c135f95a557f3102d63fd038330953c35af63b53212d67d061
MD5 374d1cd9f2bbed20777f4886e7608c0f
BLAKE2b-256 fa2cfb3e40281523b05aeec167b9a2420c2e3f8ef6ea472b9de0f0e37e39d464

See more details on using hashes here.

File details

Details for the file cortex_python_profiles-1.3.0a1-py3-none-any.whl.

File metadata

  • Download URL: cortex_python_profiles-1.3.0a1-py3-none-any.whl
  • Upload date:
  • Size: 62.7 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.50.2 CPython/2.7.14

File hashes

Hashes for cortex_python_profiles-1.3.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 f26d380a27e7d9027b64720bb46d4469bce91f0267294d79199b321b7eae33e7
MD5 d156351b734fa7a9646d5cbfeac93c79
BLAKE2b-256 a5516a8d9a57db3c21067412424278d12548b5c49998bfe2143ad625c59d3d27

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