from sfa.util.faults import *
from sfa.util.xrn import Xrn
+from sfa.planetlab.plxrn import PlXrn
+
verbose=False
class TestXrn(unittest.TestCase):
- hrns=[ # hrn, type, expected_urn
- ('ple.inria.baris','user', "urn:publicid:IDN+ple:inria+user+baris"),
- ('emulab\.net.slice.jktest','slice', "urn:publicid:IDN+emulab.net:slice+slice+jktest"),
- ('plc.princeton.tmack','user', "urn:publicid:IDN+plc:princeton+user+tmack"),
- ('fake-pi1@onelab.eu','user', "urn:publicid:IDN+fake-pi1@onelab+user+eu"),
- # not providing a type is currently not supported
- ('fake-pi1@onelab.eu',None, None),
- ]
-
- urns=[ # urn, expected_hrn, expected_type
- ('urn:publicid:IDN+emulab:net+slice+jktest', "emulab.net.jktest", "slice"),
- ('urn:publicid:IDN+emulab.net+slice+jktest', "emulab\\.net.jktest", "slice"),
- ("urn:publicid:IDN+plc:princeton+user+tmack", "plc.princeton.tmack", "user"),
- ]
-
- def test_hrns(self):
- for (h,t,exp_urn) in TestXrn.hrns:
- print 'testing (',h,t,') expecting',exp_urn
- if exp_urn:
- xrn=Xrn(hrn=h,type=t)
- if verbose: print xrn.dump_string()
- urn=xrn.get_urn()
- (h1,t1) = Xrn(urn=urn).get_hrn()
- if h1!=h or t1!=t or urn!=exp_urn:
- print "hrn->urn->hrn : MISMATCH with in=(%s,%s) -- out=(%s,%s) -- urn=%s"%(h,t,h1,t1,urn)
- self.assertEqual(h1,h)
- self.assertEqual(t1,t)
- self.assertEqual(urn,exp_urn)
- else:
- # could not figure how to use assertFails on object construction..
- # with self.assertRaises(SfaAPIError):
- # Xrn(hrn=h,type=t).get_urn()
- try:
- Xrn(hrn=h,type=t).get_urn()
- failure="Unexpectedly created Xrn object"
- except SfaAPIError:
- failure=False
- except Exception,e:
- failure="Xrn creation raised unexpected exception %r"%e
- if failure:
- print "hrn->urn->hrn - %s with HRN=%s TYPE=%s"%(failure,h,t)
- self.assertFalse(True)
-
-
- def test_urns(self):
- for (urn, exp_hrn, exp_type) in TestXrn.urns:
- xrn=Xrn(urn=urn)
- print 'testing urn',urn,'expecting (',exp_hrn,exp_type,')'
- if verbose: print xrn.dump_string()
- (h,t)=xrn.get_hrn()
- urn1 = Xrn(hrn=h,type=t).get_urn()
- if urn1!=urn:
- print "urn->hrn->urn : MISMATCH with in=(%s) -- out=(%s) -- hrn=(%s,%s)"%(urn,urn1,h,t)
- self.assertEqual(urn1,urn)
+ def __hrn(self,h,t,exp_urn):
+ if verbose: print 'testing (',h,t,') expecting',exp_urn
+ xrn=Xrn(h,type=t)
+ if verbose: print xrn.dump_string()
+ urn=xrn.get_urn()
+ (h1,t1) = Xrn(urn).get_hrn_type()
+ if h1!=h or t1!=t or urn!=exp_urn:
+ print "hrn->urn->hrn : MISMATCH with in=(%s,%s) -- out=(%s,%s) -- urn=%s"%(h,t,h1,t1,urn)
+ self.assertEqual(h1,h)
+ self.assertEqual(t1,t)
+ self.assertEqual(urn,exp_urn)
+
+ def test_hrn001 (self):
+ self.__hrn("ple.inria.baris",'user',
+ "urn:publicid:IDN+ple:inria+user+baris")
+ def test_hnr002 (self):
+ self.__hrn("emulab\.net.myslice.jktest",'slice',
+ "urn:publicid:IDN+emulab.net:myslice+slice+jktest")
+ def test_hrn003(self):
+ self.__hrn("emulab\\.net.jktest", "slice",
+ "urn:publicid:IDN+emulab.net+slice+jktest")
+ def test_hrn004(self):
+ self.__hrn("plc.princeton.tmack",'user',
+ "urn:publicid:IDN+plc:princeton+user+tmack")
+ def test_hrn005(self):
+ self.__hrn("fake-pi1@onelab.eu",'user',
+ "urn:publicid:IDN+fake-pi1@onelab+user+eu")
+ def test_hrn006(self):
+ self.__hrn("plc.princeton.tmack", 'user',
+ "urn:publicid:IDN+plc:princeton+user+tmack" )
+# not specifying a type ... this gives weird result - xxx todo
+# def test_hrn007(self):
+# # not providing a type is currently not supporte
+# self.__hrn("fake-pi1@onelab.eu",None,
+# None)
+ def test_hrn008(self):
+ self.__hrn("plc.princeton.planetlab1", 'node',
+ "urn:publicid:IDN+plc:princeton+node+planetlab1" )
+ def test_hrn009(self):
+ self.__hrn("plc.princeton", 'authority',
+ "urn:publicid:IDN+plc:princeton+authority+sa" )
+ def test_hrn010(self):
+ self.__hrn("plc.vini.site", 'authority',
+ "urn:publicid:IDN+plc:vini:site+authority+sa" )
+
+ # this one is a bit off limits but it's used in some places
+ # like .e.g when running sfi.py resources
+ def test_void(self):
+ void=Xrn(xrn='',type=None)
+ expected='urn:publicid:IDN++'
+ self.assertEqual(void.get_hrn(),'')
+ self.assertEqual(void.get_type(),None)
+ self.assertEqual(void.get_urn(),expected)
+ loop=Xrn(xrn=expected)
+ self.assertEqual(loop.get_hrn(),'')
+ # xxx - this is not quite right as the first object has type None
+ self.assertEqual(loop.get_type(),'')
+
+ def test_host001 (self):
+ xrn=PlXrn (auth="ple.inria",hostname="onelab09.pl.sophia.inria.fr")
+ self.assertEqual (xrn.get_hrn_type(), ("ple.inria.onelab09\\.pl\\.sophia\\.inria\\.fr",'node'))
+ def test_host002 (self):
+ xrn=PlXrn (auth="ple\\.inria",hostname="onelab09.pl.sophia.inria.fr")
+ self.assertEqual (xrn.get_hrn_type(), ("ple\\.inria.onelab09\\.pl\\.sophia\\.inria\\.fr",'node'))
+
+ def test_slice001 (self):
+ xrn=PlXrn (auth="ple",slicename="inria_omftest")
+ self.assertEqual (xrn.get_hrn_type(), ("ple.inria.omftest",'slice'))
+
+ def test_person001 (self):
+ xrn=PlXrn (auth="ple.inria",email="first.last@some.domain.com")
+ self.assertEqual (xrn.get_hrn_type(), ("ple.inria.first_last",'person'))
+ def test_person002 (self):
+ xrn=PlXrn (auth="ple.inria",email="first+last@some.domain.com")
+ self.assertEqual (xrn.get_hrn_type(), ("ple.inria.first_last",'person'))
+
+
+
+ def test_login_base_001 (self):
+ xrn=PlXrn(xrn='ple.inria.omftest',type='slice')
+ self.assertEqual(xrn.pl_login_base(),'inria')
+
+ def test_slicename_001 (self):
+ xrn=PlXrn(xrn='ple.inria.omftest',type='slice')
+ self.assertEqual(xrn.pl_slicename(),'inria_omftest')
+
+ def test_authname_001 (self):
+ xrn=PlXrn(xrn='ple.inria.omftest',type='slice')
+ self.assertEqual(xrn.pl_authname(),'inria')
+
+