Manage a pool of nodes for a distributed test infrastructure
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Go to file
Tobias Henkel be79acbc98
Ignore files produced by tox-cover
5 years ago
devstack Add opensuse-150 to nodepool dsvm 5 years ago
doc Add ability to ignore provider quota for a pool 5 years ago
etc Merge "Add systemd drop-in file for CentOS 7" 5 years ago
nodepool Remove Task class 5 years ago
playbooks Refactor playbooks/nodepool-zuul-functional/pre.yaml 5 years ago
releasenotes/notes Add ability to ignore provider quota for a pool 5 years ago
roles/nodepool-zuul-functional Refactor playbooks/nodepool-zuul-functional/pre.yaml 5 years ago
tools Add opensuse-150 to nodepool dsvm 5 years ago
.coveragerc Switch to stestr 5 years ago
.gitignore Ignore files produced by tox-cover 5 years ago
.gitreview Replace master with feature/zuulv3 5 years ago
.stestr.conf Switch to stestr 5 years ago
.zuul.yaml Publish docs on release 5 years ago
LICENSE license: remove dos line break 5 years ago
README.rst Rename nodepoold to nodepool-launcher 6 years ago
bindep.txt Ensure only python3 is installed with bindep.txt 5 years ago
requirements.txt webapp: fix browser return 5 years ago
setup.cfg update supported python version in setup.cfg 5 years ago
setup.py Bump pbr requirements to >=1.3 8 years ago
test-requirements.txt Switch to stestr 5 years ago
tox.ini fix tox python3 overrides 5 years ago

README.rst

Nodepool

Nodepool is a service used by the OpenStack CI team to deploy and manage a pool of devstack images on a cloud server for use in OpenStack project testing.

Developer setup

Make sure you have pip installed:

wget https://bootstrap.pypa.io/get-pip.py
sudo python get-pip.py

Install dependencies:

sudo pip install bindep
sudo apt-get install $(bindep -b nodepool)

mkdir src
cd ~/src
git clone git://git.openstack.org/openstack-infra/system-config
git clone git://git.openstack.org/openstack-infra/nodepool
cd nodepool
sudo pip install -U -r requirements.txt
sudo pip install -e .

If you're testing a specific patch that is already in gerrit, you will also want to install git-review and apply that patch while in the nodepool directory, ie:

git review -x XXXXX

Create or adapt a nodepool yaml file. You can adapt an infra/system-config one, or fake.yaml as desired. Note that fake.yaml's settings won't Just Work - consult ./modules/openstack_project/templates/nodepool/nodepool.yaml.erb in the infra/system-config tree to see a production config.

If the cloud being used has no default_floating_pool defined in nova.conf, you will need to define a pool name using the nodepool yaml file to use floating ips.

Export variable for your ssh key so you can log into the created instances:

export NODEPOOL_SSH_KEY=`cat ~/.ssh/id_rsa.pub | awk '{print $2}'`

Start nodepool with a demo config file (copy or edit fake.yaml to contain your data):

export STATSD_HOST=127.0.0.1
export STATSD_PORT=8125
nodepool-launcher -d -c tools/fake.yaml

All logging ends up in stdout.

Use the following tool to check on progress:

nodepool image-list