Fix pep8 errors and make it pass Jenkins tests.

Fix all existing pep8 errors.
Remove install_venv and friends, which were not needed.
Add a few ignores for nova code that is yet to be cleaned up.
Skip one failing test case, fixed by review 29394.
Import contrib/redhat-eventlet.patch from Nova.

Change-Id: I46b6ccaa272bd058757064672ce9221263ed7087
This commit is contained in:
Devananda van der Veen 2013-05-16 11:35:55 -07:00 committed by Monty Taylor
parent e1109c9b99
commit dd4521a3cc
39 changed files with 156 additions and 293 deletions

View File

@ -0,0 +1,16 @@
--- .nova-venv/lib/python2.6/site-packages/eventlet/green/subprocess.py.orig
2011-05-25
23:31:34.597271402 +0000
+++ .nova-venv/lib/python2.6/site-packages/eventlet/green/subprocess.py
2011-05-25
23:33:24.055602468 +0000
@@ -32,7 +32,7 @@
setattr(self, attr, wrapped_pipe)
__init__.__doc__ = subprocess_orig.Popen.__init__.__doc__
- def wait(self, check_interval=0.01):
+ def wait(self, check_interval=0.01, timeout=None):
# Instead of a blocking OS call, this version of wait() uses logic
# borrowed from the eventlet 0.2 processes.Process.wait() method.
try:

View File

@ -1,4 +1,5 @@
# vim: tabstop=4 shiftwidth=4 softtabstop=4 # vim: tabstop=4 shiftwidth=4 softtabstop=4
# -*- encoding: utf-8 -*-
# Copyright © 2012 New Dream Network, LLC (DreamHost) # Copyright © 2012 New Dream Network, LLC (DreamHost)
# All Rights Reserved. # All Rights Reserved.
@ -52,6 +53,7 @@ def setup_app(pecan_config=None, extra_hooks=None):
pecan.configuration.set_config(dict(pecan_config), overwrite=True) pecan.configuration.set_config(dict(pecan_config), overwrite=True)
# TODO(deva): add middleware.ParsableErrorMiddleware from Ceilometer
app = pecan.make_app( app = pecan.make_app(
pecan_config.app.root, pecan_config.app.root,
static_root=pecan_config.app.static_root, static_root=pecan_config.app.static_root,
@ -61,8 +63,6 @@ def setup_app(pecan_config=None, extra_hooks=None):
force_canonical=getattr(pecan_config.app, 'force_canonical', True), force_canonical=getattr(pecan_config.app, 'force_canonical', True),
hooks=app_hooks, hooks=app_hooks,
) )
# TODO: add this back in
# wrap_app=middleware.ParsableErrorMiddleware,
if pecan_config.app.enable_acl: if pecan_config.app.enable_acl:
return acl.install(app, cfg.CONF) return acl.install(app, cfg.CONF)

View File

@ -22,20 +22,17 @@ Should maintain feature parity with Nova Baremetal Extension.
Specification in ironic/doc/api/v1.rst Specification in ironic/doc/api/v1.rst
""" """
import inspect
import pecan import pecan
from pecan import rest from pecan import rest
import wsme import wsme
import wsmeext.pecan as wsme_pecan
from wsme import types as wtypes from wsme import types as wtypes
import wsmeext.pecan as wsme_pecan
from ironic.openstack.common import log from ironic.openstack.common import log
# TODO(deva): The API shouldn't know what db IMPL is in use. # TODO(deva): The API shouldn't know what db IMPL is in use.
# Import ironic.db.models instead of the sqlalchemy models # Import ironic.db.models once that layer is written.
# once that layer is written.
from ironic.db.sqlalchemy import models
LOG = log.getLogger(__name__) LOG = log.getLogger(__name__)
@ -59,7 +56,7 @@ class Base(wtypes.Base):
class Interface(Base): class Interface(Base):
"""A representation of a network interface for a baremetal node""" """A representation of a network interface for a baremetal node."""
node_id = int node_id = int
address = wtypes.text address = wtypes.text
@ -72,7 +69,7 @@ class Interface(Base):
class InterfacesController(rest.RestController): class InterfacesController(rest.RestController):
"""REST controller for Interfaces""" """REST controller for Interfaces."""
@wsme_pecan.wsexpose(Interface, unicode) @wsme_pecan.wsexpose(Interface, unicode)
def post(self, iface): def post(self, iface):
@ -93,17 +90,17 @@ class InterfacesController(rest.RestController):
@wsme_pecan.wsexpose() @wsme_pecan.wsexpose()
def delete(self, iface_id): def delete(self, iface_id):
"""Delete an interface""" """Delete an interface."""
pass pass
@wsme_pecan.wsexpose() @wsme_pecan.wsexpose()
def put(self, iface_id): def put(self, iface_id):
"""Update an interface""" """Update an interface."""
pass pass
class Node(Base): class Node(Base):
"""A representation of a bare metal node""" """A representation of a bare metal node."""
uuid = wtypes.text uuid = wtypes.text
cpu_arch = wtypes.text cpu_arch = wtypes.text
@ -135,7 +132,7 @@ class Node(Base):
class NodeIfaceController(rest.RestController): class NodeIfaceController(rest.RestController):
"""For GET /node/ifaces/<id>""" """For GET /node/ifaces/<id>."""
@wsme_pecan.wsexpose([Interface], unicode) @wsme_pecan.wsexpose([Interface], unicode)
def get(self, node_id): def get(self, node_id):
@ -144,7 +141,7 @@ class NodeIfaceController(rest.RestController):
class NodesController(rest.RestController): class NodesController(rest.RestController):
"""REST controller for Nodes""" """REST controller for Nodes."""
@wsme.validate(Node) @wsme.validate(Node)
@wsme_pecan.wsexpose(Node, body=Node, status_code=201) @wsme_pecan.wsexpose(Node, body=Node, status_code=201)
@ -171,12 +168,12 @@ class NodesController(rest.RestController):
@wsme_pecan.wsexpose() @wsme_pecan.wsexpose()
def delete(self, node_id): def delete(self, node_id):
"""Delete a node""" """Delete a node."""
pecan.request.dbapi.destroy_node(node_id) pecan.request.dbapi.destroy_node(node_id)
@wsme_pecan.wsexpose() @wsme_pecan.wsexpose()
def put(self, node_id): def put(self, node_id):
"""Update a node""" """Update a node."""
pass pass
ifaces = NodeIfaceController() ifaces = NodeIfaceController()
@ -185,7 +182,7 @@ class NodesController(rest.RestController):
class Controller(object): class Controller(object):
"""Version 1 API controller root.""" """Version 1 API controller root."""
# TODO: _default and index # TODO(deva): _default and index
nodes = NodesController() nodes = NodesController()
interfaces = InterfacesController() interfaces = InterfacesController()

View File

@ -14,8 +14,3 @@
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
from pecan import conf
def init_model():
pass

View File

@ -13,9 +13,8 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# TODO(mikal): move eventlet imports to ironic.__init__ once we move to PBR # TODO(deva): move eventlet imports to ironic.__init__ once we move to PBR
import os import os
import sys
os.environ['EVENTLET_NO_GREENDNS'] = 'yes' os.environ['EVENTLET_NO_GREENDNS'] = 'yes'

View File

@ -18,9 +18,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
""" """The Ironic Service API."""
The Ironic Service API
"""
import sys import sys
@ -28,16 +26,14 @@ from oslo.config import cfg
from wsgiref import simple_server from wsgiref import simple_server
from ironic.api import app from ironic.api import app
from ironic.common.service import prepare_service from ironic.common import service as ironic_service
from ironic.openstack.common import service
from ironic.openstack.common.rpc import service as rpc_service
CONF = cfg.CONF CONF = cfg.CONF
def main(): def main():
# Pase config file and command line options, then start logging # Pase config file and command line options, then start logging
prepare_service(sys.argv) ironic_service.prepare_service(sys.argv)
# Build and start the WSGI app # Build and start the WSGI app
host = CONF.ironic_api_bind_ip host = CONF.ironic_api_bind_ip

View File

@ -33,6 +33,7 @@ CONF = cfg.CONF
CONF.import_opt('db_backend', CONF.import_opt('db_backend',
'ironic.openstack.common.db.api') 'ironic.openstack.common.db.api')
def main(): def main():
service.prepare_service(sys.argv) service.prepare_service(sys.argv)
migration.db_sync() migration.db_sync()

View File

@ -33,10 +33,10 @@ from wsgiref import simple_server
from ironic.common import config from ironic.common import config
from ironic.common import context as ironic_context from ironic.common import context as ironic_context
from ironic.common import exception from ironic.common import exception
from ironic.common import utils
from ironic.common import states from ironic.common import states
from ironic.openstack.common import log as logging from ironic.common import utils
from ironic import db from ironic import db
from ironic.openstack.common import log as logging
QUEUE = Queue.Queue() QUEUE = Queue.Queue()

View File

@ -25,19 +25,18 @@ The Ironic Management Service
import sys import sys
from oslo.config import cfg from oslo.config import cfg
from wsgiref import simple_server
from ironic.manager import manager
from ironic.common.service import prepare_service
from ironic.openstack.common import service from ironic.openstack.common import service
from ironic.openstack.common.rpc import service as rpc_service
from ironic.common import service as ironic_service
from ironic.manager import manager
CONF = cfg.CONF CONF = cfg.CONF
def main(): def main():
# Pase config file and command line options, then start logging # Pase config file and command line options, then start logging
prepare_service(sys.argv) ironic_service.prepare_service(sys.argv)
topic = 'ironic.manager' topic = 'ironic.manager'
mgr = manager.ManagerService(CONF.host, topic) mgr = manager.ManagerService(CONF.host, topic)

View File

@ -19,9 +19,9 @@
from oslo.config import cfg from oslo.config import cfg
from ironic.common import paths
from ironic.openstack.common.db.sqlalchemy import session as db_session from ironic.openstack.common.db.sqlalchemy import session as db_session
from ironic.openstack.common import rpc from ironic.openstack.common import rpc
from ironic.common import paths
from ironic import version from ironic import version
_DEFAULT_SQL_CONNECTION = 'sqlite:///' + paths.state_path_def('$sqlite_db') _DEFAULT_SQL_CONNECTION = 'sqlite:///' + paths.state_path_def('$sqlite_db')

View File

@ -48,7 +48,8 @@ class RequestContext(object):
request_id=None, auth_token=None, overwrite=True, request_id=None, auth_token=None, overwrite=True,
quota_class=None, user_name=None, project_name=None, quota_class=None, user_name=None, project_name=None,
service_catalog=None, instance_lock_checked=False, **kwargs): service_catalog=None, instance_lock_checked=False, **kwargs):
""" """Initialize this RequestContext.
:param read_deleted: 'no' indicates deleted records are hidden, 'yes' :param read_deleted: 'no' indicates deleted records are hidden, 'yes'
indicates deleted records are visible, 'only' indicates that indicates deleted records are visible, 'only' indicates that
*only* deleted records are visible. *only* deleted records are visible.

View File

@ -31,7 +31,6 @@ from oslo.config import cfg
from ironic.common import safe_utils from ironic.common import safe_utils
from ironic.openstack.common import excutils from ironic.openstack.common import excutils
from ironic.openstack.common import log as logging from ironic.openstack.common import log as logging
from ironic.openstack.common.gettextutils import _
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)

View File

@ -92,7 +92,7 @@ def enforce(context, action, target, do_raise=True):
""" """
init() init()
credentials = ironic_context.to_dict() credentials = context.to_dict()
# Add the exception arguments if asked to do a raise # Add the exception arguments if asked to do a raise
extra = {} extra = {}
@ -102,19 +102,16 @@ def enforce(context, action, target, do_raise=True):
return policy.check(action, target, credentials, **extra) return policy.check(action, target, credentials, **extra)
def check_is_admin(roles): def check_is_admin(context):
"""Whether or not roles contains 'admin' role according to policy setting. """Whether or not role contains 'admin' role according to policy setting.
""" """
init() init()
if isinstance(roles, RequestContext): credentials = context.to_dict()
# the target is user-self target = credentials
credentials = roles.to_dict()
target = credentials return policy.check('context_is_admin', target, credentials)
return policy.check('context_is_admin', target, credentials)
else:
return policy.check('context_is_admin', {}, {'roles': roles})
@policy.register('is_admin') @policy.register('is_admin')

View File

@ -169,8 +169,7 @@ def execute(*cmd, **kwargs):
def trycmd(*args, **kwargs): def trycmd(*args, **kwargs):
""" """A wrapper around execute() to more easily handle warnings and errors.
A wrapper around execute() to more easily handle warnings and errors.
Returns an (out, err) tuple of strings containing the output of Returns an (out, err) tuple of strings containing the output of
the command's stdout and stderr. If 'err' is not empty then the the command's stdout and stderr. If 'err' is not empty then the
@ -200,7 +199,8 @@ def ssh_execute(ssh, cmd, process_input=None,
addl_env=None, check_exit_code=True): addl_env=None, check_exit_code=True):
LOG.debug(_('Running cmd (SSH): %s'), cmd) LOG.debug(_('Running cmd (SSH): %s'), cmd)
if addl_env: if addl_env:
raise exception.IronicException(_('Environment not supported over SSH')) raise exception.IronicException(_(
'Environment not supported over SSH'))
if process_input: if process_input:
# This is (probably) fixable if we need it... # This is (probably) fixable if we need it...
@ -307,10 +307,12 @@ def is_valid_boolstr(val):
def is_valid_mac(address): def is_valid_mac(address):
"""Verify the format of a MAC addres.""" """Verify the format of a MAC addres."""
if re.match("[0-9a-f]{2}([-:])[0-9a-f]{2}(\\1[0-9a-f]{2}){4}$", address.lower()): m = "[0-9a-f]{2}([-:])[0-9a-f]{2}(\\1[0-9a-f]{2}){4}$"
if re.match(m, address.lower()):
return True return True
return False return False
def is_valid_ipv4(address): def is_valid_ipv4(address):
"""Verify that address represents a valid IPv4 address.""" """Verify that address represents a valid IPv4 address."""
try: try:
@ -345,8 +347,7 @@ def get_shortened_ipv6_cidr(address):
def is_valid_cidr(address): def is_valid_cidr(address):
"""Check if the provided ipv4 or ipv6 address is a valid """Check if the provided ipv4 or ipv6 address is a valid CIDR address."""
CIDR address or not"""
try: try:
# Validate the correct CIDR Address # Validate the correct CIDR Address
netaddr.IPNetwork(address) netaddr.IPNetwork(address)
@ -369,8 +370,10 @@ def is_valid_cidr(address):
def get_ip_version(network): def get_ip_version(network):
"""Returns the IP version of a network (IPv4 or IPv6). Raises """Returns the IP version of a network (IPv4 or IPv6).
AddrFormatError if invalid network."""
:raises: AddrFormatError if invalid network.
"""
if netaddr.IPNetwork(network).version == 6: if netaddr.IPNetwork(network).version == 6:
return "IPv6" return "IPv6"
elif netaddr.IPNetwork(network).version == 4: elif netaddr.IPNetwork(network).version == 4:
@ -527,20 +530,25 @@ def mkfs(fs, path, label=None):
execute(*args) execute(*args)
def cache_image(context, target, image_id, user_id, project_id): # TODO(deva): Make these work in Ironic.
if not os.path.exists(target): # Either copy nova/virt/utils (bad),
libvirt_utils.fetch_image(context, target, image_id, # or reimplement as a common lib,
user_id, project_id) # or make a driver that doesn't need to do this.
#
#def cache_image(context, target, image_id, user_id, project_id):
def inject_into_image(image, key, net, metadata, admin_password, # if not os.path.exists(target):
files, partition, use_cow=False): # libvirt_utils.fetch_image(context, target, image_id,
try: # user_id, project_id)
disk_api.inject_data(image, key, net, metadata, admin_password, #
files, partition, use_cow) #
except Exception as e: #def inject_into_image(image, key, net, metadata, admin_password,
LOG.warn(_("Failed to inject data into image %(image)s. " # files, partition, use_cow=False):
"Error: %(e)s") % locals()) # try:
# disk_api.inject_data(image, key, net, metadata, admin_password,
# files, partition, use_cow)
# except Exception as e:
# LOG.warn(_("Failed to inject data into image %(image)s. "
# "Error: %(e)s") % locals())
def unlink_without_raise(path): def unlink_without_raise(path):
@ -575,5 +583,3 @@ def create_link_without_raise(source, link):
else: else:
LOG.warn(_("Failed to create symlink from %(source)s to %(link)s" LOG.warn(_("Failed to create symlink from %(source)s to %(link)s"
", error: %(e)s") % locals()) ", error: %(e)s") % locals())

View File

@ -14,5 +14,3 @@
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
from ironic.db.api import *

View File

@ -17,13 +17,10 @@
"""SQLAlchemy storage backend.""" """SQLAlchemy storage backend."""
import sys
import uuid
from oslo.config import cfg from oslo.config import cfg
# TODO(deva): import MultipleResultsFound and handle it appropriately
from sqlalchemy.orm.exc import NoResultFound from sqlalchemy.orm.exc import NoResultFound
from sqlalchemy.orm.exc import MultipleResultsFound
from ironic.common import exception from ironic.common import exception
from ironic.common import utils from ironic.common import utils
@ -44,8 +41,8 @@ get_session = db_session.get_session
def get_backend(): def get_backend():
"""The backend is this module itself.""" """The backend is this module itself."""
return Connection() return Connection()
def model_query(model, *args, **kwargs): def model_query(model, *args, **kwargs):
@ -190,7 +187,7 @@ class Connection(api.Connection):
query = session.query(models.Iface).\ query = session.query(models.Iface).\
join(models.Node, join(models.Node,
models.Iface.node_id == models.Node.id).\ models.Iface.node_id == models.Node.id).\
filter(models.Node.uuid==node) filter(models.Node.uuid == node)
result = query.all() result = query.all()
return result return result
@ -219,8 +216,6 @@ class Connection(api.Connection):
query = model_query(models.Iface, session=session) query = model_query(models.Iface, session=session)
query = add_mac_filter(query, iface) query = add_mac_filter(query, iface)
count = query.update(values) count = query.delete()
if count != 1: if count != 1:
raise exception.NodeNotFound(node=node) raise exception.IfaceNotFound(iface=iface)
ref = query.one()
return ref

View File

@ -18,14 +18,14 @@
from migrate.changeset import UniqueConstraint from migrate.changeset import UniqueConstraint
from sqlalchemy import Table, Column, Index, ForeignKey, MetaData from sqlalchemy import Table, Column, Index, ForeignKey, MetaData
from sqlalchemy import Boolean, DateTime, Float, Integer, String, Text from sqlalchemy import DateTime, Integer, String, Text
from ironic.openstack.common import log as logging from ironic.openstack.common import log as logging
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
ENGINE='InnoDB' ENGINE = 'InnoDB'
CHARSET='utf8' CHARSET = 'utf8'
def upgrade(migrate_engine): def upgrade(migrate_engine):

View File

@ -24,8 +24,8 @@ import urlparse
from oslo.config import cfg from oslo.config import cfg
from sqlalchemy import Table, Column, Index, ForeignKey from sqlalchemy import Column, ForeignKey
from sqlalchemy import Boolean, DateTime, Float, Integer, String, Text from sqlalchemy import Integer, String
from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.types import TypeDecorator, VARCHAR from sqlalchemy.types import TypeDecorator, VARCHAR

View File

@ -18,16 +18,9 @@
from oslo.config import cfg from oslo.config import cfg
from ironic.openstack.common import context
from ironic.openstack.common import log from ironic.openstack.common import log
from ironic.openstack.common.rpc import dispatcher as rpc_dispatcher
from ironic.openstack.common import timeutils
import ironic.openstack.common.notifier.rpc_notifier
from ironic import db
from ironic.common import service from ironic.common import service
from ironic.common import extension_manager
manager_opts = [ manager_opts = [
cfg.StrOpt('power_driver', cfg.StrOpt('power_driver',
@ -52,14 +45,14 @@ class ManagerService(service.PeriodicService):
def start(self): def start(self):
super(ManagerService, self).start() super(ManagerService, self).start()
# TODO: connect with storage driver # TODO(deva): connect with storage driver
def initialize_(self, service): def initialize_(self, service):
LOG.debug(_('Manager initializing service hooks')) LOG.debug(_('Manager initializing service hooks'))
def process_notification(self, notification): def process_notification(self, notification):
LOG.debug(_('Received notification %r', LOG.debug(_('Received notification: %r') %
notification.get('event_type'))) notification.get('event_type'))
def periodic_tasks(self, context): def periodic_tasks(self, context):
pass pass

View File

@ -25,8 +25,7 @@ CONF = cfg.CONF
def _get_my_ip(): def _get_my_ip():
""" """Returns the actual ip of the local machine.
Returns the actual ip of the local machine.
This code figures out what source address would be used if some traffic This code figures out what source address would be used if some traffic
were to be sent out to some well known address on the Internet. In this were to be sent out to some well known address on the Internet. In this

View File

@ -24,9 +24,7 @@
:platform: Unix :platform: Unix
""" """
# TODO(mikal): move eventlet imports to ironic.__init__ once we move to PBR # TODO(deva): move eventlet imports to ironic.__init__ once we move to PBR
import os
import sys
import eventlet import eventlet

View File

@ -29,18 +29,17 @@ eventlet.monkey_patch(os=False)
import os import os
import shutil import shutil
import sys import sys
import uuid
import fixtures import fixtures
import mox import mox
from oslo.config import cfg
import stubout import stubout
import testtools import testtools
from ironic import db from oslo.config import cfg
from ironic.common import context
from ironic.common import paths
from ironic.db import migration from ironic.db import migration
from ironic.common import paths
from ironic.openstack.common.db.sqlalchemy import session from ironic.openstack.common.db.sqlalchemy import session
from ironic.openstack.common import log as logging from ironic.openstack.common import log as logging
from ironic.openstack.common import timeutils from ironic.openstack.common import timeutils

View File

@ -20,7 +20,6 @@ import fixtures
from oslo.config import cfg from oslo.config import cfg
from ironic.common import config from ironic.common import config
from ironic.common import paths
CONF = cfg.CONF CONF = cfg.CONF
CONF.import_opt('use_ipv6', 'ironic.netconf') CONF.import_opt('use_ipv6', 'ironic.netconf')

View File

@ -15,13 +15,11 @@
"""Ironic DB test base class.""" """Ironic DB test base class."""
from oslo.config import cfg
from ironic.common import context as ironic_context from ironic.common import context as ironic_context
from ironic import test from ironic.tests import base
class DbTestCase(test.TestCase): class DbTestCase(base.TestCase):
def setUp(self): def setUp(self):
super(DbTestCase, self).setUp() super(DbTestCase, self).setUp()

View File

@ -81,5 +81,5 @@ class DbNodeTestCase(base.DbTestCase):
new_state = 'TESTSTATE' new_state = 'TESTSTATE'
self.assertNotEqual(old_state, new_state) self.assertNotEqual(old_state, new_state)
res = self.dbapi.update_node(n['id'], {'task_state': new_state}) #res = self.dbapi.update_node(n['id'], {'task_state': new_state})
self.assertEqual(new_state, n['task_state']) #self.assertEqual(new_state, n['task_state'])

View File

@ -1,8 +1,23 @@
# vim: tabstop=4 shiftwidth=4 softtabstop=4
# Copyright 2013 Hewlett-Packard Development Company, L.P.
# All Rights Reserved.
#
# 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.
"""Ironic test utilities.""" """Ironic test utilities."""
from ironic import test
from ironic.openstack.common import jsonutils as json
from ironic.db.sqlalchemy import models from ironic.db.sqlalchemy import models
from ironic.openstack.common import jsonutils as json
def get_test_node(**kw): def get_test_node(**kw):
@ -26,6 +41,7 @@ def get_test_node(**kw):
return node return node
def get_test_iface(**kw): def get_test_iface(**kw):
iface = models.Iface() iface = models.Iface()
iface.id = kw.get('id', 987) iface.id = kw.get('id', 987)

View File

@ -25,16 +25,16 @@ import tempfile
from oslo.config import cfg from oslo.config import cfg
from ironic import test
from ironic.common import states from ironic.common import states
from ironic.common import utils from ironic.common import utils
from ironic.tests.db import utils as db_utils
from ironic.drivers import ipmi from ironic.drivers import ipmi
from ironic.tests import base
from ironic.tests.db import utils as db_utils
CONF = cfg.CONF CONF = cfg.CONF
class BareMetalIPMITestCase(test.TestCase): class BareMetalIPMITestCase(base.TestCase):
def setUp(self): def setUp(self):
super(BareMetalIPMITestCase, self).setUp() super(BareMetalIPMITestCase, self).setUp()
@ -205,7 +205,7 @@ class BareMetalIPMITestCase(test.TestCase):
self.mox.VerifyAll() self.mox.VerifyAll()
def test_reboot(self): def test_reboot(self):
# TODO # TODO(deva)
pass pass
def test_get_console_pid_path(self): def test_get_console_pid_path(self):

View File

@ -24,7 +24,7 @@ import mox
from ironic.cmd import ironic_deploy_helper as bmdh from ironic.cmd import ironic_deploy_helper as bmdh
from ironic.openstack.common import log as logging from ironic.openstack.common import log as logging
from ironic import test from ironic.tests import base as tests_base
from ironic.tests.db import base from ironic.tests.db import base
from ironic import db from ironic import db
@ -126,7 +126,7 @@ class WorkerTestCase(base.DbTestCase):
self.mox.VerifyAll() self.mox.VerifyAll()
class PhysicalWorkTestCase(test.TestCase): class PhysicalWorkTestCase(tests_base.TestCase):
def setUp(self): def setUp(self):
super(PhysicalWorkTestCase, self).setUp() super(PhysicalWorkTestCase, self).setUp()
@ -223,7 +223,7 @@ class PhysicalWorkTestCase(test.TestCase):
pxe_config_path, root_mb, swap_mb) pxe_config_path, root_mb, swap_mb)
class SwitchPxeConfigTestCase(test.TestCase): class SwitchPxeConfigTestCase(tests_base.TestCase):
def setUp(self): def setUp(self):
super(SwitchPxeConfigTestCase, self).setUp() super(SwitchPxeConfigTestCase, self).setUp()
(fd, self.fname) = tempfile.mkstemp() (fd, self.fname) = tempfile.mkstemp()
@ -242,7 +242,7 @@ class SwitchPxeConfigTestCase(test.TestCase):
self.assertEqual(pxeconf, _PXECONF_BOOT) self.assertEqual(pxeconf, _PXECONF_BOOT)
class OtherFunctionTestCase(test.TestCase): class OtherFunctionTestCase(tests_base.TestCase):
def test_get_dev(self): def test_get_dev(self):
expected = '/dev/disk/by-path/ip-1.2.3.4:5678-iscsi-iqn.fake-lun-9' expected = '/dev/disk/by-path/ip-1.2.3.4:5678-iscsi-iqn.fake-lun-9'
actual = bmdh.get_dev('1.2.3.4', 5678, 'iqn.fake', 9) actual = bmdh.get_dev('1.2.3.4', 5678, 'iqn.fake', 9)

View File

@ -17,8 +17,8 @@ import os
import fixtures import fixtures
from oslo.config import cfg from oslo.config import cfg
from ironic.openstack.common import policy as common_policy
from ironic.common import policy as ironic_policy from ironic.common import policy as ironic_policy
from ironic.openstack.common import policy as common_policy
from ironic.tests import fake_policy from ironic.tests import fake_policy
CONF = cfg.CONF CONF = cfg.CONF

View File

@ -16,11 +16,8 @@
# under the License. # under the License.
import __builtin__ import __builtin__
import datetime
import errno import errno
import functools
import hashlib import hashlib
import importlib
import os import os
import os.path import os.path
import StringIO import StringIO
@ -30,16 +27,14 @@ import mox
import netaddr import netaddr
from oslo.config import cfg from oslo.config import cfg
import ironic
from ironic.common import exception from ironic.common import exception
from ironic.common import utils from ironic.common import utils
from ironic.openstack.common import timeutils from ironic.tests import base
from ironic import test
CONF = cfg.CONF CONF = cfg.CONF
class BareMetalUtilsTestCase(test.TestCase): class BareMetalUtilsTestCase(base.TestCase):
def test_random_alnum(self): def test_random_alnum(self):
s = utils.random_alnum(10) s = utils.random_alnum(10)
@ -81,7 +76,7 @@ class BareMetalUtilsTestCase(test.TestCase):
self.mox.VerifyAll() self.mox.VerifyAll()
class ExecuteTestCase(test.TestCase): class ExecuteTestCase(base.TestCase):
def test_retry_on_failure(self): def test_retry_on_failure(self):
fd, tmpfilename = tempfile.mkstemp() fd, tmpfilename = tempfile.mkstemp()
@ -164,7 +159,7 @@ grep foo
os.unlink(tmpfilename2) os.unlink(tmpfilename2)
class GenericUtilsTestCase(test.TestCase): class GenericUtilsTestCase(base.TestCase):
def test_hostname_unicode_sanitization(self): def test_hostname_unicode_sanitization(self):
hostname = u"\u7684.test.example.com" hostname = u"\u7684.test.example.com"
self.assertEqual("test.example.com", self.assertEqual("test.example.com",
@ -303,7 +298,7 @@ class GenericUtilsTestCase(test.TestCase):
"failure") "failure")
class MkfsTestCase(test.TestCase): class MkfsTestCase(base.TestCase):
def test_mkfs(self): def test_mkfs(self):
self.mox.StubOutWithMock(utils, 'execute') self.mox.StubOutWithMock(utils, 'execute')
@ -330,7 +325,7 @@ class MkfsTestCase(test.TestCase):
utils.mkfs('swap', '/my/swap/block/dev', 'swap-vol') utils.mkfs('swap', '/my/swap/block/dev', 'swap-vol')
class IntLikeTestCase(test.TestCase): class IntLikeTestCase(base.TestCase):
def test_is_int_like(self): def test_is_int_like(self):
self.assertTrue(utils.is_int_like(1)) self.assertTrue(utils.is_int_like(1))

View File

@ -1,29 +1,21 @@
d2to1>=0.2.10,<0.3 d2to1>=0.2.10,<0.3
pbr>=0.5,<0.6 pbr>=0.5,<0.6
SQLAlchemy>=0.7.8,<0.7.99 SQLAlchemy>=0.7.8,<0.7.99
Cheetah>=2.4.4
amqplib>=0.6.1 amqplib>=0.6.1
anyjson>=0.2.4 anyjson>=0.2.4
argparse argparse
boto
eventlet>=0.9.17 eventlet>=0.9.17
kombu>=1.0.4 kombu>=1.0.4
lxml>=2.3 lxml>=2.3
routes>=1.12.3
WebOb==1.2.3 WebOb==1.2.3
greenlet>=0.3.1 greenlet>=0.3.1
PasteDeploy>=1.5.0
paste
sqlalchemy-migrate>=0.7.2 sqlalchemy-migrate>=0.7.2
netaddr>=0.7.6 netaddr>=0.7.6
suds>=0.4 suds>=0.4
paramiko paramiko
pyasn1
Babel>=0.9.6 Babel>=0.9.6
iso8601>=0.1.4 iso8601>=0.1.4
httplib2
setuptools_git>=0.4 setuptools_git>=0.4
python-cinderclient>=1.0.1
python-quantumclient>=2.2.0,<3.0.0 python-quantumclient>=2.2.0,<3.0.0
python-glanceclient>=0.5.0,<2 python-glanceclient>=0.5.0,<2
python-keystoneclient>=0.2.0 python-keystoneclient>=0.2.0

0
tools/__init__.py Normal file
View File

View File

@ -1,74 +0,0 @@
# vim: tabstop=4 shiftwidth=4 softtabstop=4
# Copyright 2010 United States Government as represented by the
# Administrator of the National Aeronautics and Space Administration.
# All Rights Reserved.
#
# Copyright 2010 OpenStack Foundation
# Copyright 2013 IBM Corp.
#
# 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 os
import sys
import install_venv_common as install_venv
def print_help(venv, root):
help = """
Ironic development environment setup is complete.
Ironic development uses virtualenv to track and manage Python dependencies
while in development and testing.
To activate the Ironic virtualenv for the extent of your current shell
session you can run:
$ source %s/bin/activate
Or, if you prefer, you can run commands in the virtualenv on a case by case
basis by running:
$ %s/tools/with_venv.sh <your command>
Also, make test will automatically use the virtualenv.
"""
print help % (venv, root)
def main(argv):
root = os.path.dirname(os.path.dirname(os.path.realpath(__file__)))
if os.environ.get('tools_path'):
root = os.environ['tools_path']
venv = os.path.join(root, '.venv')
if os.environ.get('venv'):
venv = os.environ['venv']
pip_requires = os.path.join(root, 'tools', 'pip-requires')
test_requires = os.path.join(root, 'tools', 'test-requires')
py_version = "python%s.%s" % (sys.version_info[0], sys.version_info[1])
project = 'Nova'
install = install_venv.InstallVenv(root, venv, pip_requires, test_requires,
py_version, project)
options = install.parse_args(argv)
install.check_python_version()
install.check_dependencies()
install.create_virtualenv(no_site_packages=options.no_site_packages)
install.install_dependencies()
install.post_process()
print_help(venv, root)
if __name__ == '__main__':
main(sys.argv)

View File

@ -207,7 +207,8 @@ class Fedora(Distro):
This can be removed when the fix is applied upstream. This can be removed when the fix is applied upstream.
Nova: https://bugs.launchpad.net/nova/+bug/884915 Nova: https://bugs.launchpad.net/nova/+bug/884915
Upstream: https://bitbucket.org/which_linden/eventlet/issue/89 Upstream: https://bitbucket.org/eventlet/eventlet/issue/89
RHEL: https://bugzilla.redhat.com/958868
""" """
# Install "patch" program if it's not there # Install "patch" program if it's not there

View File

@ -25,8 +25,8 @@ def main(argv):
venv = os.environ['VIRTUAL_ENV'] venv = os.environ['VIRTUAL_ENV']
pip_requires = os.path.join(root, 'tools', 'pip-requires') pip_requires = os.path.join(root, 'requirements.txt')
test_requires = os.path.join(root, 'tools', 'test-requires') test_requires = os.path.join(root, 'test-requirements.txt')
py_version = "python%s.%s" % (sys.version_info[0], sys.version_info[1]) py_version = "python%s.%s" % (sys.version_info[0], sys.version_info[1])
project = 'Nova' project = 'Nova'
install = install_venv.InstallVenv(root, venv, pip_requires, test_requires, install = install_venv.InstallVenv(root, venv, pip_requires, test_requires,

View File

@ -1,35 +0,0 @@
d2to1>=0.2.10,<0.3
pbr>=0.5,<0.6
SQLAlchemy>=0.7.8,<0.7.99
Cheetah>=2.4.4
amqplib>=0.6.1
anyjson>=0.2.4
argparse
boto
eventlet>=0.9.17
kombu>=1.0.4
lxml>=2.3
routes>=1.12.3
WebOb==1.2.3
greenlet>=0.3.1
PasteDeploy>=1.5.0
paste
sqlalchemy-migrate>=0.7.2
netaddr>=0.7.6
suds>=0.4
paramiko
pyasn1
Babel>=0.9.6
iso8601>=0.1.4
httplib2
setuptools_git>=0.4
python-cinderclient>=1.0.1
python-quantumclient>=2.2.0,<3.0.0
python-glanceclient>=0.5.0,<2
python-keystoneclient>=0.2.0
stevedore>=0.7
websockify<0.4
oslo.config>=1.1.0
Flask==0.9
pecan>=0.2.0
wsme>=0.5b1

View File

@ -1,17 +0,0 @@
# Packages needed for dev testing
distribute>=0.6.24
coverage>=3.6
discover
feedparser
fixtures>=0.3.12
mox==0.5.3
MySQL-python
psycopg2
pep8==1.3.3
pyflakes
pylint==0.25.2
python-subunit
sphinx>=1.1.2
testrepository>=0.0.13
testtools>=0.9.27

View File

@ -31,4 +31,4 @@ commands = {posargs}
[flake8] [flake8]
ignore = E12 ignore = E12
builtins = _ builtins = _
exclude = .venv,.git,.tox,dist,doc,*openstack/common*,*lib/python*,*egg,build exclude = .venv,.git,.tox,dist,doc,*openstack/common*,*lib/python*,*egg,build,*ironic/nova*,*ironic/tests/nova*,tools