Cleaned up pep8/pylint for bin/* files. I did not fix rsapi since this is already cleaned up in another branch.
This commit is contained in:
parent
ff47d384a4
commit
46c0f66d12
@ -29,8 +29,6 @@ from nova import flags
|
|||||||
from nova import rpc
|
from nova import rpc
|
||||||
from nova import server
|
from nova import server
|
||||||
from nova import utils
|
from nova import utils
|
||||||
from nova.auth import manager
|
|
||||||
from nova.compute import model
|
|
||||||
from nova.endpoint import admin
|
from nova.endpoint import admin
|
||||||
from nova.endpoint import api
|
from nova.endpoint import api
|
||||||
from nova.endpoint import cloud
|
from nova.endpoint import cloud
|
||||||
@ -39,10 +37,10 @@ FLAGS = flags.FLAGS
|
|||||||
|
|
||||||
|
|
||||||
def main(_argv):
|
def main(_argv):
|
||||||
|
"""Load the controllers and start the tornado I/O loop."""
|
||||||
controllers = {
|
controllers = {
|
||||||
'Cloud': cloud.CloudController(),
|
'Cloud': cloud.CloudController(),
|
||||||
'Admin': admin.AdminController()
|
'Admin': admin.AdminController()}
|
||||||
}
|
|
||||||
_app = api.APIServerApplication(controllers)
|
_app = api.APIServerApplication(controllers)
|
||||||
|
|
||||||
conn = rpc.Connection.instance()
|
conn = rpc.Connection.instance()
|
||||||
|
@ -18,8 +18,6 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
nova-dhcpbridge
|
|
||||||
|
|
||||||
Handle lease database updates from DHCP servers.
|
Handle lease database updates from DHCP servers.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
@ -42,34 +40,43 @@ from nova.network import service
|
|||||||
FLAGS = flags.FLAGS
|
FLAGS = flags.FLAGS
|
||||||
|
|
||||||
|
|
||||||
def add_lease(mac, ip, hostname, interface):
|
def add_lease(_mac, ip, _hostname, _interface):
|
||||||
|
"""Set the IP that was assigned by the DHCP server."""
|
||||||
if FLAGS.fake_rabbit:
|
if FLAGS.fake_rabbit:
|
||||||
service.VlanNetworkService().lease_ip(ip)
|
service.VlanNetworkService().lease_ip(ip)
|
||||||
else:
|
else:
|
||||||
rpc.cast("%s.%s" (FLAGS.network_topic, FLAGS.node_name),
|
rpc.cast("%s.%s" % (FLAGS.network_topic, FLAGS.node_name),
|
||||||
{"method": "lease_ip",
|
{"method": "lease_ip",
|
||||||
"args" : {"fixed_ip": ip}})
|
"args": {"fixed_ip": ip}})
|
||||||
|
|
||||||
def old_lease(mac, ip, hostname, interface):
|
|
||||||
|
def old_lease(_mac, _ip, _hostname, _interface):
|
||||||
|
"""Do nothing, just an old lease update."""
|
||||||
logging.debug("Adopted old lease or got a change of mac/hostname")
|
logging.debug("Adopted old lease or got a change of mac/hostname")
|
||||||
|
|
||||||
def del_lease(mac, ip, hostname, interface):
|
|
||||||
|
def del_lease(_mac, ip, _hostname, _interface):
|
||||||
|
"""Remove the leased IP from the databases."""
|
||||||
if FLAGS.fake_rabbit:
|
if FLAGS.fake_rabbit:
|
||||||
service.VlanNetworkService().release_ip(ip)
|
service.VlanNetworkService().release_ip(ip)
|
||||||
else:
|
else:
|
||||||
rpc.cast("%s.%s" (FLAGS.network_topic, FLAGS.node_name),
|
rpc.cast("%s.%s" % (FLAGS.network_topic, FLAGS.node_name),
|
||||||
{"method": "release_ip",
|
{"method": "release_ip",
|
||||||
"args" : {"fixed_ip": ip}})
|
"args": {"fixed_ip": ip}})
|
||||||
|
|
||||||
|
|
||||||
def init_leases(interface):
|
def init_leases(interface):
|
||||||
|
"""Get the list of hosts for an interface."""
|
||||||
net = model.get_network_by_interface(interface)
|
net = model.get_network_by_interface(interface)
|
||||||
res = ""
|
res = ""
|
||||||
for host_name in net.hosts:
|
for host_name in net.hosts:
|
||||||
res += "%s\n" % linux_net.hostDHCP(net, host_name, net.hosts[host_name])
|
res += "%s\n" % linux_net.hostDHCP(net, host_name,
|
||||||
|
net.hosts[host_name])
|
||||||
return res
|
return res
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
|
"""Parse environment and arguments and call the approproate action."""
|
||||||
flagfile = os.environ.get('FLAGFILE', FLAGS.dhcpbridge_flagfile)
|
flagfile = os.environ.get('FLAGFILE', FLAGS.dhcpbridge_flagfile)
|
||||||
utils.default_flagfile(flagfile)
|
utils.default_flagfile(flagfile)
|
||||||
argv = FLAGS(sys.argv)
|
argv = FLAGS(sys.argv)
|
||||||
@ -79,18 +86,19 @@ def main():
|
|||||||
FLAGS.redis_db = 8
|
FLAGS.redis_db = 8
|
||||||
FLAGS.network_size = 32
|
FLAGS.network_size = 32
|
||||||
FLAGS.connection_type = 'fake'
|
FLAGS.connection_type = 'fake'
|
||||||
FLAGS.fake_network=True
|
FLAGS.fake_network = True
|
||||||
FLAGS.auth_driver='nova.auth.ldapdriver.FakeLdapDriver'
|
FLAGS.auth_driver = 'nova.auth.ldapdriver.FakeLdapDriver'
|
||||||
action = argv[1]
|
action = argv[1]
|
||||||
if action in ['add','del','old']:
|
if action in ['add', 'del', 'old']:
|
||||||
mac = argv[2]
|
mac = argv[2]
|
||||||
ip = argv[3]
|
ip = argv[3]
|
||||||
hostname = argv[4]
|
hostname = argv[4]
|
||||||
logging.debug("Called %s for mac %s with ip %s and hostname %s on interface %s" % (action, mac, ip, hostname, interface))
|
logging.debug("Called %s for mac %s with ip %s and "
|
||||||
globals()[action+'_lease'](mac, ip, hostname, interface)
|
"hostname %s on interface %s",
|
||||||
|
action, mac, ip, hostname, interface)
|
||||||
|
globals()[action + '_lease'](mac, ip, hostname, interface)
|
||||||
else:
|
else:
|
||||||
print init_leases(interface)
|
print init_leases(interface)
|
||||||
exit(0)
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
sys.exit(main())
|
main()
|
||||||
|
@ -37,20 +37,17 @@ FLAGS = flags.FLAGS
|
|||||||
|
|
||||||
api_url = 'https://imagestore.canonical.com/api/dashboard'
|
api_url = 'https://imagestore.canonical.com/api/dashboard'
|
||||||
|
|
||||||
image_cache = None
|
|
||||||
def images():
|
|
||||||
global image_cache
|
|
||||||
if not image_cache:
|
|
||||||
try:
|
|
||||||
images = json.load(urllib2.urlopen(api_url))['images']
|
|
||||||
image_cache = [i for i in images if i['title'].find('amd64') > -1]
|
|
||||||
except Exception:
|
|
||||||
print 'unable to download canonical image list'
|
|
||||||
sys.exit(1)
|
|
||||||
return image_cache
|
|
||||||
|
|
||||||
# FIXME(ja): add checksum/signature checks
|
def get_images():
|
||||||
|
"""Get a list of the images from the imagestore URL."""
|
||||||
|
images = json.load(urllib2.urlopen(api_url))['images']
|
||||||
|
images = [img for img in images if img['title'].find('amd64') > -1]
|
||||||
|
return images
|
||||||
|
|
||||||
|
|
||||||
def download(img):
|
def download(img):
|
||||||
|
"""Download an image to the local filesystem."""
|
||||||
|
# FIXME(ja): add checksum/signature checks
|
||||||
tempdir = tempfile.mkdtemp(prefix='cis-')
|
tempdir = tempfile.mkdtemp(prefix='cis-')
|
||||||
|
|
||||||
kernel_id = None
|
kernel_id = None
|
||||||
@ -79,20 +76,22 @@ def download(img):
|
|||||||
|
|
||||||
shutil.rmtree(tempdir)
|
shutil.rmtree(tempdir)
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
|
"""Main entry point."""
|
||||||
utils.default_flagfile()
|
utils.default_flagfile()
|
||||||
argv = FLAGS(sys.argv)
|
argv = FLAGS(sys.argv)
|
||||||
|
images = get_images()
|
||||||
|
|
||||||
if len(argv) == 2:
|
if len(argv) == 2:
|
||||||
for img in images():
|
for img in images:
|
||||||
if argv[1] == 'all' or argv[1] == img['title']:
|
if argv[1] == 'all' or argv[1] == img['title']:
|
||||||
download(img)
|
download(img)
|
||||||
else:
|
else:
|
||||||
print 'usage: %s (title|all)'
|
print 'usage: %s (title|all)'
|
||||||
print 'available images:'
|
print 'available images:'
|
||||||
for image in images():
|
for img in images:
|
||||||
print image['title']
|
print img['title']
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
|
||||||
|
@ -22,7 +22,6 @@
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
from twisted.internet import task
|
|
||||||
from twisted.application import service
|
from twisted.application import service
|
||||||
|
|
||||||
from nova import twistd
|
from nova import twistd
|
||||||
@ -30,7 +29,11 @@ from nova.compute import monitor
|
|||||||
|
|
||||||
logging.getLogger('boto').setLevel(logging.WARN)
|
logging.getLogger('boto').setLevel(logging.WARN)
|
||||||
|
|
||||||
def main():
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
twistd.serve(__file__)
|
||||||
|
|
||||||
|
if __name__ == '__builtin__':
|
||||||
logging.warn('Starting instance monitor')
|
logging.warn('Starting instance monitor')
|
||||||
m = monitor.InstanceMonitor()
|
m = monitor.InstanceMonitor()
|
||||||
|
|
||||||
@ -38,14 +41,3 @@ def main():
|
|||||||
# parses this file, return it so that we can get it into globals below
|
# parses this file, return it so that we can get it into globals below
|
||||||
application = service.Application('nova-instancemonitor')
|
application = service.Application('nova-instancemonitor')
|
||||||
m.setServiceParent(application)
|
m.setServiceParent(application)
|
||||||
return application
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
twistd.serve(__file__)
|
|
||||||
|
|
||||||
if __name__ == '__builtin__':
|
|
||||||
application = main()
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
138
bin/nova-manage
138
bin/nova-manage
@ -37,12 +37,15 @@ FLAGS = flags.FLAGS
|
|||||||
|
|
||||||
|
|
||||||
class VpnCommands(object):
|
class VpnCommands(object):
|
||||||
|
"""Class for managing VPNs."""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.manager = manager.AuthManager()
|
self.manager = manager.AuthManager()
|
||||||
self.instdir = model.InstanceDirectory()
|
self.instdir = model.InstanceDirectory()
|
||||||
self.pipe = pipelib.CloudPipe(cloud.CloudController())
|
self.pipe = pipelib.CloudPipe(cloud.CloudController())
|
||||||
|
|
||||||
def list(self):
|
def list(self):
|
||||||
|
"""Print a listing of the VPNs for all projects."""
|
||||||
print "%-12s\t" % 'project',
|
print "%-12s\t" % 'project',
|
||||||
print "%-12s\t" % 'ip:port',
|
print "%-12s\t" % 'ip:port',
|
||||||
print "%s" % 'state'
|
print "%s" % 'state'
|
||||||
@ -50,9 +53,10 @@ class VpnCommands(object):
|
|||||||
print "%-12s\t" % project.name,
|
print "%-12s\t" % project.name,
|
||||||
print "%s:%s\t" % (project.vpn_ip, project.vpn_port),
|
print "%s:%s\t" % (project.vpn_ip, project.vpn_port),
|
||||||
|
|
||||||
vpn = self.__vpn_for(project.id)
|
vpn = self._vpn_for(project.id)
|
||||||
if vpn:
|
if vpn:
|
||||||
out, err = utils.execute("ping -c1 -w1 %s > /dev/null; echo $?" % vpn['private_dns_name'])
|
command = "ping -c1 -w1 %s > /dev/null; echo $?"
|
||||||
|
out, _err = utils.execute(command % vpn['private_dns_name'])
|
||||||
if out.strip() == '0':
|
if out.strip() == '0':
|
||||||
net = 'up'
|
net = 'up'
|
||||||
else:
|
else:
|
||||||
@ -66,25 +70,32 @@ class VpnCommands(object):
|
|||||||
else:
|
else:
|
||||||
print None
|
print None
|
||||||
|
|
||||||
def __vpn_for(self, project_id):
|
def _vpn_for(self, project_id):
|
||||||
|
"""Get the VPN instance for a project ID."""
|
||||||
for instance in self.instdir.all:
|
for instance in self.instdir.all:
|
||||||
if (instance.state.has_key('image_id')
|
if ('image_id' in instance.state
|
||||||
and instance['image_id'] == FLAGS.vpn_image_id
|
and instance['image_id'] == FLAGS.vpn_image_id
|
||||||
and not instance['state_description'] in ['shutting_down', 'shutdown']
|
and not instance['state_description'] in
|
||||||
|
['shutting_down', 'shutdown']
|
||||||
and instance['project_id'] == project_id):
|
and instance['project_id'] == project_id):
|
||||||
return instance
|
return instance
|
||||||
|
|
||||||
def spawn(self):
|
def spawn(self):
|
||||||
|
"""Run all VPNs."""
|
||||||
for p in reversed(self.manager.get_projects()):
|
for p in reversed(self.manager.get_projects()):
|
||||||
if not self.__vpn_for(p.id):
|
if not self._vpn_for(p.id):
|
||||||
print 'spawning %s' % p.id
|
print 'spawning %s' % p.id
|
||||||
self.pipe.launch_vpn_instance(p.id)
|
self.pipe.launch_vpn_instance(p.id)
|
||||||
time.sleep(10)
|
time.sleep(10)
|
||||||
|
|
||||||
def run(self, project_id):
|
def run(self, project_id):
|
||||||
|
"""Start the VPN for a given project."""
|
||||||
self.pipe.launch_vpn_instance(project_id)
|
self.pipe.launch_vpn_instance(project_id)
|
||||||
|
|
||||||
|
|
||||||
class RoleCommands(object):
|
class RoleCommands(object):
|
||||||
|
"""Class for managing roles."""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.manager = manager.AuthManager()
|
self.manager = manager.AuthManager()
|
||||||
|
|
||||||
@ -107,25 +118,24 @@ class RoleCommands(object):
|
|||||||
arguments: user, role [project]"""
|
arguments: user, role [project]"""
|
||||||
self.manager.remove_role(user, role, project)
|
self.manager.remove_role(user, role, project)
|
||||||
|
|
||||||
|
|
||||||
class UserCommands(object):
|
class UserCommands(object):
|
||||||
|
"""Class for managing users."""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.manager = manager.AuthManager()
|
self.manager = manager.AuthManager()
|
||||||
|
|
||||||
def __print_export(self, user):
|
|
||||||
print 'export EC2_ACCESS_KEY=%s' % user.access
|
|
||||||
print 'export EC2_SECRET_KEY=%s' % user.secret
|
|
||||||
|
|
||||||
def admin(self, name, access=None, secret=None):
|
def admin(self, name, access=None, secret=None):
|
||||||
"""creates a new admin and prints exports
|
"""creates a new admin and prints exports
|
||||||
arguments: name [access] [secret]"""
|
arguments: name [access] [secret]"""
|
||||||
user = self.manager.create_user(name, access, secret, True)
|
user = self.manager.create_user(name, access, secret, True)
|
||||||
self.__print_export(user)
|
print_export(user)
|
||||||
|
|
||||||
def create(self, name, access=None, secret=None):
|
def create(self, name, access=None, secret=None):
|
||||||
"""creates a new user and prints exports
|
"""creates a new user and prints exports
|
||||||
arguments: name [access] [secret]"""
|
arguments: name [access] [secret]"""
|
||||||
user = self.manager.create_user(name, access, secret, False)
|
user = self.manager.create_user(name, access, secret, False)
|
||||||
self.__print_export(user)
|
print_export(user)
|
||||||
|
|
||||||
def delete(self, name):
|
def delete(self, name):
|
||||||
"""deletes an existing user
|
"""deletes an existing user
|
||||||
@ -137,7 +147,7 @@ class UserCommands(object):
|
|||||||
arguments: name"""
|
arguments: name"""
|
||||||
user = self.manager.get_user(name)
|
user = self.manager.get_user(name)
|
||||||
if user:
|
if user:
|
||||||
self.__print_export(user)
|
print_export(user)
|
||||||
else:
|
else:
|
||||||
print "User %s doesn't exist" % name
|
print "User %s doesn't exist" % name
|
||||||
|
|
||||||
@ -147,53 +157,58 @@ class UserCommands(object):
|
|||||||
for user in self.manager.get_users():
|
for user in self.manager.get_users():
|
||||||
print user.name
|
print user.name
|
||||||
|
|
||||||
|
|
||||||
|
def print_export(user):
|
||||||
|
"""Print export variables to use with API."""
|
||||||
|
print 'export EC2_ACCESS_KEY=%s' % user.access
|
||||||
|
print 'export EC2_SECRET_KEY=%s' % user.secret
|
||||||
|
|
||||||
|
|
||||||
class ProjectCommands(object):
|
class ProjectCommands(object):
|
||||||
|
"""Class for managing projects."""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.manager = manager.AuthManager()
|
self.manager = manager.AuthManager()
|
||||||
|
|
||||||
def add(self, project, user):
|
def add(self, project, user):
|
||||||
"""adds user to project
|
"""Adds user to project
|
||||||
arguments: project user"""
|
arguments: project user"""
|
||||||
self.manager.add_to_project(user, project)
|
self.manager.add_to_project(user, project)
|
||||||
|
|
||||||
def create(self, name, project_manager, description=None):
|
def create(self, name, project_manager, description=None):
|
||||||
"""creates a new project
|
"""Creates a new project
|
||||||
arguments: name project_manager [description]"""
|
arguments: name project_manager [description]"""
|
||||||
user = self.manager.create_project(name, project_manager, description)
|
self.manager.create_project(name, project_manager, description)
|
||||||
|
|
||||||
def delete(self, name):
|
def delete(self, name):
|
||||||
"""deletes an existing project
|
"""Deletes an existing project
|
||||||
arguments: name"""
|
arguments: name"""
|
||||||
self.manager.delete_project(name)
|
self.manager.delete_project(name)
|
||||||
|
|
||||||
def environment(self, project_id, user_id, filename='novarc'):
|
def environment(self, project_id, user_id, filename='novarc'):
|
||||||
"""exports environment variables to an sourcable file
|
"""Exports environment variables to an sourcable file
|
||||||
arguments: project_id user_id [filename='novarc]"""
|
arguments: project_id user_id [filename='novarc]"""
|
||||||
rc = self.manager.get_environment_rc(project_id, user_id)
|
rc = self.manager.get_environment_rc(project_id, user_id)
|
||||||
with open(filename, 'w') as f:
|
with open(filename, 'w') as f:
|
||||||
f.write(rc)
|
f.write(rc)
|
||||||
|
|
||||||
def list(self):
|
def list(self):
|
||||||
"""lists all projects
|
"""Lists all projects
|
||||||
arguments: <none>"""
|
arguments: <none>"""
|
||||||
for project in self.manager.get_projects():
|
for project in self.manager.get_projects():
|
||||||
print project.name
|
print project.name
|
||||||
|
|
||||||
def remove(self, project, user):
|
def remove(self, project, user):
|
||||||
"""removes user from project
|
"""Removes user from project
|
||||||
arguments: project user"""
|
arguments: project user"""
|
||||||
self.manager.remove_from_project(user, project)
|
self.manager.remove_from_project(user, project)
|
||||||
|
|
||||||
def zip(self, project_id, user_id, filename='nova.zip'):
|
def create_zip(self, project_id, user_id, filename='nova.zip'):
|
||||||
"""exports credentials for project to a zip file
|
"""Exports credentials for project to a zip file
|
||||||
arguments: project_id user_id [filename='nova.zip]"""
|
arguments: project_id user_id [filename='nova.zip]"""
|
||||||
zip = self.manager.get_credentials(project_id, user_id)
|
zip_file = self.manager.get_credentials(project_id, user_id)
|
||||||
with open(filename, 'w') as f:
|
with open(filename, 'w') as f:
|
||||||
f.write(zip)
|
f.write(zip_file)
|
||||||
|
|
||||||
|
|
||||||
def usage(script_name):
|
|
||||||
print script_name + " category action [<args>]"
|
|
||||||
|
|
||||||
|
|
||||||
categories = [
|
categories = [
|
||||||
@ -205,62 +220,61 @@ categories = [
|
|||||||
|
|
||||||
|
|
||||||
def lazy_match(name, key_value_tuples):
|
def lazy_match(name, key_value_tuples):
|
||||||
"""finds all objects that have a key that case insensitively contains [name]
|
"""Finds all objects that have a key that case insensitively contains
|
||||||
key_value_tuples is a list of tuples of the form (key, value)
|
[name] key_value_tuples is a list of tuples of the form (key, value)
|
||||||
returns a list of tuples of the form (key, value)"""
|
returns a list of tuples of the form (key, value)"""
|
||||||
return [(k, v) for (k, v) in key_value_tuples if k.lower().find(name.lower()) == 0]
|
result = []
|
||||||
|
for (k, v) in key_value_tuples:
|
||||||
|
if k.lower().find(name.lower()) == 0:
|
||||||
|
result.append((k, v))
|
||||||
|
if len(result) == 0:
|
||||||
|
print "%s does not match any options:" % name
|
||||||
|
for k, _v in key_value_tuples:
|
||||||
|
print "\t%s" % k
|
||||||
|
sys.exit(2)
|
||||||
|
if len(result) > 1:
|
||||||
|
print "%s matched multiple options:" % name
|
||||||
|
for k, _v in result:
|
||||||
|
print "\t%s" % k
|
||||||
|
sys.exit(2)
|
||||||
|
return result
|
||||||
|
|
||||||
|
|
||||||
def methods_of(obj):
|
def methods_of(obj):
|
||||||
"""get all callable methods of an object that don't start with underscore
|
"""Get all callable methods of an object that don't start with underscore
|
||||||
returns a list of tuples of the form (method_name, method)"""
|
returns a list of tuples of the form (method_name, method)"""
|
||||||
return [(i, getattr(obj, i)) for i in dir(obj) if callable(getattr(obj, i)) and not i.startswith('_')]
|
result = []
|
||||||
|
for i in dir(obj):
|
||||||
|
if callable(getattr(obj, i)) and not i.startswith('_'):
|
||||||
|
result.append((i, getattr(obj, i)))
|
||||||
|
return result
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
def main():
|
||||||
|
"""Parse options and call the appropriate class/method."""
|
||||||
utils.default_flagfile('/etc/nova/nova-manage.conf')
|
utils.default_flagfile('/etc/nova/nova-manage.conf')
|
||||||
argv = FLAGS(sys.argv)
|
argv = FLAGS(sys.argv)
|
||||||
script_name = argv.pop(0)
|
script_name = argv.pop(0)
|
||||||
if len(argv) < 1:
|
if len(argv) < 1:
|
||||||
usage(script_name)
|
print script_name + " category action [<args>]"
|
||||||
print "Available categories:"
|
print "Available categories:"
|
||||||
for k, v in categories:
|
for k, _ in categories:
|
||||||
print "\t%s" % k
|
print "\t%s" % k
|
||||||
sys.exit(2)
|
sys.exit(2)
|
||||||
category = argv.pop(0)
|
category = argv.pop(0)
|
||||||
matches = lazy_match(category, categories)
|
matches = lazy_match(category, categories)
|
||||||
if len(matches) == 0:
|
|
||||||
print "%s does not match any categories:" % category
|
|
||||||
for k, v in categories:
|
|
||||||
print "\t%s" % k
|
|
||||||
sys.exit(2)
|
|
||||||
if len(matches) > 1:
|
|
||||||
print "%s matched multiple categories:" % category
|
|
||||||
for k, v in matches:
|
|
||||||
print "\t%s" % k
|
|
||||||
sys.exit(2)
|
|
||||||
# instantiate the command group object
|
# instantiate the command group object
|
||||||
category, fn = matches[0]
|
category, fn = matches[0]
|
||||||
command_object = fn()
|
command_object = fn()
|
||||||
actions = methods_of(command_object)
|
actions = methods_of(command_object)
|
||||||
if len(argv) < 1:
|
if len(argv) < 1:
|
||||||
usage(script_name)
|
print script_name + " category action [<args>]"
|
||||||
print "Available actions for %s category:" % category
|
print "Available actions for %s category:" % category
|
||||||
for k, v in actions:
|
for k, _v in actions:
|
||||||
print "\t%s" % k
|
print "\t%s" % k
|
||||||
sys.exit(2)
|
sys.exit(2)
|
||||||
action = argv.pop(0)
|
action = argv.pop(0)
|
||||||
matches = lazy_match(action, actions)
|
matches = lazy_match(action, actions)
|
||||||
if len(matches) == 0:
|
|
||||||
print "%s does not match any actions" % action
|
|
||||||
for k, v in actions:
|
|
||||||
print "\t%s" % k
|
|
||||||
sys.exit(2)
|
|
||||||
if len(matches) > 1:
|
|
||||||
print "%s matched multiple actions:" % action
|
|
||||||
for k, v in matches:
|
|
||||||
print "\t%s" % k
|
|
||||||
sys.exit(2)
|
|
||||||
action, fn = matches[0]
|
action, fn = matches[0]
|
||||||
# call the action with the remaining arguments
|
# call the action with the remaining arguments
|
||||||
try:
|
try:
|
||||||
@ -271,3 +285,5 @@ if __name__ == '__main__':
|
|||||||
print "%s %s: %s" % (category, action, fn.__doc__)
|
print "%s %s: %s" % (category, action, fn.__doc__)
|
||||||
sys.exit(2)
|
sys.exit(2)
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
||||||
|
@ -30,15 +30,9 @@ from nova.objectstore import handler
|
|||||||
FLAGS = flags.FLAGS
|
FLAGS = flags.FLAGS
|
||||||
|
|
||||||
|
|
||||||
def main():
|
|
||||||
app = handler.get_application()
|
|
||||||
print app
|
|
||||||
return app
|
|
||||||
|
|
||||||
# NOTE(soren): Stolen from nova-compute
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
twistd.serve(__file__)
|
twistd.serve(__file__)
|
||||||
|
|
||||||
if __name__ == '__builtin__':
|
if __name__ == '__builtin__':
|
||||||
utils.default_flagfile()
|
utils.default_flagfile()
|
||||||
application = main()
|
application = handler.get_application()
|
||||||
|
3
pylintrc
3
pylintrc
@ -1,3 +1,6 @@
|
|||||||
|
[Messages Control]
|
||||||
|
disable-msg=C0103
|
||||||
|
|
||||||
[Basic]
|
[Basic]
|
||||||
method-rgx=[a-z_][a-z0-9_]{2,50}$
|
method-rgx=[a-z_][a-z0-9_]{2,50}$
|
||||||
|
|
||||||
|
@ -68,7 +68,8 @@ flags.DEFINE_bool('flush_db', True,
|
|||||||
'Flush the database before running fake tests')
|
'Flush the database before running fake tests')
|
||||||
|
|
||||||
flags.DEFINE_string('tests_stderr', 'run_tests.err.log',
|
flags.DEFINE_string('tests_stderr', 'run_tests.err.log',
|
||||||
'Path to where to pipe STDERR during test runs. Default = "run_tests.err.log"')
|
'Path to where to pipe STDERR during test runs. '
|
||||||
|
'Default = "run_tests.err.log"')
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
OptionsClass = twistd.WrapTwistedOptions(trial_script.Options)
|
OptionsClass = twistd.WrapTwistedOptions(trial_script.Options)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user