Skip to main content

TBD

Project description

# Devnest Tool

A simple CLI to manage “reservations” for the hardware in devnest.

The primary use case for this tool is to reserve shared node for debugging and development work.

Current implementation uses Jenkins APIs and metadata stored inside Jenkins to manage lifecycle of hardware in the DevNest.

Once the node is reserved it’s being put offline, so no other Jenkins user is able to use it, until reservation expires and it’s being cleaned.

### Usage

## Config File

By default, devnest looks for ~/.config/jenkins_jobs/jenkins_jobs.ini, or /etc/jenkins_jobs/jenkins_jobs.ini (in that order).

It is possible to replace CLI arguments such as user, password and url with config file containing this information and pass path to this file using –conf flag.:

` [jenkins] user=JENKINS_USERNAME password=JENKINS_API_TOKEN url=https://JENKINS_URL `

JENKINS_API_TOKEN can be found using Jenkins at:

https://JENKINS_URL/user/JENKINS_USERNAME/configure

## Run DevNest CLI

Running in virtual environment:

` git clone https://github.com/rhos-infra/devnest.git virtualenv my-devnest-virtenv source my-devnest-virtenv/bin/activate pushd devnest pip install . devnest --help `

## Sample commands

To list based on regexp in a “shared” pool of servers ` devnest --conf config.ini list -g shared "*my_node_0?" `

To list all i a “shared” pool of servers ` devnest --conf config.ini list -g shared `

To reserve node from “shared” pool for 4h (regex must match only 1 node) ` devnest --conf config.ini reserve -g shared -t 4 *my_node_03 `

To release reservation ` devnest --conf config.ini release *my_node_03 `

CHANGES

  • Add option to list nodes based on state

  • Updated links after moving devnest from private to rhos-infra repo

  • Fix linting

  • Fix parsing of json if one contains wrong quotes

  • Add functions to setup slave based on XML file

  • Fix function argument name

  • Added AUTHORS file

  • Added option to set reprovision pending state

  • Enhance groups in columns to be comma separated list

  • Updated options to be more user friendly

  • Enable packaging

  • User can select parseable type output

  • Default location for config file

  • Rename Jenkins to DevNest

  • Added extra metadata to easy login to the box

  • Rename jenkinsnodecli to devnest

  • Added vCPU capability

  • Introduced node capabilities

  • Changed column names in the output

  • Changed termnology for the node status

  • Add option to specify owner who reserved the node

  • Fixed issue where node was not in sync with description

  • Added options to manage node groups/labels

  • Changed CLI arguments and supporting functions to be more restrictive for standard user, e.g. one user can’t release box of another user

  • Added info for the better user experience

  • Fix improper call to Jenkins.node (performance)

  • Fixed function get_reservation_endtime_epoch

  • Added error when no argument is specified

  • Initial commit of Jenkins Node CLI

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

devnest-0.0.1.dev29.tar.gz (21.2 kB view details)

Uploaded Source

Built Distribution

devnest-0.0.1.dev29-py2.py3-none-any.whl (22.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file devnest-0.0.1.dev29.tar.gz.

File metadata

File hashes

Hashes for devnest-0.0.1.dev29.tar.gz
Algorithm Hash digest
SHA256 26203943925112379198713e7e45a61faf94ddccd7c4dc94f148d2e1f2408f25
MD5 c6a3994ef3afbabdedb322d011801fb9
BLAKE2b-256 d8800bfadb1e356b7ec0026160f2a84da4d5c0fa0055ba8d2cb60674543a8f19

See more details on using hashes here.

File details

Details for the file devnest-0.0.1.dev29-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for devnest-0.0.1.dev29-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 15f6031a4ad0317054def17ab7d0050125ff641561836b758f8ce6fba6e065cb
MD5 d8d11ff4ca8520a0823dedf7e7891541
BLAKE2b-256 9599c506cfd142bbe20a36134d8a0251f56b90c565a3b5a2892fc6b3543f2481

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