mirror of
https://github.com/kevingruesser/bootstrap-vz.git
synced 2025-08-24 15:36:27 +00:00

Up until now I didn't see the point of using spaces for indentation. However, the previous commit (a18bec3) was quite eye opening. Given that python is an indentation aware language, the amount of mistakes that went unnoticed because tabs and spaces were used at the same time (tabs for indentation and spaces for alignment) were unacceptable. E101,W191 have been re-enable in the tox flake8 checker and the documentation has been modified accordingly. The following files have been left as-is: * bootstrapvz/common/assets/extlinux/extlinux.conf * bootstrapvz/common/assets/init.d/expand-root * bootstrapvz/common/assets/init.d/generate-ssh-hostkeys * bootstrapvz/common/assets/init.d/squeeze/generate-ssh-hostkeys * bootstrapvz/plugins/docker_daemon/assets/init.d/docker * bootstrapvz/providers/ec2/assets/bin/growpart * bootstrapvz/providers/ec2/assets/grub.d/40_custom * bootstrapvz/providers/ec2/assets/init.d/ec2-get-credentials * bootstrapvz/providers/ec2/assets/init.d/ec2-run-user-data * docs/_static/taskoverview.coffee * docs/_static/taskoverview.less * tests/unit/subprocess.sh
46 lines
1.5 KiB
Python
46 lines
1.5 KiB
Python
|
|
|
|
def pick_build_server(build_servers, manifest, preferences={}):
|
|
# Validate the build servers list
|
|
from bootstrapvz.common.tools import load_data
|
|
import os.path
|
|
schema = load_data(os.path.normpath(os.path.join(os.path.dirname(__file__), 'build-servers-schema.yml')))
|
|
import jsonschema
|
|
jsonschema.validate(build_servers, schema)
|
|
|
|
if manifest['provider']['name'] == 'ec2':
|
|
must_bootstrap = 'ec2-' + manifest['volume']['backing']
|
|
else:
|
|
must_bootstrap = manifest['provider']['name']
|
|
|
|
def matches(name, settings):
|
|
if preferences.get('name', name) != name:
|
|
return False
|
|
if preferences.get('release', settings['release']) != settings['release']:
|
|
return False
|
|
if must_bootstrap not in settings['can_bootstrap']:
|
|
return False
|
|
return True
|
|
|
|
for name, settings in build_servers.iteritems():
|
|
if not matches(name, settings):
|
|
continue
|
|
if settings['type'] == 'local':
|
|
from local import LocalBuildServer
|
|
return LocalBuildServer(name, settings)
|
|
else:
|
|
from remote import RemoteBuildServer
|
|
return RemoteBuildServer(name, settings)
|
|
raise Exception('Unable to find a build server that matches your preferences.')
|
|
|
|
|
|
def getNPorts(n, port_range=(1024, 65535)):
|
|
import random
|
|
ports = []
|
|
for i in range(0, n):
|
|
while True:
|
|
port = random.randrange(*port_range)
|
|
if port not in ports:
|
|
ports.append(port)
|
|
break
|
|
return ports
|