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

0.0.6

  • Update devnest to work with jenkinsapi >= 0.3.23

  • Add missing six module to requirements

0.0.5

  • Unescape html content from offline reason

0.0.4

  • Fix error devnest command py313

  • Add timeout option for Jenkins operations

0.0.3

  • Catch all exceptions from nodes

  • Catch AttributeError from node

  • Add noqe for import in setup.py

  • add ‘distro’ and ‘selinux’ to setup_requires

  • latest changes and improvments (offline, post_xml)

  • Improve error handling

  • Lint fix in setup.py

  • Python3.8 deprecates platform.linux_distribution

  • add hostname to the devnest offline message

0.0.2

  • offline the slave after it’s been set up

  • offline the slave after it’s been set up

  • add support for ‘disconnect’ from Jenkins master cli command - lint fix

  • add support for ‘disconnect’ from Jenkins master cli command

0.0.1.dev49

  • Add IP address to the list column

  • Add dump config options

  • Add directory options to update multiply slaves at once

  • Ensure force reservation is only for not reserved nodes

  • Add force reserve without specific node

  • Add host to json output when reserving

  • Pep8 simple fix

  • If no regex is specified to match the host, reserve first available within group

  • Add json output to management command

  • Few tox fixes

  • Add python3 compability

  • Allow to extend node which is already reserved

  • Add option to force reserve node which is currently running CI job

  • Add new status for the node which isn’t idle

  • Allows loading params from environment variables

  • Use CrumbRequester instead of Requester

  • Ensure node is temporary offline before bringing it online

  • Ensure node is temp offline before marking it online

  • 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.6.tar.gz (28.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

devnest-0.0.6-py2.py3-none-any.whl (28.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file devnest-0.0.6.tar.gz.

File metadata

  • Download URL: devnest-0.0.6.tar.gz
  • Upload date:
  • Size: 28.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for devnest-0.0.6.tar.gz
Algorithm Hash digest
SHA256 ffd134c1dd8e1a66b3b37238e5a0a884d4dba5440f1841bdf854fe1822c87adc
MD5 4b510071cf4b39845af0fe5d1c7cab99
BLAKE2b-256 c9455dba95f1b3a1eeab09a6163df1838664d9d173c71e68865bc0420b76642a

See more details on using hashes here.

File details

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

File metadata

  • Download URL: devnest-0.0.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 28.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for devnest-0.0.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 ef46908fe8a81ccf02f15959b33bf7a6d619cf0d46d08fc7cd47fcaf040ebea7
MD5 d87c17c4d2097267db8c93fa5326dcc3
BLAKE2b-256 aa6a646d21cc3b08cd5ae2e8f7b4c8d3ed3a355586397cd89ef2090538d8d241

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page