Add a test that checks move_additional_files work with unicode paths

This is to test PICARD-1207
This commit is contained in:
Antonio Larrosa
2018-08-02 20:04:41 +02:00
committed by Sambhav Kothari
parent f95a848c82
commit 2eb01c2063
2 changed files with 90 additions and 0 deletions

89
test/test_filesystem.py Normal file
View File

@@ -0,0 +1,89 @@
# -*- coding: utf-8 -*-
import os.path
import picard.formats
import unittest
import shutil
from contextlib import suppress
from PyQt5 import QtCore
from picard import config
from tempfile import mkdtemp
from test.test_formats import FakeTagger
settings = {
'enabled_plugins': '',
'move_files': True,
'move_additional_files': True,
'move_additional_files_pattern': 'cover.jpg',
}
class TestFileSystem(unittest.TestCase):
def setUp(self):
self.src_directory = mkdtemp()
self.tgt_directory = mkdtemp()
QtCore.QObject.tagger = FakeTagger()
config.setting = settings.copy()
def tearDown(self):
shutil.rmtree(self.src_directory)
shutil.rmtree(self.tgt_directory)
def _set_up_src_file(self, filename, src_rel_path):
"""Copy filename to the src directory under src_rel_path."""
path = os.path.join(self.src_directory, src_rel_path)
shutil.copy(filename, path)
return path
def _set_up_tgt_filename(self, tgt_rel_path):
"""Return the absolute path to tgt_rel_path in the tgt directory."""
return os.path.join(self.tgt_directory, tgt_rel_path)
def _prepare_files(self, src_rel_path='', tgt_rel_path=''):
"""Prepare src files and tgt filenames for a test."""
with suppress(FileExistsError):
os.mkdir(os.path.join(self.src_directory, src_rel_path))
# Prepare the source directory structure under self.src_directory
# .../<src_rel_path>/test.mp3
# .../<src_rel_path>/cover.jpg
old_filename = self._set_up_src_file(os.path.join('test', 'data', 'test.mp3'),
os.path.join(src_rel_path, 'test.mp3'))
old_additional_filename = self._set_up_src_file(os.path.join('test', 'data', 'mb.jpg'),
os.path.join(src_rel_path, 'cover.jpg'))
with suppress(FileExistsError):
os.mkdir(os.path.join(self.tgt_directory, tgt_rel_path))
# Prepare the target filenames under self.tgt_directory
# .../<tgt_rel_path>/test.mp3
# .../<tgt_rel_path>/cover.jpg
new_filename = self._set_up_tgt_filename(os.path.join(tgt_rel_path, 'test.mp3'))
new_additional_filename = self._set_up_tgt_filename(os.path.join(tgt_rel_path, 'cover.jpg'))
return (old_filename, old_additional_filename, new_filename, new_additional_filename)
def test_move_additional_files_source_unicode(self):
files = self._prepare_files(src_rel_path='música')
(old_filename, old_additional_filename, new_filename, new_additional_filename) = files
f = picard.formats.open_(old_filename)
f._move_additional_files(old_filename, new_filename)
self.assertTrue(os.path.isfile(new_additional_filename))
self.assertFalse(os.path.isfile(old_additional_filename))
def test_move_additional_files_target_unicode(self):
files = self._prepare_files(tgt_rel_path='música')
(old_filename, old_additional_filename, new_filename, new_additional_filename) = files
f = picard.formats.open_(old_filename)
f._move_additional_files(old_filename, new_filename)
self.assertTrue(os.path.isfile(new_additional_filename))
self.assertFalse(os.path.isfile(old_additional_filename))