Skip to main content

Wrapper around https://github.com/kubernetes-client/python

Project description

openshift-python-wrapper

Pypi: openshift-python-wrapper
A python wrapper for openshift-restclient-python with support for RedHat Container Virtualization. (Openshift Virtualization)
Docs: openshift-python-wrapper docs

Installation

From source:

git clone https://github.com/RedHatQE/openshift-python-wrapper.git
cd openshift-python-wrapper
python setup.py install --user

From pypi:

pip install openshift-python-wrapper --user

Release new version

requirements:

  • Export GitHub token
export GITHUB_TOKEN=<your_github_token>
sudo npm install --global release-it
npm install --save-dev @release-it/bumper

usage:

  • Create a release, run from the relevant branch.
    To create a 4.9 release, run:
git checkout v4.9
git pull
release-it # Follow the instructions

docs

Hosted on readthedocs.io


## PR dependency
For PR dependency we use [dpulls](https://www.dpulls.com/)  
To make PR depends on other PR add `depends on #<PR NUMBER>` in the PR description.

## Examples
### Client
```python
client = DynamicClient(client=kubernetes.config.new_client_from_config())

The examples given below are relevant to all resources. For simplicity we will use the resource - Namespace.

Import

Import Namespace:

from resources.namespace import Namespace

Create

Create a Namespace:

ns = Namespace(name="namespace-example-1")
ns.create()

Will return True if creation succeeded.

We can also use the with statement which ensures automatic clean-up of the code executed:

with Namespace(name="namespace-example-2") as ns:
    yield ns

teardown=False - Disables clean-up after execution.

Wait

Wait for Namespace to be in status Active:

ns.wait_for_status(status=Namespace.Status.ACTIVE, timeout=120)

Will raise a TimeoutExpiredError if Namespace is not in the desired status.

Delete

Delete the Namespace

ns.delete()

Will return False if not found.

Exists

Checks if Namespace exists on the server:

ns.exists

Will return None if not found.

Get

Query to get Pods (resource) in the connected cluster with label of label_example=example. Returns a generator of the resource - pod

for pod in Pod.get(dyn_client=client, label_selector="label_example=example")):
    pod.log()

We can also get the name of the Node that the pod is running on:

pod.node.name

VM

Start:

with VirtualMachine(
    name="vm-example",
    namespace="namespace-example",
    node_selector="worker-node-example",
) as vm:
    vm.start()

Stop:

vm.stop()

Restart:

vm.restart()

Get VMI:

test_vmi = vm.vmi

After having a VMI, we can wait until VMI is in running state:

test_vmi.wait_until_running()

Will raise TimeoutExpiredError if VMI failed to run.

Then, we can get the Pod that is in Running state and execute a command on it:

command_output = test_vmi.virt_launcher_pod.execute(command="command-example")

If no Pod was found, will raise ResourceNotFoundError.

Code check

We use pre-commit for code check.

pre-commit install

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

openshift_python_wrapper-4.9.14.tar.gz (53.4 kB view details)

Uploaded Source

Built Distribution

openshift_python_wrapper-4.9.14-py3-none-any.whl (89.9 kB view details)

Uploaded Python 3

File details

Details for the file openshift_python_wrapper-4.9.14.tar.gz.

File metadata

  • Download URL: openshift_python_wrapper-4.9.14.tar.gz
  • Upload date:
  • Size: 53.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.4 Linux/6.3.12-200.fc38.x86_64

File hashes

Hashes for openshift_python_wrapper-4.9.14.tar.gz
Algorithm Hash digest
SHA256 6d8932ed61729730e39b021b0553642c701791fbc4606a7e4233583cd5b53710
MD5 f21ccb27216761ca92d2534ab4adf48e
BLAKE2b-256 bce35c9f0e0b950a1f5b702a34d5274fd78b417c677de871f72ed46a5bb176ff

See more details on using hashes here.

File details

Details for the file openshift_python_wrapper-4.9.14-py3-none-any.whl.

File metadata

File hashes

Hashes for openshift_python_wrapper-4.9.14-py3-none-any.whl
Algorithm Hash digest
SHA256 9eb4241503d54c2f4bf599b1eb0a3beccda171e506673b4220e23d1a864e314d
MD5 9123bca4ca044d85d45da0d934cac3d9
BLAKE2b-256 5b621403d48903f7cd92459f9d612c1ab6432f94a52a8c5f6562b57ec86654c6

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