# Mark Huang <mlhuang@cs.princeton.edu>
# Copyright (C) 2006 The Trustees of Princeton University
#
-# $Id: Test.py,v 1.1 2006/09/08 00:29:56 mlhuang Exp $
+# $Id: Test.py,v 1.9 2006/10/11 15:46:09 mlhuang Exp $
#
from pprint import pprint
from string import letters, digits, punctuation
+import re
+import socket
+import struct
from random import Random
random = Random()
-import re
-
def randfloat(min = 0.0, max = 1.0):
return float(min) + (random.random() * (float(max) - float(min)))
site_ids.append(site_id)
print "=>", site_id
+ # Check site
print "AdmGetSites(%d)" % site_id,
site = AdmGetSites(admin, [site_id])[0]
for key in 'name', 'abbreviated_name', 'login_base', 'latitude', 'longitude', 'site_id':
assert unicmp(site[key], locals()[key])
print "=> OK"
+ # Update site
+ name = randstr(254)
+ abbreviated_name = randstr(50)
+ latitude = int(randfloat(-90.0, 90.0) * 1000) / 1000.0
+ longitude = int(randfloat(-180.0, 180.0) * 1000) / 1000.0
+ max_slices = 10
+ print "AdmUpdateSite(%s)" % login_base,
+ AdmUpdateSite(admin, site_id, {'name': name, 'abbreviated_name': abbreviated_name,
+ 'latitude': latitude, 'longitude': longitude,
+ 'max_slices': max_slices})
+ site = AdmGetSites(admin, [site_id])[0]
+ for key in 'name', 'abbreviated_name', 'latitude', 'longitude', 'max_slices':
+ assert unicmp(site[key], locals()[key])
+ print "=> OK"
+
print "AdmGetSites",
sites = AdmGetSites(admin, site_ids)
assert set(site_ids) == set([site['site_id'] for site in sites])
for auth in user, pi, tech:
first_name = randstr(128)
last_name = randstr(128)
- email = randstr(119, letters + digits) + "@" + randhostname()
+ # 119 + 1 + 64 + 64 + 6 = 254
+ email = (randstr(119, letters + digits) + "@" + randhostname()).lower()
bio = randstr(254)
# Accounts are disabled by default
enabled = False
# Check account
print "AdmGetPersons(%d)" % person_id,
person = AdmGetPersons(admin, [person_id])[0]
- for key in 'first_name', 'last_name', 'bio', 'person_id', 'enabled':
+ for key in 'first_name', 'last_name', 'email', 'bio', 'person_id', 'enabled':
+ assert unicmp(person[key], locals()[key])
+ print "=> OK"
+
+ # Update account
+ first_name = randstr(128)
+ last_name = randstr(128)
+ bio = randstr(254)
+ print "AdmUpdatePerson(%d)" % person_id,
+ AdmUpdatePerson(admin, person_id, {'first_name': first_name,
+ 'last_name': last_name,
+ 'bio': bio})
+ person = AdmGetPersons(admin, [person_id])[0]
+ for key in 'first_name', 'last_name', 'email', 'bio':
assert unicmp(person[key], locals()[key])
print "=> OK"
AdmAddPersonToSite(admin, person_id, site_id)
print "=> OK"
+ print "AdmGetSitePersons(%d)" % site_id,
+ site_person_ids = AdmGetSitePersons(admin, site_id)
+ assert person_id in site_person_ids
+ print "=>", site_person_ids
+
# Make sure it really did it
print "AdmGetPersonSites(%d)" % person_id,
person_site_ids = AdmGetPersonSites(auth, person_id)
assert person['site_ids'][0] == person_site_ids[1]
print "=> OK"
+ # Check authentication
+ print "AdmAuthCheck(%s)" % auth['Username'],
+ assert AdmAuthCheck(auth)
+ print "=> OK"
+
print "AdmGetPersons",
persons = AdmGetPersons(admin, person_ids)
assert set(person_ids) == set([person['person_id'] for person in persons])
print "=>", person_ids
+# Verify PI role
+for person in persons:
+ if 'pi' in person['roles']:
+ assert AdmIsPersonInRole(admin, pi['Username'], roles['pi'])
+
+# Add node groups
+nodegroup_ids = []
+for i in range(3):
+ name = randstr(50)
+ description = randstr(200)
+ print "AdmAddNodeGroup",
+ nodegroup_id = AdmAddNodeGroup(admin, name, description)
+
+ # Should return a unique nodegroup_id
+ assert nodegroup_id not in nodegroup_ids
+ nodegroup_ids.append(nodegroup_id)
+ print "=>", nodegroup_id
+
+ # Check nodegroup
+ print "AdmGetNodeGroups(%d)" % nodegroup_id,
+ nodegroup = AdmGetNodeGroups(admin, [nodegroup_id])[0]
+ for key in 'name', 'description', 'nodegroup_id':
+ assert unicmp(nodegroup[key], locals()[key])
+ print "=> OK"
+
+ # Update node group
+ name = randstr(50)
+ description = randstr(200)
+ print "AdmUpdateNodeGroup",
+ AdmUpdateNodeGroup(admin, nodegroup_id, name, description)
+ nodegroup = AdmGetNodeGroups(admin, [nodegroup_id])[0]
+ for key in 'name', 'description', 'nodegroup_id':
+ assert unicmp(nodegroup[key], locals()[key])
+ print "=> OK"
+
+print "AdmGetNodeGroups",
+nodegroups = AdmGetNodeGroups(admin, nodegroup_ids)
+assert set(nodegroup_ids) == set([nodegroup['nodegroup_id'] for nodegroup in nodegroups])
+print "=>", nodegroup_ids
+
# Add nodes
node_ids = []
for site_id in site_ids:
assert unicmp(node[key], locals()[key])
print "=> OK"
- # XXX AdmGetSiteNodes
+ # Update node
+ hostname = randhostname()
+ model = randstr(255)
+ print "AdmUpdateNode(%s)" % hostname,
+ AdmUpdateNode(admin, node_id, {'hostname': hostname, 'model': model})
+ node = AdmGetNodes(admin, [node_id])[0]
+ for key in 'hostname', 'boot_state', 'model', 'node_id':
+ assert unicmp(node[key], locals()[key])
+ print "=> OK"
+
+ # Add to node groups
+ for nodegroup_id in nodegroup_ids:
+ print "AdmAddNodeToNodeGroup(%d, %d)" % (nodegroup_id, node_id),
+ AdmAddNodeToNodeGroup(admin, nodegroup_id, node_id)
+ print "=> OK"
print "AdmGetNodes",
nodes = AdmGetNodes(admin, node_ids)
assert set(node_ids) == set([node['node_id'] for node in nodes])
print "=>", node_ids
+print "AdmGetSiteNodes" % site_ids,
+site_node_ids = AdmGetSiteNodes(admin, site_ids)
+assert set(node_ids) == set(reduce(lambda a, b: a + b, site_node_ids.values()))
+print "=>", site_node_ids
+
+for nodegroup_id in nodegroup_ids:
+ print "AdmGetNodeGroupNodes(%d)" % nodegroup_id,
+ nodegroup_node_ids = AdmGetNodeGroupNodes(admin, nodegroup_id)
+ assert set(nodegroup_node_ids) == set(node_ids)
+ print "=>", nodegroup_node_ids
+
+# Add node networks
+nodenetwork_ids = []
+for node_id in node_ids:
+ ip = randint(0, 0xffffffff)
+ netmask = (0xffffffff << randint(2, 31)) & 0xffffffff
+ network = ip & netmask
+ broadcast = ((ip & netmask) | ~netmask) & 0xffffffff
+ gateway = randint(network + 1, broadcast - 1)
+ dns1 = randint(0, 0xffffffff)
+
+ for method in 'static', 'dhcp':
+ optional = {}
+ if method == 'static':
+ for key in 'ip', 'netmask', 'network', 'broadcast', 'gateway', 'dns1':
+ optional[key] = socket.inet_ntoa(struct.pack('>L', locals()[key]))
+
+ print "AdmAddNodeNetwork(%s)" % method,
+ nodenetwork_id = AdmAddNodeNetwork(admin, node_id, method, 'ipv4', optional)
+
+ # Should return a unique nodenetwork_id
+ assert nodenetwork_id not in nodenetwork_ids
+ nodenetwork_ids.append(nodenetwork_id)
+ print "=>", nodenetwork_id
+
+ # Check node networks
+ print "AdmGetAllNodeNetworks(%d)" % node_id,
+ nodenetworks = AdmGetAllNodeNetworks(admin, node_id)
+ for nodenetwork in nodenetworks:
+ if nodenetwork['method'] == 'static':
+ for key in 'ip', 'netmask', 'network', 'broadcast', 'gateway', 'dns1':
+ address = struct.unpack('>L', socket.inet_aton(nodenetwork[key]))[0]
+ assert address == locals()[key]
+ print "=>", [nodenetwork['nodenetwork_id'] for nodenetwork in nodenetworks]
+
+# Update node networks
+for node_id in node_ids:
+ ip = randint(0, 0xffffffff)
+ netmask = (0xffffffff << randint(2, 31)) & 0xffffffff
+ network = ip & netmask
+ broadcast = ((ip & netmask) | ~netmask) & 0xffffffff
+ gateway = randint(network + 1, broadcast - 1)
+ dns1 = randint(0, 0xffffffff)
+
+ nodenetworks = AdmGetAllNodeNetworks(admin, node_id)
+ for nodenetwork in nodenetworks:
+ # Update node network
+ optional = {}
+ if nodenetwork['method'] == 'static':
+ for key in 'ip', 'netmask', 'network', 'broadcast', 'gateway', 'dns1':
+ optional[key] = socket.inet_ntoa(struct.pack('>L', locals()[key]))
+
+ print "AdmUpdateNodeNetwork(%s)" % nodenetwork['method'],
+ AdmUpdateNodeNetwork(admin, nodenetwork['nodenetwork_id'], optional)
+ print "=> OK"
+
+ # Check node network again
+ print "AdmGetAllNodeNetworks(%d)" % node_id,
+ nodenetworks = AdmGetAllNodeNetworks(admin, node_id)
+ for nodenetwork in nodenetworks:
+ if nodenetwork['method'] == 'static':
+ for key in 'ip', 'netmask', 'network', 'broadcast', 'gateway', 'dns1':
+ address = struct.unpack('>L', socket.inet_aton(nodenetwork[key]))[0]
+ assert address == locals()[key]
+ print "=>", [nodenetwork['nodenetwork_id'] for nodenetwork in nodenetworks]
+
+# Add node attribute types
+attribute_type_ids = []
+for i in range(3):
+ name = randstr(100)
+ description = randstr(254)
+ min_role_id = random.sample(roles.values(), 1)[0]
+
+ # Add slice attribute type
+ print "AddSliceAttributeType",
+ attribute_type_id = AddSliceAttributeType(admin, name,
+ {'description': description,
+ 'min_role_id': min_role_id})
+
+ # Should return a unique attribute_type_id
+ assert attribute_type_id not in attribute_type_ids
+ attribute_type_ids.append(attribute_type_id)
+ print "=>", attribute_type_id
+
+ # Check slice attribute type
+ print "GetSliceAttributeTypes(%d)" % attribute_type_id,
+ attribute_type = GetSliceAttributeTypes(admin, [attribute_type_id])[0]
+ for key in 'min_role_id', 'description':
+ assert unicmp(attribute_type[key], locals()[key])
+ print "=> OK"
+
+ # Update slice attribute type
+ description = randstr(254)
+ min_role_id = random.sample(roles.values(), 1)[0]
+ print "UpdateSliceAttributeType(%d)" % attribute_type_id,
+ UpdateSliceAttributeType(admin, attribute_type_id,
+ {'description': description,
+ 'min_role_id': min_role_id})
+ attribute_type = GetSliceAttributeTypes(admin, [attribute_type_id])[0]
+ for key in 'min_role_id', 'description':
+ assert unicmp(attribute_type[key], locals()[key])
+ print "=> OK"
+
+# Add slices and slice attributes
+slice_ids = []
+slice_attribute_ids = []
+sites = AdmGetSites(admin, site_ids)
+for site in sites:
+ for i in range(10):
+ name = site['login_base'] + "_" + randstr(11, letters).lower()
+ url = "http://" + randhostname() + "/"
+ description = randstr(2048)
+
+ # Add slice
+ print "AddSlice(%s)" % name,
+ slice_id = AddSlice(admin, name, {'url': url, 'description': description})
+
+ # Should return a unique slice_id
+ assert slice_id not in slice_ids
+ slice_ids.append(slice_id)
+ print "=>", slice_id
+
+ # Check slice
+ print "GetSlices(%d)" % slice_id,
+ slice = GetSlices(admin, [slice_id])[0]
+ for key in 'name', 'url', 'description', 'slice_id':
+ assert unicmp(slice[key], locals()[key])
+ print "=> OK"
+
+ # Update slice
+ url = "http://" + randhostname() + "/"
+ description = randstr(2048)
+ print "UpdateSlice(%s)" % name,
+ UpdateSlice(admin, slice_id, {'url': url, 'description': description})
+ slice = GetSlices(admin, [slice_id])[0]
+ for key in 'name', 'url', 'description', 'slice_id':
+ assert unicmp(slice[key], locals()[key])
+ print "=> OK"
+
+ # XXX Add nodes to slice
+
+ # XXX Add people to slice
+
+ # Set slice/sliver attributes
+ for attribute_type_id in attribute_type_ids:
+ value = randstr(254)
+ # Make it a sliver attribute with 50% probability
+ # node_id = random.sample(node_ids + [None] * len(node_ids), 1)[0]
+ node_id = None
+
+ # Add slice attribute
+ print "AddSliceAttribute(%s, %d)" % (name, attribute_type_id),
+ if node_id is None:
+ slice_attribute_id = AddSliceAttribute(admin, slice_id, attribute_type_id, value)
+ else:
+ slice_attribute_id = AddSliceAttribute(admin, slice_id, attribute_type_id, value, node_id)
+
+ # Should return a unique slice_attribute_id
+ assert slice_attribute_id not in slice_attribute_ids
+ slice_attribute_ids.append(slice_attribute_id)
+ print "=>", slice_attribute_id
+
+ # Check slice attribute
+ print "GetSliceAttributes(%d)" % slice_attribute_id,
+ slice_attribute = GetSliceAttributes(admin, [slice_attribute_id])[0]
+ for key in 'attribute_type_id', 'slice_id', 'node_id', 'slice_attribute_id', 'value':
+ assert unicmp(slice_attribute[key], locals()[key])
+ print "=> OK"
+
+ # Update slice attribute
+ url = "http://" + randhostname() + "/"
+ description = randstr(2048)
+ print "UpdateSliceAttribute(%s)" % name,
+ UpdateSliceAttribute(admin, slice_attribute_id, value)
+ slice_attribute = GetSliceAttributes(admin, [slice_attribute_id])[0]
+ for key in 'attribute_type_id', 'slice_id', 'node_id', 'slice_attribute_id', 'value':
+ assert unicmp(slice_attribute[key], locals()[key])
+ print "=> OK"
+
+# Delete slices
+for slice_id in slice_ids:
+ # Delete slice attributes
+ slice = GetSlices(admin, [slice_id])[0]
+ for slice_attribute_id in slice['slice_attribute_ids']:
+ print "DeleteSliceAttribute(%s, %d)" % (slice['name'], slice_attribute_id),
+ DeleteSliceAttribute(admin, slice_attribute_id)
+ print "=> OK"
+ slice = GetSlices(admin, [slice_id])[0]
+ assert not slice['slice_attribute_ids']
+
+ # Delete slice
+ print "DeleteSlice(%d)" % slice_id,
+ DeleteSlice(admin, slice_id)
+ assert not GetSlices(admin, [slice_id])
+
+ # Make sure it really deleted it
+ slices = GetSlices(admin, slice_ids)
+ assert slice_id not in [slice['slice_id'] for slice in slices]
+ print "=> OK"
+
+print "GetSlices",
+assert not GetSlices(admin, slice_ids)
+print "=> []"
+
+# Delete slice attribute types
+for attribute_type_id in attribute_type_ids:
+ # Delete attribute
+ print "DeleteAttribute(%d)" % attribute_type_id,
+ DeleteSliceAttributeType(admin, attribute_type_id)
+ assert not GetSliceAttributeTypes(admin, [attribute_type_id])
+
+ # Make sure it really deleted it
+ attribute_types = GetSliceAttributeTypes(admin, attribute_type_ids)
+ assert attribute_type_id not in [attribute_type['attribute_type_id'] for attribute_type in attribute_types]
+ print "=> OK"
+
+print "GetAttributes",
+assert not GetSliceAttributeTypes(admin, attribute_type_ids)
+print "=> []"
+
+# Delete node networks
+for node_id in node_ids:
+ nodenetworks = AdmGetAllNodeNetworks(admin, node_id)
+ for nodenetwork in nodenetworks:
+ # Delete node network
+ print "AdmDeleteNodeNetwork(%d, %d)" % (node_id, nodenetwork['nodenetwork_id']),
+ AdmDeleteNodeNetwork(admin, node_id, nodenetwork['nodenetwork_id'])
+ print "=>", "OK"
+ assert not AdmGetAllNodeNetworks(admin, node_id)
+
# Delete nodes
for node_id in node_ids:
+ # Remove from node groups
+ for nodegroup_id in nodegroup_ids:
+ print "AdmRemoveNodeFromNodeGroup(%d, %d)" % (nodegroup_id, node_id),
+ AdmRemoveNodeFromNodeGroup(admin, nodegroup_id, node_id)
+ # Make sure it really deleted it
+ assert node_id not in AdmGetNodeGroupNodes(nodegroup_id)
+ print "=> OK"
+
+ # Delete node
print "AdmDeleteNode(%d)" % node_id,
AdmDeleteNode(admin, node_id)
assert not AdmGetNodes(admin, [node_id])
assert not AdmGetNodes(admin, node_ids)
print "=> []"
+for nodegroup_id in nodegroup_ids:
+ print "AdmGetNodeGroupNodes(%d)" % nodegroup_id,
+ assert not AdmGetNodeGroupNodes(nodegroup_id)
+ print "=> []"
+
# Delete users
for person_id in person_ids:
# Remove from each site
assert not AdmGetPersons(admin, person_ids)
print "=> []"
+# Delete node groups
+for nodegroup_id in nodegroup_ids:
+ print "AdmDeleteNodeGroup(%d)" % nodegroup_id,
+ AdmDeleteNodeGroup(admin, nodegroup_id)
+ assert not AdmGetNodeGroups(admin, [nodegroup_id])
+ print "=> OK"
+
+print "AdmGetNodeGroups",
+assert not AdmGetNodeGroups(admin, nodegroup_ids)
+print "=> []"
+
# Delete sites
for site_id in site_ids:
print "AdmDeleteSite(%d)" % site_id,