senlin/senlin/tests/drivers/os_test/nova_v2.py

281 lines
9.0 KiB
Python

# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import copy
import time
from oslo_utils import uuidutils
from senlin.common import consts
from senlin.drivers import base
from senlin.drivers import sdk
class NovaClient(base.DriverBase):
"""Fake Nova V2 driver for test."""
def __init__(self, ctx):
self.fake_flavor = {
"is_disabled": False,
"disk": 1,
"OS-FLV-EXT-DATA:ephemeral": 0,
"os-flavor-access:is_public": True,
"id": "1",
"links": [],
"name": "m1.tiny",
"ram": 512,
"swap": "",
"vcpus": 1,
}
self.fake_image = {
"created": "2015-01-01T01:02:03Z",
"id": "70a599e0-31e7-49b7-b260-868f441e862b",
"links": [],
"metadata": {
"architecture": "x86_64",
"auto_disk_config": "True",
"kernel_id": "nokernel",
"ramdisk_id": "nokernel"
},
"minDisk": 0,
"minRam": 0,
"name": "cirros-0.3.5-x86_64-disk",
"progress": 100,
"status": "ACTIVE",
"updated": "2011-01-01T01:02:03Z"
}
self.fake_server_create = {
"id": "893c7791-f1df-4c3d-8383-3caae9656c62",
"availability_zone": "Zone1",
"name": "new-server-test",
"imageRef": "http://localhost/openstack/images/test-image",
"flavorRef": "http://localhost/openstack/flavors/1",
"metadata": {
"My Server Name": "Apache1"
},
"personality": [
{
"path": "/etc/banner.txt",
"contents": "personality-content"
}
],
"block_device_mapping_v2": [
{
"device_name": "/dev/sdb1",
"source_type": "blank",
"destination_type": "local",
"delete_on_termination": "True",
"guest_format": "swap",
"boot_index": "-1"
},
{
"device_name": "/dev/sda1",
"source_type": "volume",
"destination_type": "volume",
"uuid": "fake-volume-id-1",
"boot_index": "0"
}
]
}
self.fake_server_get = {
# Note: The name of some attrs are defined as following to keep
# compatible with the resource definition in openstacksdk. But
# the real name of these attrs returned by Nova API could be
# different, e.g. the name of 'access_ipv4' attribute is actually
# 'accessIPv4' in server_get API response.
"id": "893c7791-f1df-4c3d-8383-3caae9656c62",
"name": "new-server-test",
"availability_zone": "ZONE1",
"access_ipv4": "192.168.0.3",
"access_ipv6": "fe80::ac0e:2aff:fe87:5911",
"addresses": {
"private": [
{
"addr": "192.168.0.3",
"version": 4
}
]
},
"created_at": "2015-08-18T21:11:09Z",
"updated_at": "2012-08-20T21:11:09Z",
"flavor": {
"id": "1",
"links": []
},
"host_id": "65201c14a29663e06d0748e561207d998b343",
"image": {
"id": "FAKE_IMAGE_ID",
"links": []
},
"links": [],
"metadata": {
"My Server Name": "Apache1"
},
"progress": 0,
"status": "ACTIVE",
"project_id": "openstack",
"user_id": "fake"
}
self.fake_service_list = [
{
'id': 'IDENTIFIER1',
'binary': 'nova-api',
'host': 'host1',
'status': 'enabled',
'state': 'up',
'zone': 'nova'
},
{
'id': 'IDENTIFIER2',
'binary': 'nova-compute',
'host': 'host1',
'status': 'enabled',
'state': 'up',
'zone': 'nova'
},
]
self.keypair = {
'public_key': 'blahblah',
'type': 'ssh',
'name': 'oskey',
'fingerprint': 'not-real',
}
self.availability_zone = {
'zoneState': {
'available': True
},
'hosts': None,
'zoneName': 'nova',
}
self.simulated_waits = {}
def flavor_find(self, name_or_id, ignore_missing=False):
return sdk.FakeResourceObject(self.fake_flavor)
def flavor_list(self, details=True, **query):
return [sdk.FakeResourceObject(self.fake_flavor)]
def image_find(self, name_or_id, ignore_missing=False):
return sdk.FakeResourceObject(self.fake_image)
def image_list(self, details=True, **query):
return [sdk.FakeResourceObject(self.fake_image)]
def keypair_list(self, details=True, **query):
return [sdk.FakeResourceObject(self.fake_keypair)]
def keypair_find(self, name_or_id, ignore_missing=False):
return sdk.FakeResourceObject(self.keypair)
def server_create(self, **attrs):
server_id = uuidutils.generate_uuid()
self.fake_server_create['id'] = server_id
self.fake_server_get['id'] = server_id
# save simulated wait time if it was set in metadata
if ('metadata' in attrs and
'simulated_wait_time' in attrs['metadata']):
simulated_wait = attrs['metadata']['simulated_wait_time']
if (isinstance(simulated_wait, int) and simulated_wait > 0):
self.simulated_waits[server_id] = simulated_wait
return sdk.FakeResourceObject(self.fake_server_create)
def server_get(self, server):
return sdk.FakeResourceObject(self.fake_server_get)
def wait_for_server(self, server, status=consts.VS_ACTIVE,
failures=None,
interval=2, timeout=None):
# sleep for simulated wait time if it was supplied during server_create
if server in self.simulated_waits:
time.sleep(self.simulated_waits[server])
return
def wait_for_server_delete(self, server, timeout=None):
# sleep for simulated wait time if it was supplied during server_create
if server in self.simulated_waits:
time.sleep(self.simulated_waits[server])
del self.simulated_waits[server]
return
def server_update(self, server, **attrs):
self.fake_server_get.update(attrs)
return sdk.FakeResourceObject(self.fake_server_get)
def server_rebuild(self, server, imageref, name=None, admin_password=None,
**attrs):
if imageref:
attrs['image'] = {'id': imageref}
if name:
attrs['name'] = name
if admin_password:
attrs['adminPass'] = admin_password
self.fake_server_get.update(attrs)
return sdk.FakeResourceObject(self.fake_server_get)
def server_resize(self, server, flavor):
self.fake_server_get['flavor'].update({'id': flavor})
def server_resize_confirm(self, server):
return
def server_resize_revert(self, server):
return
def server_reboot(self, server, reboot_type):
return
def server_delete(self, server, ignore_missing=True):
return
def server_stop(self, server):
return
def server_force_delete(self, server, ignore_missing=True):
return
def server_metadata_get(self, server):
return {}
def server_metadata_update(self, server, metadata):
new_server = copy.deepcopy(self.fake_server_get)
new_server['metadata'] = metadata
server = sdk.FakeResourceObject(new_server)
return server
def server_metadata_delete(self, server, keys):
return
def service_list(self):
return sdk.FakeResourceObject(self.fake_service_list)
def service_force_down(self, service, host, binary):
return
def service_enable(self, service, host, binary):
return
def service_disable(self, service, host, binary):
return
def availability_zone_list(self, **query):
return [sdk.FakeResourceObject(self.availability_zone)]