[Python-checkins] python/nondist/sandbox/setuptools/setuptools/tests test_resources.py, 1.8, 1.9

pje@users.sourceforge.net pje at users.sourceforge.net
Sun May 22 22:28:49 CEST 2005


Update of /cvsroot/python/python/nondist/sandbox/setuptools/setuptools/tests
In directory sc8-pr-cvs1.sourceforge.net:/tmp/cvs-serv21794/setuptools/tests
Modified Files:
	test_resources.py 
Log Message:
Added support for specifying options on requirements, so that a package's
optional dependencies can be included when processing nested dependencies.
Next up: tests for the resolve() algorithm.
Index: test_resources.py
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/setuptools/setuptools/tests/test_resources.py,v
retrieving revision 1.8
retrieving revision 1.9
diff -u -d -r1.8 -r1.9
--- test_resources.py	22 May 2005 19:40:22 -0000	1.8
+++ test_resources.py	22 May 2005 20:28:47 -0000	1.9
@@ -1,6 +1,7 @@
 from unittest import TestCase, makeSuite
 from pkg_resources import *
 import pkg_resources, sys
+from sets import ImmutableSet
 
 class Metadata:
 """Mock object to return metadata as if from an on-disk distribution"""
@@ -18,7 +19,6 @@
 return yield_lines(self.get_metadata(name))
 
 
-
 class DistroTests(TestCase):
 
 def testCollection(self):
@@ -167,12 +167,13 @@
 def testBasics(self):
 r = Requirement.parse("Twisted>=1.2")
 self.assertEqual(str(r),"Twisted>=1.2")
- self.assertEqual(repr(r),"Requirement('Twisted', [('>=', '1.2')])")
+ self.assertEqual(repr(r),"Requirement('Twisted', [('>=', '1.2')], ())")
 self.assertEqual(r, Requirement("Twisted", [('>=','1.2')]))
 self.assertEqual(r, Requirement("twisTed", [('>=','1.2')]))
 self.assertNotEqual(r, Requirement("Twisted", [('>=','2.0')]))
 self.assertNotEqual(r, Requirement("Zope", [('>=','1.2')]))
 self.assertNotEqual(r, Requirement("Zope", [('>=','3.0')]))
+ self.assertNotEqual(r, Requirement.parse("Twisted[extras]>=1.2"))
 
 def testOrdering(self):
 r1 = Requirement("Twisted", [('==','1.2c1'),('>=','1.2')])
@@ -202,6 +203,46 @@
 self.failUnless(v not in r, (v,r))
 
 
+ def testOptionsAndHashing(self):
+ r1 = Requirement.parse("Twisted[foo,bar]>=1.2")
+ r2 = Requirement.parse("Twisted[bar,FOO]>=1.2")
+ r3 = Requirement.parse("Twisted[BAR,FOO]>=1.2.0")
+ self.assertEqual(r1,r2)
+ self.assertEqual(r1,r3)
+ self.assertEqual(r1.options, ("foo","bar"))
+ self.assertEqual(r2.options, ("bar","FOO"))
+ self.assertEqual(hash(r1), hash(r2))
+ self.assertEqual(
+ hash(r1), hash(("twisted", ((">=",parse_version("1.2")),),
+ ImmutableSet(["foo","bar"])))
+ )
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
 
 class ParseTests(TestCase):
 
@@ -233,7 +274,7 @@
 """
 )
 ),
- [(None,["x"]), ("y",["z","a"]), ("b",["c"]), ("q",["v"])]
+ [(None,["x"]), ("y",["z","a"]), ("b",["c"]), ("d",[]), ("q",["v"])]
 )
 self.assertRaises(ValueError,list,pkg_resources.split_sections("[foo"))
 


More information about the Python-checkins mailing list

AltStyle によって変換されたページ (->オリジナル) /