diff --git a/airtime_mvc/application/models/StoredFile.php b/airtime_mvc/application/models/StoredFile.php index c005243db..efe81c7b9 100644 --- a/airtime_mvc/application/models/StoredFile.php +++ b/airtime_mvc/application/models/StoredFile.php @@ -396,7 +396,6 @@ SQL; return $possible_ext; } - // We fallback to guessing the extension from the mimetype if we // cannot extract it from the file name @@ -993,15 +992,18 @@ SQL; /** * * Enter description here ... - * @param $dir_id - if this is not provided, it returns all files with full path constructed. + * @param $dir_id - if this is not provided, it returns all files with full + * path constructed. */ public static function listAllFiles($dir_id=null, $all) { $con = Propel::getConnection(); - $sql = "SELECT filepath as fp" - ." FROM CC_FILES as f" - ." WHERE f.directory = :dir_id"; + $sql = << /dev/null 2>&1") % \ pathname.replace("'", "'\\''") - print(command) return True return_code = subprocess.call(command, shell=True) return (return_code == 0) diff --git a/python_apps/media-monitor2/media/monitor/watchersyncer.py b/python_apps/media-monitor2/media/monitor/watchersyncer.py index 214335fb6..61146326a 100644 --- a/python_apps/media-monitor2/media/monitor/watchersyncer.py +++ b/python_apps/media-monitor2/media/monitor/watchersyncer.py @@ -8,6 +8,7 @@ from media.monitor.log import Loggable from media.monitor.exceptions import BadSongFile from media.monitor.pure import LazyProperty from media.monitor.eventcontractor import EventContractor +from media.monitor.events import EventProxy import api_clients.api_client as ac @@ -125,7 +126,7 @@ class WatchSyncer(ReportHandler,Loggable): try: # If there is a strange bug anywhere in the code the next line # should be a suspect - if self.contractor.register(event): self.push_queue( event ) + if self.contractor.register(EventProxy(event)): self.push_queue( event ) #self.push_queue( event ) except BadSongFile as e: self.fatal_exception("Received bas song file '%s'" % e.path, e) diff --git a/python_apps/media-monitor2/tests/prepare_tests.py b/python_apps/media-monitor2/tests/prepare_tests.py index 2522468ef..4e9a2247c 100644 --- a/python_apps/media-monitor2/tests/prepare_tests.py +++ b/python_apps/media-monitor2/tests/prepare_tests.py @@ -1,19 +1,15 @@ -import shutil -import subprocess # The tests rely on a lot of absolute paths and other garbage so this file # configures all of that + music_folder = u'/home/rudi/music' o_path = u'/home/rudi/throwaway/ACDC_-_Back_In_Black-sample-64kbps.ogg' watch_path = u'/home/rudi/throwaway/fucking_around/watch/', real_path1 = u'/home/rudi/throwaway/fucking_around/watch/unknown/unknown/ACDC_-_Back_In_Black-sample-64kbps-64kbps.ogg' opath = u"/home/rudi/Airtime/python_apps/media-monitor2/tests/" ppath = u"/home/rudi/Airtime/python_apps/media-monitor2/media/" -sample_config = u'/home/rudi/Airtime/python_apps/media-monitor2/tests/api_client.cfg' -real_config = u'/home/rudi/Airtime/python_apps/media-monitor2/tests/live_client.cfg' + api_client_path = '/etc/airtime/api_client.cfg' - -if __name__ == "__main__": - shutil.copy(api_client_path, real_config) - # TODO : fix this to use liberal permissions - subprocess.call(["chown","rudi",real_config]) +# holdover from the time we had a special config for testing +sample_config = api_client_path +real_config = api_client_path diff --git a/python_apps/media-monitor2/tests/test_api_client.py b/python_apps/media-monitor2/tests/test_api_client.py index f89b5efb3..26f1a25ef 100644 --- a/python_apps/media-monitor2/tests/test_api_client.py +++ b/python_apps/media-monitor2/tests/test_api_client.py @@ -9,7 +9,8 @@ import prepare_tests class TestApiClient(unittest.TestCase): def setUp(self): - test_path = prepare_tests.real_config + test_path = prepare_tests.api_client_path + print("Running from api_config: %s" % test_path) if not os.path.exists(test_path): print("path for config does not exist: '%s' % test_path") # TODO : is there a cleaner way to exit the unit testing? diff --git a/python_apps/media-monitor2/tests/test_eventcontractor.py b/python_apps/media-monitor2/tests/test_eventcontractor.py index da35a71d1..f5ad827c2 100644 --- a/python_apps/media-monitor2/tests/test_eventcontractor.py +++ b/python_apps/media-monitor2/tests/test_eventcontractor.py @@ -3,48 +3,37 @@ from media.monitor.eventcontractor import EventContractor #from media.monitor.exceptions import BadSongFile from media.monitor.events import FakePyinotify, NewFile, MoveFile, \ DeleteFile -from mock import patch class TestMMP(unittest.TestCase): def test_event_registered(self): ev = EventContractor() - e1 = NewFile( FakePyinotify('bullshit.mp3') ) - e2 = MoveFile( FakePyinotify('bullshit.mp3') ) + e1 = NewFile( FakePyinotify('bullshit.mp3') ).proxify() + e2 = MoveFile( FakePyinotify('bullshit.mp3') ).proxify() ev.register(e1) self.assertTrue( ev.event_registered(e2) ) def test_get_old_event(self): ev = EventContractor() - e1 = NewFile( FakePyinotify('bullshit.mp3') ) - e2 = MoveFile( FakePyinotify('bullshit.mp3') ) + e1 = NewFile( FakePyinotify('bullshit.mp3') ).proxify() + e2 = MoveFile( FakePyinotify('bullshit.mp3') ).proxify() ev.register(e1) self.assertEqual( ev.get_old_event(e2), e1 ) def test_register(self): ev = EventContractor() - e1 = NewFile( FakePyinotify('bullshit.mp3') ) - e2 = DeleteFile( FakePyinotify('bullshit.mp3') ) + e1 = NewFile( FakePyinotify('bullshit.mp3') ).proxify() + e2 = DeleteFile( FakePyinotify('bullshit.mp3') ).proxify() self.assertTrue( ev.register(e1) ) - # Check that morph_into is called when it should be - with patch.object(NewFile, 'morph_into', return_value='kimchi') \ - as mock_method: - ret = ev.register(e2) - self.assertFalse(ret) - mock_method.assert_called_once_with(e2) - - # This time we are not patching morph self.assertFalse( ev.register(e2) ) - # We did not an element - self.assertTrue( len(ev.store.keys()) == 1 ) - morphed = ev.get_old_event(e2) - self.assertTrue( isinstance(morphed, DeleteFile) ) + + self.assertEqual( len(ev.store.keys()), 1 ) delete_ev = e1.safe_pack()[0] self.assertEqual( delete_ev['mode'], u'delete') - self.assertTrue( len(ev.store.keys()) == 0 ) + self.assertEqual( len(ev.store.keys()), 0 ) - e3 = DeleteFile( FakePyinotify('horseshit.mp3') ) + e3 = DeleteFile( FakePyinotify('horseshit.mp3') ).proxify() self.assertTrue( ev.register(e3) ) self.assertTrue( ev.register(e2) ) @@ -58,11 +47,12 @@ class TestMMP(unittest.TestCase): DeleteFile( FakePyinotify(p) ), NewFile( FakePyinotify(p) ), NewFile( FakePyinotify(p) ), ] + events = map(lambda x: x.proxify(), events) actual_events = [] for e in events: if ev.register(e): actual_events.append(e) self.assertEqual( len(ev.store.keys()), 1 ) - packed = [ x.safe_pack() for x in actual_events ] + #packed = [ x.safe_pack() for x in actual_events ] if __name__ == '__main__': unittest.main()