mirror of
https://github.com/fergalmoran/picard.git
synced 2025-12-22 17:28:58 +00:00
166 lines
5.9 KiB
Python
166 lines
5.9 KiB
Python
# -*- coding: utf-8 -*-
|
|
#
|
|
# Picard, the next-generation MusicBrainz tagger
|
|
#
|
|
# Copyright (C) 2021 Laurent Monin
|
|
# Copyright (C) 2021 Philipp Wolfer
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License
|
|
# as published by the Free Software Foundation; either version 2
|
|
# of the License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
|
from test.picardtestcase import PicardTestCase
|
|
|
|
from picard.cluster import (
|
|
Cluster,
|
|
FileCluster,
|
|
tokenize,
|
|
)
|
|
from picard.file import File
|
|
|
|
|
|
class TokenizeTest(PicardTestCase):
|
|
|
|
def test_tokenize(self):
|
|
token = tokenize("")
|
|
self.assertEqual(token, "")
|
|
|
|
token = tokenize(" \t ")
|
|
self.assertEqual(token, "")
|
|
|
|
token = tokenize(" A\tWord-test ")
|
|
self.assertEqual(token, "awordtest")
|
|
|
|
|
|
class ClusterTest(PicardTestCase):
|
|
|
|
def setUp(self):
|
|
super().setUp()
|
|
self.set_config_values({
|
|
'windows_compatibility': False,
|
|
'va_name': 'Diverse Interpreten',
|
|
})
|
|
|
|
def _create_file(self, album, artist, filename="foo.mp3"):
|
|
file = File(filename)
|
|
file.metadata['album'] = album
|
|
file.metadata['artist'] = artist
|
|
return file
|
|
|
|
def assertClusterEqual(self, album, artist, files, cluster):
|
|
self.assertEqual(album, cluster.title)
|
|
self.assertEqual(artist, cluster.artist)
|
|
self.assertEqual(set(files), set(cluster.files))
|
|
|
|
def test_cluster_none(self):
|
|
clusters = list(Cluster.cluster([]))
|
|
# No cluster is being created
|
|
self.assertEqual(0, len(clusters))
|
|
|
|
def test_cluster_single_file(self):
|
|
files = [
|
|
self._create_file('album foo', 'artist foo'),
|
|
]
|
|
clusters = list(Cluster.cluster(files))
|
|
self.assertEqual(1, len(clusters))
|
|
|
|
def test_cluster_single_cluster(self):
|
|
files = [
|
|
self._create_file('album foo', 'artist bar'),
|
|
self._create_file('album foo', 'artist foo'),
|
|
self._create_file('album foo', 'artist foo'),
|
|
]
|
|
clusters = list(Cluster.cluster(files))
|
|
self.assertEqual(1, len(clusters))
|
|
self.assertClusterEqual('album foo', 'artist foo', files, clusters[0])
|
|
|
|
def test_cluster_multi(self):
|
|
files = [
|
|
self._create_file('album cluster1', 'artist bar'),
|
|
self._create_file('album cluster2', 'artist foo'),
|
|
self._create_file('album cluster1', 'artist foo'),
|
|
self._create_file('albumcluster2', 'artist bar'),
|
|
self._create_file('album single', 'artist bar'),
|
|
]
|
|
clusters = list(Cluster.cluster(files))
|
|
self.assertEqual(3, len(clusters))
|
|
self.assertClusterEqual('album cluster1', 'artist bar', {files[0], files[2]}, clusters[0])
|
|
self.assertClusterEqual('album cluster2', 'artist foo', {files[1], files[3]}, clusters[1])
|
|
self.assertClusterEqual('album single', 'artist bar', {files[4]}, clusters[2])
|
|
|
|
def test_cluster_by_path(self):
|
|
files = [
|
|
self._create_file(None, None, 'artist1/album1/foo1.ogg'),
|
|
self._create_file(None, None, 'album2/foo1.ogg'),
|
|
self._create_file(None, None, 'artist1/album1/foo2.ogg'),
|
|
self._create_file(None, None, 'album2/foo2.ogg'),
|
|
self._create_file(None, None, 'single/foo.ogg'),
|
|
self._create_file(None, None, 'album1/foo3.ogg'),
|
|
]
|
|
clusters = list(Cluster.cluster(files))
|
|
self.assertEqual(3, len(clusters))
|
|
self.assertClusterEqual('album1', 'artist1', {files[0], files[2], files[5]}, clusters[0])
|
|
self.assertClusterEqual('album2', 'Diverse Interpreten', {files[1], files[3]}, clusters[1])
|
|
self.assertClusterEqual('single', 'Diverse Interpreten', {files[4]}, clusters[2])
|
|
|
|
def test_cluster_no_metadata(self):
|
|
files = [
|
|
self._create_file(None, None, 'foo1.ogg'),
|
|
self._create_file(None, None, 'foo2.ogg'),
|
|
self._create_file(None, None, 'foo3.ogg'),
|
|
]
|
|
clusters = list(Cluster.cluster(files))
|
|
self.assertEqual(0, len(clusters))
|
|
|
|
def test_common_artist_name(self):
|
|
files = [
|
|
self._create_file('cluster 1', 'artist 1'),
|
|
self._create_file('cluster 1', 'artist 2'),
|
|
self._create_file('cluster 1', 'artist2'),
|
|
self._create_file('cluster 1', 'artist 1'),
|
|
self._create_file('cluster 1', 'artist 2'),
|
|
]
|
|
clusters = list(Cluster.cluster(files))
|
|
self.assertEqual(1, len(clusters))
|
|
self.assertClusterEqual('cluster 1', 'artist 2', files, clusters[0])
|
|
|
|
|
|
class FileClusterTest(PicardTestCase):
|
|
|
|
def test_single(self):
|
|
file = File('foo')
|
|
fc = FileCluster()
|
|
fc.add('album 1', 'artist 1', file)
|
|
self.assertEqual('album 1', fc.title)
|
|
self.assertEqual('artist 1', fc.artist)
|
|
self.assertEqual([file], list(fc.files))
|
|
|
|
def test_multi(self):
|
|
files = [
|
|
File('foo1'),
|
|
File('foo2'),
|
|
File('foo3'),
|
|
File('foo4'),
|
|
File('foo5'),
|
|
]
|
|
fc = FileCluster()
|
|
fc.add('album 1', 'artist1', files[0])
|
|
fc.add('Album 1', 'artist 2', files[1])
|
|
fc.add('album\t1', 'Artist 1', files[2])
|
|
fc.add('Album 1', 'Artist 2', files[3])
|
|
fc.add('album 2', 'Artist 1', files[4])
|
|
self.assertEqual('Album 1', fc.title)
|
|
self.assertEqual('Artist 1', fc.artist)
|
|
self.assertEqual(files, list(fc.files))
|