Fix mistakes in tag cache generation

This commit is contained in:
Thomas Adamcik 2010-10-30 01:06:26 +02:00
parent d2d8e4c090
commit ea74f539ba
2 changed files with 33 additions and 14 deletions

View File

@ -122,7 +122,10 @@ def tracks_to_tag_cache_format(tracks):
return result
def _add_to_tag_cache(result, folders, files):
for name, entry in folders.items():
for path, entry in folders.items():
name = os.path.split(path)[1]
result.append(('directory', path))
result.append(('mtime', stat(name).st_mtime))
result.append(('begin', name))
_add_to_tag_cache(result, *entry)
result.append(('end', name))
@ -136,11 +139,13 @@ def tracks_to_directory_tree(tracks):
directories = ({}, [])
for track in tracks:
uri = uri_to_mpd_relative_path(track.uri)
folder = os.path.dirname(uri_to_path(uri))
path = ''
current = directories
for part in split_path(folder):
if part not in current[0]:
current[0][part] = ({}, [])
current = current[0][part]
for part in split_path(os.path.dirname(uri_to_path(uri))):
path = os.path.join(path, part)
print path
if path not in current[0]:
current[0][path] = ({}, [])
current = current[0][path]
current[1].append(track)
return directories

View File

@ -8,7 +8,7 @@ from mopidy.models import Album, Artist, Playlist, Track
from tests import data_folder, SkipTest
def fake_stat(path):
def fake_mtime(path):
class StatResult(object):
def __getattr__(self, key):
assert key == 'st_mtime', key
@ -18,7 +18,7 @@ def fake_stat(path):
class TrackMpdFormatTest(unittest.TestCase):
def setUp(self):
settings.LOCAL_MUSIC_FOLDER = '/dir/subdir'
translator.stat = fake_stat
translator.stat = fake_mtime
def tearDown(self):
settings.runtime.clear()
@ -134,7 +134,7 @@ class TracksToTagCacheFormatTest(unittest.TestCase):
def setUp(self):
settings.LOCAL_MUSIC_FOLDER = '/dir/subdir'
translator.stat = fake_stat
translator.stat = fake_mtime
def tearDown(self):
settings.runtime.clear()
@ -155,11 +155,13 @@ class TracksToTagCacheFormatTest(unittest.TestCase):
self.fail("Couldn't find songList end in result")
def consume_directory(self, result):
self.assertEqual('begin', result[0][0])
directory = result[0][1]
self.assertEqual('directory', result[0][0])
self.assertEqual(('mtime', fake_mtime('').st_mtime), result[1])
self.assertEqual(('begin', os.path.split(result[0][1])[1]), result[2])
directory = result[2][1]
for i, row in enumerate(result):
if row == ('end', directory):
return result[1:i], result[i+1:]
return result[3:i], result[i+1:]
self.fail("Couldn't find end %s in result" % directory)
def test_empty_tag_cache_has_header(self):
@ -225,6 +227,18 @@ class TracksToTagCacheFormatTest(unittest.TestCase):
self.assertEqual(len(result), 0)
self.assertEqual(song_list, formated)
def test_tag_cache_diretory_header_is_right(self):
track = Track(uri='file:///dir/subdir/folder/sub/song.mp3')
formated = translator.track_to_mpd_format(track, key=True, mtime=True)
result = translator.tracks_to_tag_cache_format([track])
result = self.consume_headers(result)
folder, result = self.consume_directory(result)
self.assertEqual(('directory', 'folder/sub'), folder[0])
self.assertEqual(('mtime', fake_mtime('').st_mtime), folder[1])
self.assertEqual(('begin', 'sub'), folder[2])
def test_tag_cache_suports_sub_directories(self):
track = Track(uri='file:///dir/subdir/folder/sub/song.mp3')
formated = translator.track_to_mpd_format(track, key=True, mtime=True)
@ -317,7 +331,7 @@ class TracksToDirectoryTreeTest(unittest.TestCase):
def test_single_file_in_sub_subdir(self):
tracks = [Track(uri='file:///dir1/dir2/file1.mp3')]
tree = translator.tracks_to_directory_tree(tracks)
expected = ({'dir1': ({'dir2': ({}, tracks)}, [])}, [])
expected = ({'dir1': ({'dir1/dir2': ({}, tracks)}, [])}, [])
self.assertEqual(tree, expected)
def test_complex_file_structure(self):
@ -334,7 +348,7 @@ class TracksToDirectoryTreeTest(unittest.TestCase):
'dir1': ({}, [tracks[1], tracks[2]]),
'dir2': (
{
'sub': ({}, [tracks[4]])
'dir2/sub': ({}, [tracks[4]])
},
[tracks[3]]
),