From 03eb698bbf601eb51d694de79b77c5205c319350 Mon Sep 17 00:00:00 2001 From: Przemyslaw Kaminski Date: Tue, 4 Aug 2015 09:31:40 +0200 Subject: [PATCH] Nova API test.py with servers, flavors, images --- resources/cinder_puppet/README.md | 4 +- resources/glance_api_service/test.py | 2 +- resources/glance_puppet/README.md | 2 +- resources/glance_puppet/test.py | 2 +- resources/keystone_service_endpoint/test.py | 2 +- resources/keystone_user/test.py | 2 +- resources/nova_api_puppet/test.py | 92 +++++++++++++++++++++ resources/nova_puppet/README.md | 2 +- solar/solar/core/validation.py | 2 +- 9 files changed, 101 insertions(+), 9 deletions(-) create mode 100644 resources/nova_api_puppet/test.py diff --git a/resources/cinder_puppet/README.md b/resources/cinder_puppet/README.md index 0f288ca8..52021836 100644 --- a/resources/cinder_puppet/README.md +++ b/resources/cinder_puppet/README.md @@ -1,6 +1,6 @@ # Cinder resource for puppet handler -Controlls a live cycle of the cinder entities, +Controls a live cycle of the cinder entities, like the main puppet class, auth, DB, AMQP, packages, keystone user, role and endpoint. @@ -109,4 +109,4 @@ source https://github.com/openstack/puppet-cinder/blob/5.1.0/manifests/init.pp ``sql_connection`` DEPRECATED ``sql_idle_timeout`` - DEPRECATED \ No newline at end of file + DEPRECATED diff --git a/resources/glance_api_service/test.py b/resources/glance_api_service/test.py index 23dcb7de..ba87049c 100644 --- a/resources/glance_api_service/test.py +++ b/resources/glance_api_service/test.py @@ -9,7 +9,7 @@ def test(resource): args = resource.args - token = validation.validate_token( + token, _ = validation.validate_token( keystone_host=args['keystone_host'].value, keystone_port=args['keystone_port'].value, user='glance_admin', diff --git a/resources/glance_puppet/README.md b/resources/glance_puppet/README.md index 8c84b90f..74be1851 100644 --- a/resources/glance_puppet/README.md +++ b/resources/glance_puppet/README.md @@ -1,6 +1,6 @@ # Glance (API) resource for puppet handler -Controlls a live cycle of the glance entities, +Controls a live cycle of the glance entities, like the main puppet class, auth, DB, AMQP, packages, keystone user, role and endpoint, API service. Also configures glance file backend. diff --git a/resources/glance_puppet/test.py b/resources/glance_puppet/test.py index b3ee8f02..e6fece1f 100644 --- a/resources/glance_puppet/test.py +++ b/resources/glance_puppet/test.py @@ -13,7 +13,7 @@ def test(resource): args = resource.args - token = validation.validate_token( + token, _ = validation.validate_token( keystone_host=args['keystone_host'].value, keystone_port=args['keystone_port'].value, user=args['keystone_user'].value, diff --git a/resources/keystone_service_endpoint/test.py b/resources/keystone_service_endpoint/test.py index edeede03..19819125 100644 --- a/resources/keystone_service_endpoint/test.py +++ b/resources/keystone_service_endpoint/test.py @@ -12,7 +12,7 @@ def test(resource): 'http://%s:%s/v3/services' % (resource.args['ip'].value, resource.args['keystone_admin_port'].value), headers={ 'X-Auth-Token': resource.args['admin_token'].value, - } + } ) resp_json = resp.json() diff --git a/resources/keystone_user/test.py b/resources/keystone_user/test.py index fcce9508..f37f375e 100644 --- a/resources/keystone_user/test.py +++ b/resources/keystone_user/test.py @@ -9,7 +9,7 @@ def test(resource): args = resource.args - token = validation.validate_token( + token, _ = validation.validate_token( keystone_host=args['keystone_host'].value, keystone_port=args['keystone_port'].value, user=args['user_name'].value, diff --git a/resources/nova_api_puppet/test.py b/resources/nova_api_puppet/test.py new file mode 100644 index 00000000..ca32863f --- /dev/null +++ b/resources/nova_api_puppet/test.py @@ -0,0 +1,92 @@ +import json +import requests + +from solar.core.log import log +from solar.core import validation + + +def test(resource): + log.debug('Testing nova api') + + args = resource.args + + token, token_data = validation.validate_token( + keystone_host=args['auth_host'].value, + keystone_port=args['auth_port'].value, + user=args['admin_user'].value, + tenant=args['admin_tenant_name'].value, + password=args['admin_password'].value, + ) + + endpoints = [ + e['endpoints'] for e in token_data['access']['serviceCatalog'] + if e['name'] == 'nova' + ][0] + public_url = endpoints[0]['publicURL'] + + log.debug('nova admin_url: %s', public_url) + + servers = requests.get( + '{public_url}/servers/detail'.format(public_url=public_url), + headers={ + 'X-Auth-Token': token, + 'Content-Type': 'application/json', + } + ) + + servers_json = servers.json() + + log.debug( + 'NOVA API SERVERS: %s', + json.dumps(servers_json, indent=2) + ) + + assert 'servers' in servers_json + assert isinstance(servers_json['servers'], list) + + flavors = requests.get( + '{public_url}/flavors'.format(public_url=public_url), + headers={ + 'X-Auth-Token': token, + 'Content-Type': 'application/json', + } + ) + + flavors_json = flavors.json() + + log.debug('NOVA API FLAVORS: %s', json.dumps(flavors_json, indent=2)) + + assert 'flavors' in flavors_json + assert isinstance(flavors_json['flavors'], list) + assert len(flavors_json['flavors']) > 0 + + for flavor_data in flavors_json['flavors']: + url = [link['href'] for link in flavor_data['links'] + if link['rel'] == 'self'][0] + + flavor = requests.get( + url, + headers={ + 'X-Auth-Token': token, + 'Content-Type': 'application/json', + } + ) + + flavor_json = flavor.json() + + log.debug( + 'NOVA API FLAVOR %s data: %s', + flavor_data['name'], + json.dumps(flavor_json, indent=2) + ) + + images = requests.get( + '{public_url}/images'.format(public_url=public_url), + headers={ + 'X-Auth-Token': token, + 'Content-Type': 'application/json', + } + ) + + log.debug('NOVA API IMAGES: %s', images.json()) + diff --git a/resources/nova_puppet/README.md b/resources/nova_puppet/README.md index 76b594e3..ad41226a 100644 --- a/resources/nova_puppet/README.md +++ b/resources/nova_puppet/README.md @@ -1,6 +1,6 @@ # Nova resource for puppet handler -Controlls a live cycle of the nova entities, +Controls a live cycle of the nova entities, like the main puppet class, auth, DB, AMQP, packages, keystone user, role and endpoint. diff --git a/solar/solar/core/validation.py b/solar/solar/core/validation.py index dee5cf11..e4efe4a0 100644 --- a/solar/solar/core/validation.py +++ b/solar/solar/core/validation.py @@ -192,4 +192,4 @@ def validate_token( log.debug('%s TOKEN: %s', user, token) - return token + return token, token_data.json()