#!/usr/bin/env python # coding: utf8 """ Unit testing for Separator class. """ __email__ = 'research@deezer.com' __author__ = 'Deezer Research' __license__ = 'MIT License' import filecmp from os.path import basename, exists, join from tempfile import TemporaryDirectory import pytest from spleeter import SpleeterError from spleeter.audio.adapter import get_default_audio_adapter from spleeter.separator import Separator TEST_AUDIO_DESCRIPTOR = 'audio_example.mp3' TEST_AUDIO_BASENAME = basename(TEST_AUDIO_DESCRIPTOR) TEST_CONFIGURATIONS = [ ('spleeter:2stems', ('vocals', 'accompaniment')), ('spleeter:4stems', ('vocals', 'drums', 'bass', 'other')), ('spleeter:5stems', ('vocals', 'drums', 'bass', 'piano', 'other')) ] @pytest.mark.parametrize('configuration, instruments', TEST_CONFIGURATIONS) def test_separate(configuration, instruments): """ Test separation from raw data. """ adapter = get_default_audio_adapter() waveform, _ = adapter.load(TEST_AUDIO_DESCRIPTOR) separator = Separator(configuration) prediction = separator.separate(waveform) assert len(prediction) == len(instruments) for instrument in instruments: assert instrument in prediction for instrument in instruments: track = prediction[instrument] assert not (waveform == track).all() for compared in instruments: if instrument != compared: assert not (track == prediction[compared]).all() @pytest.mark.parametrize('configuration, instruments', TEST_CONFIGURATIONS) def test_separate_to_file(configuration, instruments): """ Test file based separation. """ separator = Separator(configuration) with TemporaryDirectory() as directory: separator.separate_to_file( TEST_AUDIO_DESCRIPTOR, directory) for instrument in instruments: assert exists(join( directory, '{}/{}.wav'.format(TEST_AUDIO_BASENAME, instrument))) @pytest.mark.parametrize('configuration, instruments', TEST_CONFIGURATIONS) def test_filename_format(configuration, instruments): """ Test custom filename format. """ separator = Separator(configuration) with TemporaryDirectory() as directory: separator.separate_to_file( TEST_AUDIO_DESCRIPTOR, directory, filename_format='export/{filename}/{instrument}.{codec}') for instrument in instruments: assert exists(join( directory, 'export/{}/{}.wav'.format(TEST_AUDIO_BASENAME, instrument))) def test_filename_confilct(): """ Test error handling with static pattern. """ separator = Separator(TEST_CONFIGURATIONS[0][0]) with TemporaryDirectory() as directory: with pytest.raises(SpleeterError): separator.separate_to_file( TEST_AUDIO_DESCRIPTOR, directory, filename_format='I wanna be your lover')