# -*- Mode: Python; test-case-name: morituri.test.test_image_image -*- # vi:si:et:sw=4:sts=4:ts=4 import os import tempfile import gobject gobject.threads_init() import gst from morituri.image import image from morituri.common import common, log from morituri.extern.task import task, gstreamer from morituri.test import common as tcommon log.init() def h(i): return "0x%08x" % i class TrackSingleTestCase(tcommon.TestCase): def setUp(self): self.image = image.Image(os.path.join(os.path.dirname(__file__), u'track-single.cue')) self.runner = task.SyncRunner(verbose=False) self.image.setup(self.runner) def testAccurateRipChecksum(self): checksumtask = image.AccurateRipChecksumTask(self.image) self.runner.run(checksumtask, verbose=False) self.assertEquals(len(checksumtask.checksums), 4) self.assertEquals(h(checksumtask.checksums[0]), '0x00000000') self.assertEquals(h(checksumtask.checksums[1]), '0x793fa868') self.assertEquals(h(checksumtask.checksums[2]), '0x8dd37c26') self.assertEquals(h(checksumtask.checksums[3]), '0x00000000') def testLength(self): self.assertEquals(self.image.table.getTrackLength(1), 2) self.assertEquals(self.image.table.getTrackLength(2), 2) self.assertEquals(self.image.table.getTrackLength(3), 2) self.assertEquals(self.image.table.getTrackLength(4), 4) def testCDDB(self): self.assertEquals(self.image.table.getCDDBDiscId(), "08000004") def testAccurateRip(self): self.assertEquals(self.image.table.getAccurateRipIds(), ( "00000016", "0000005b")) class TrackSeparateTestCase(tcommon.TestCase): def setUp(self): self.image = image.Image(os.path.join(os.path.dirname(__file__), u'track-separate.cue')) self.runner = task.SyncRunner(verbose=False) self.image.setup(self.runner) def testAccurateRipChecksum(self): checksumtask = image.AccurateRipChecksumTask(self.image) self.runner.run(checksumtask, verbose=False) self.assertEquals(len(checksumtask.checksums), 4) self.assertEquals(h(checksumtask.checksums[0]), '0xd60e55e1') self.assertEquals(h(checksumtask.checksums[1]), '0xd63dc2d2') self.assertEquals(h(checksumtask.checksums[2]), '0xd63dc2d2') self.assertEquals(h(checksumtask.checksums[3]), '0x7271db39') def testLength(self): self.assertEquals(self.image.table.getTrackLength(1), 10) self.assertEquals(self.image.table.getTrackLength(2), 10) self.assertEquals(self.image.table.getTrackLength(3), 10) self.assertEquals(self.image.table.getTrackLength(4), 10) def testCDDB(self): self.assertEquals(self.image.table.getCDDBDiscId(), "08000004") def testAccurateRip(self): self.assertEquals(self.image.table.getAccurateRipIds(), ( "00000064", "00000191")) class AudioLengthTestCase(tcommon.TestCase): def testLength(self): path = os.path.join(os.path.dirname(__file__), u'track.flac') t = image.AudioLengthTask(path) runner = task.SyncRunner() runner.run(t, verbose=False) self.assertEquals(t.length, 10 * common.SAMPLES_PER_FRAME) class AudioLengthPathTestCase(tcommon.TestCase): def _testSuffix(self, suffix): self.runner = task.SyncRunner(verbose=False) fd, path = tempfile.mkstemp(suffix=suffix) t = image.AudioLengthTask(path) e = self.assertRaises(task.TaskException, self.runner.run, t, verbose=False) self.failUnless(isinstance(e.exception, gstreamer.GstException), "%r is not a gstreamer.GstException" % e.exceptionMessage) self.assertEquals(e.exception.gerror.domain, gst.STREAM_ERROR) # our empty file triggers TYPE_NOT_FOUND self.assertEquals(e.exception.gerror.code, gst.STREAM_ERROR_TYPE_NOT_FOUND) os.unlink(path) class NormalAudioLengthPathTestCase(AudioLengthPathTestCase): def testSingleQuote(self): self._testSuffix(u"morituri.test.Guns 'N Roses") def testDoubleQuote(self): # This test makes sure we can checksum files with double quote in # their name self._testSuffix(u'morituri.test.12" edit') class UnicodeAudioLengthPathTestCase(AudioLengthPathTestCase, tcommon.UnicodeTestMixin): def testUnicodePath(self): # this test makes sure we can checksum a unicode path self._testSuffix(u'morituri.test.B\xeate Noire.empty')