Python SDK for codeflare client
Project description
Codeflare-SDK
An intuitive, easy-to-use python interface for batch resource requesting, access, job submission, and observation. Simplifying the developer's life while enabling access to high-performance compute resources, either in the cloud or on-prem.
For guided demos and basics walkthroughs, check out the following links:
- Guided demo notebooks available here, and copies of the notebooks with expected output also available
- Note that these notebooks will work with the latest
codeflare-sdk
PyPI release. For testing and experimentation withmain
branch, please use the preview notebooks - Additionally, we have a video walkthrough of these basic demos from June, 2023
Full documentation can be found here
Installation
Can be installed via pip
: pip install codeflare-sdk
Development
Prerequisites
We recommend using Python 3.9 for development, along with Poetry. Create a Poetry virtual environment with the required Python version 3.9, and run all commands within this environment.
- run:
poetry shell
Install dependencies:
- run:
poetry install
This will install standard requirements as specified in the poetry.lock file. Test and docs dependencies are optional.
-
To include test dependencies run:
poetry install --with test
-
To include docs dependencies run:
poetry install --with docs
-
To include test and docs dependencies run:
poetry install --with test,docs
If you require a requirements.txt file you can run:
poetry export -f requirements.txt --output requirements.txt --without-hashes
Pre-commit
We use pre-commit to make sure the code is consistently formatted. To make sure that pre-commit is run every time you commit changes, simply run pre-commit install
To build the codeflare-sdk pre-commit image run podman build -f .github/build/Containerfile .
from the root directory.
Testing
- To install codeflare-sdk in editable mode, run
pip install -e .
from the repo root. - Any new test functions/scripts can be added into the
tests
folder - NOTE: Functional tests coming soon, will live in
tests/func_test.py
Unit Testing
- To run the unit tests, run
pytest -v tests/unit_test.py
Local e2e Testing
- Please follow the e2e documentation
Code Coverage
- Run tests with the following command:
coverage run -m --source=src pytest tests/unit_test.py
- To then view a code coverage report w/ missing lines, run
coverage report -m
Code Formatting
- To check file formatting, in top-level dir run
black --check .
- To auto-reformat all files, remove the
--check
flag - To reformat an individual file, run
black <filename>
Package Build
To build the python package: $ poetry build
Release Instructions
Automated Releases
It is possible to use the Release Github workflow to do the release. This is generally the process we follow for releases
Manual Releases
The following instructions apply when doing release manually. This may be required in instances where the automation is failing.
- Check and update the version in "pyproject.toml" file.
- Generate new documentation.
pdoc --html -o docs src/codeflare_sdk && pushd docs && rm -rf cluster job utils && mv codeflare_sdk/* . && rm -rf codeflare_sdk && popd && find docs -type f -name "*.html" -exec bash -c "echo '' >> {}" \;
(it is possible to install pdoc using the following commandpoetry install --with docs
) - Commit all the changes to the repository.
- Create Github release (https://docs.github.com/en/repositories/releasing-projects-on-github/managing-releases-in-a-repository#creating-a-release).
- Build the Python package.
poetry build
- If not present already, add the API token to Poetry.
poetry config pypi-token.pypi API_TOKEN
- Publish the Python package.
poetry publish
- Change directory to custom-nb-image.
cd custom-nb-image
- Set tag
export tag=TAG
- Build the container image.
podman build --build-arg SDK_VERSION=<version> -t quay.io/project-codeflare/notebook:${tag} .
- Login to quay.io.
podman login quay.io
- Push the image.
podman push quay.io/project-codeflare/notebook:${tag}
- Push the stable image tag
podman push quay.io/project-codeflare/notebook:${tag} quay.io/project-codeflare/notebook:stable
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
Built Distribution
File details
Details for the file codeflare_sdk-0.16.2.tar.gz
.
File metadata
- Download URL: codeflare_sdk-0.16.2.tar.gz
- Upload date:
- Size: 30.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6929a6874e3d72b0145163bf8d0e4b0bae3998bfacd2b41c1d84bbf4d3ff1c6d |
|
MD5 | ec8c5e5d816ba019d1d702f48557f0de |
|
BLAKE2b-256 | 00f937c4c0956837b61df0d88b4a52f99b83d6360dcc5af7768a644b1573eef6 |
File details
Details for the file codeflare_sdk-0.16.2-py3-none-any.whl
.
File metadata
- Download URL: codeflare_sdk-0.16.2-py3-none-any.whl
- Upload date:
- Size: 36.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 562dc912af7beb56ad7d66c1256166b8e283662ddd536cd0e2cf37f18f922bf3 |
|
MD5 | fe73cb9ce7af1097dca1fa4435e79542 |
|
BLAKE2b-256 | bd881b4e7a9b212a8305d17bee6520bfb4b8485bfeefe1ac6df10e1dc9c62ade |