[RARSLAVE] Add extraction class
[rarslave2.git] / rarslave-test.py
index c57075a..d8336b1 100644 (file)
@@ -5,6 +5,19 @@ import os, sys, unittest
 from rarslave import *
 
 class rarslavetest (unittest.TestCase):
+
+       def assertListEquals (self, l1, l2):
+               if l1 is l2:
+                       return True
+
+               self.assertEquals (len(l1), len(l2))
+
+               for e in l1:
+                       if e not in l2:
+                               self.fail ("Element missing from list")
+
+               return True
+
        def setUp (self):
                pass
 
@@ -38,7 +51,7 @@ class rarslavetest (unittest.TestCase):
 
        def testFindLikelyFilesBadDir (self):
                DIR = '/fake/dir'
-               
+
                self.assertRaises (ValueError, find_likely_files, "fake", DIR)
 
        def testFindAllPar2Files (self):
@@ -62,6 +75,22 @@ class rarslavetest (unittest.TestCase):
                self.assertFalse (has_extension (FILE, '.part01'))
                self.assertFalse (has_extension (FILE, 'part01'))
 
+       def testIsNewRar (self):
+               DIR = os.getcwd() + '/test_material/01/'
+
+               self.assertTrue (is_newrar (os.listdir (DIR)))
+
+       def testDeletableFiles1 (self):
+               FILES = ['test.part%d.rar' % n for n in xrange(10)]
+
+               self.assertListEquals (find_deleteable_files (FILES), FILES)
+
+       def testDeletableFiles2 (self):
+               FILESN = ['%d.mp3' % n for n in xrange(20)]
+               FILESY = ['%d.zip' % n for n in xrange(5)]
+
+               self.assertListEquals (find_deleteable_files (FILESN + FILESY), FILESY)
+
 
 if __name__ == '__main__':
        unittest.main ()