# Mark Huang <mlhuang@cs.princeton.edu>
# Copyright (C) 2006 The Trustees of Princeton University
#
-# $Id: Test.py,v 1.5 2006/09/14 15:47:27 tmack Exp $
+# $Id: Test.py,v 1.8 2006/10/03 19:33:16 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])
first_name = randstr(128)
last_name = randstr(128)
# 119 + 1 + 64 + 64 + 6 = 254
- email = randstr(119, letters + digits) + "@" + randhostname()
+ 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(%s)" % name,
+ print "AdmAddNodeGroup",
nodegroup_id = AdmAddNodeGroup(admin, name, description)
# Should return a unique nodegroup_id
# Update node group
name = randstr(50)
description = randstr(200)
- print "AdmUpdateNodeGroup(%s)" % name,
+ print "AdmUpdateNodeGroup",
AdmUpdateNodeGroup(admin, nodegroup_id, name, description)
nodegroup = AdmGetNodeGroups(admin, [nodegroup_id])[0]
for key in 'name', 'description', 'nodegroup_id':
assert set(nodegroup_node_ids) == set(node_ids)
print "=>", nodegroup_node_ids
+print "AdmGetAllNodeNetworkBandwidthLimits",
+bwlimits = AdmGetAllNodeNetworkBandwidthLimits(admin)
+print "=>", bwlimits
+
+# 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 attribute types
+attribute_ids = []
+for i in range(3):
+ name = randstr(100)
+ description = randstr(254)
+ min_role_id = random.sample(roles.values(), 1)[0]
+
+ # Add attribute
+ print "AddAttribute",
+ attribute_id = AddAttribute(admin, name,
+ {'description': description,
+ 'min_role_id': min_role_id})
+
+ # Should return a unique attribute_id
+ assert attribute_id not in attribute_ids
+ attribute_ids.append(attribute_id)
+ print "=>", attribute_id
+
+ # Check attribute
+ print "GetAttributes(%d)" % attribute_id,
+ attribute = GetAttributes(admin, [attribute_id])[0]
+ for key in 'min_role_id', 'description':
+ assert unicmp(attribute[key], locals()[key])
+ print "=> OK"
+
+ # Update attribute
+ description = randstr(254)
+ min_role_id = random.sample(roles.values(), 1)[0]
+ print "UpdateAttribute(%d)" % attribute_id,
+ UpdateAttribute(admin, attribute_id,
+ {'description': description,
+ 'min_role_id': min_role_id})
+ attribute = GetAttributes(admin, [attribute_id])[0]
+ for key in 'min_role_id', 'description':
+ assert unicmp(attribute[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_id in attribute_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_id),
+ if node_id is None:
+ slice_attribute_id = AddSliceAttribute(admin, slice_id, attribute_id, value)
+ else:
+ slice_attribute_id = AddSliceAttribute(admin, slice_id, attribute_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_id, [slice_attribute_id])[0]
+ for key in 'attribute_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_id, [slice_attribute_id])[0]
+ for key in 'attribute_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 attributes
+for attribute_id in attribute_ids:
+ # Delete attribute
+ print "DeleteAttribute(%d)" % attribute_id,
+ DeleteAttribute(admin, attribute_id)
+ assert not GetAttributes(admin, [attribute_id])
+
+ # Make sure it really deleted it
+ attributes = GetAttributes(admin, attribute_ids)
+ assert attribute_id not in [attribute['attribute_id'] for attribute in attributes]
+ print "=> OK"
+
+print "GetAttributes",
+assert not GetAttributes(admin, attribute_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
print "AdmGetSites",
assert not AdmGetSites(admin, site_ids)
print "=> []"
-