File size: 1,325 Bytes
74f2c64
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import pytest

from src import output, config
import test_config


def test_write_audio():
    """
    Tests write_audio function, takes in an audio tensor with a file path and writes the audio to a file.
    """
    import torch

    test_path = test_config.data_path / 'test_audio.wav'
    audio_path = test_config.data_path / 'test_audio.pt'
    audio_list = torch.load(audio_path)

    output.write_audio(audio_list, test_path)

    assert test_path.is_file()
    assert test_path.stat().st_size == 592858

    test_path.unlink()


def test_assemble_zip():
    """
    Tests assemble_zip function, which collects all the audio files from the output directory,
    and zips them up into a zip directory.
    """
    from shutil import copy2

    if not config.output_path.exists():
        config.output_path.mkdir()

    title = "speaker_samples"
    zip_path = config.output_path / 'speaker_samples.zip'
    wav1_path = config.output_path / 'speaker_en_0.wav'
    wav2_path = config.output_path / 'speaker_en_110.wav'

    for file_path in config.resource_path.iterdir():
        if file_path.suffix == '.wav':
            copy2(file_path, config.output_path)

    _ = output.assemble_zip(title)

    assert zip_path.is_file()
    assert not wav1_path.is_file()
    assert not wav2_path.is_file()

    zip_path.unlink()