X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=tests%2Fdbtest_debversion.py;h=c45200d1f2440d7a3e96f43d5ad57de561d5f45a;hb=7c5adcf962fe99d6a42307595f263f47d0112fbc;hp=548a2e8ea5c97c626aca4f999dab16599a17fe90;hpb=35d077b255152cadca13de999048a044207a30d6;p=dak.git diff --git a/tests/dbtest_debversion.py b/tests/dbtest_debversion.py index 548a2e8e..c45200d1 100755 --- a/tests/dbtest_debversion.py +++ b/tests/dbtest_debversion.py @@ -16,6 +16,13 @@ class Version(object): return "" % self.version class DebVersionTestCase(DBDakTestCase): + """ + The DebVersionTestCase tests both comparison (<=, ==, >, !=), the in_() + method and aggregate functions (min, max) for the DebVersion type. To + simplify the test it creates a separate table 'version' which is not used + by dak itself. + """ + def setUp(self): super(DebVersionTestCase, self).setUp() self.version_table = Table('version', self.metadata, \ @@ -32,19 +39,22 @@ class DebVersionTestCase(DBDakTestCase): self.session.add(v) v = Version('1.0') self.session.add(v) - #self.session.commit() q = self.session.query(Version) self.assertEqual(3, q.count()) + self.assertEqual(2, q.filter(Version.version <= '0.5').count()) + self.assertEqual(1, q.filter(Version.version == '0.5').count()) self.assertEqual(2, q.filter(Version.version > '0.5~').count()) self.assertEqual(1, q.filter(Version.version > '0.5').count()) self.assertEqual(0, q.filter(Version.version > '1.0').count()) + self.assertEqual(2, q.filter(Version.version != '1.0').count()) + self.assertEqual(2, q.filter(Version.version.in_(['0.5~', '1.0'])).count()) q = self.session.query(func.min(Version.version)) - self.assertEqual('0.5~', q.one()[0]) + self.assertEqual('0.5~', q.scalar()) q = self.session.query(func.max(Version.version)) - self.assertEqual('1.0', q.one()[0]) + self.assertEqual('1.0', q.scalar()) def tearDown(self): - self.session.close() + self.session.rollback() self.version_table.drop() super(DebVersionTestCase, self).tearDown()