forked from mia/Aegisub
Fix failing unit tests on Windows
This commit is contained in:
parent
dd59fc988a
commit
1122c0880a
2 changed files with 78 additions and 57 deletions
|
@ -122,7 +122,7 @@ TEST(lagi_audio, save_audio_clip) {
|
||||||
agi::SaveAudioClip(*provider, path, 60 * 60 * 1000, (60 * 60 + 10) * 1000);
|
agi::SaveAudioClip(*provider, path, 60 * 60 * 1000, (60 * 60 + 10) * 1000);
|
||||||
|
|
||||||
{
|
{
|
||||||
bfs::ifstream s(path);
|
bfs::ifstream s(path, std::ios_base::binary);
|
||||||
ASSERT_TRUE(s.good());
|
ASSERT_TRUE(s.good());
|
||||||
s.seekg(0, std::ios::end);
|
s.seekg(0, std::ios::end);
|
||||||
// 10 seconds of 44.1 kHz samples per second of 16-bit mono, plus 44 bytes of header
|
// 10 seconds of 44.1 kHz samples per second of 16-bit mono, plus 44 bytes of header
|
||||||
|
@ -141,7 +141,7 @@ TEST(lagi_audio, save_audio_clip_out_of_audio_range) {
|
||||||
// Start time after end of clip: empty file
|
// Start time after end of clip: empty file
|
||||||
agi::SaveAudioClip(*provider, path, end_time, end_time + 1);
|
agi::SaveAudioClip(*provider, path, end_time, end_time + 1);
|
||||||
{
|
{
|
||||||
bfs::ifstream s(path);
|
bfs::ifstream s(path, std::ios_base::binary);
|
||||||
ASSERT_TRUE(s.good());
|
ASSERT_TRUE(s.good());
|
||||||
s.seekg(0, std::ios::end);
|
s.seekg(0, std::ios::end);
|
||||||
EXPECT_EQ(44, s.tellg());
|
EXPECT_EQ(44, s.tellg());
|
||||||
|
@ -151,7 +151,7 @@ TEST(lagi_audio, save_audio_clip_out_of_audio_range) {
|
||||||
// Start time >= end time: empty file
|
// Start time >= end time: empty file
|
||||||
agi::SaveAudioClip(*provider, path, end_time - 1, end_time - 1);
|
agi::SaveAudioClip(*provider, path, end_time - 1, end_time - 1);
|
||||||
{
|
{
|
||||||
bfs::ifstream s(path);
|
bfs::ifstream s(path, std::ios_base::binary);
|
||||||
ASSERT_TRUE(s.good());
|
ASSERT_TRUE(s.good());
|
||||||
s.seekg(0, std::ios::end);
|
s.seekg(0, std::ios::end);
|
||||||
EXPECT_EQ(44, s.tellg());
|
EXPECT_EQ(44, s.tellg());
|
||||||
|
@ -161,7 +161,7 @@ TEST(lagi_audio, save_audio_clip_out_of_audio_range) {
|
||||||
// Start time during clip, end time after end of clip: save only the part that exists
|
// Start time during clip, end time after end of clip: save only the part that exists
|
||||||
agi::SaveAudioClip(*provider, path, end_time - 1000, end_time + 1000);
|
agi::SaveAudioClip(*provider, path, end_time - 1000, end_time + 1000);
|
||||||
{
|
{
|
||||||
bfs::ifstream s(path);
|
bfs::ifstream s(path, std::ios_base::binary);
|
||||||
ASSERT_TRUE(s.good());
|
ASSERT_TRUE(s.good());
|
||||||
s.seekg(0, std::ios::end);
|
s.seekg(0, std::ios::end);
|
||||||
// 1 second of 44.1 kHz samples per second of 16-bit mono, plus 44 bytes of header
|
// 1 second of 44.1 kHz samples per second of 16-bit mono, plus 44 bytes of header
|
||||||
|
@ -365,6 +365,7 @@ TEST(lagi_audio, pcm_simple) {
|
||||||
agi::SaveAudioClip(provider, path, 0, 1000);
|
agi::SaveAudioClip(provider, path, 0, 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
auto provider = agi::CreatePCMAudioProvider(path, nullptr);
|
auto provider = agi::CreatePCMAudioProvider(path, nullptr);
|
||||||
EXPECT_EQ(1, provider->GetChannels());
|
EXPECT_EQ(1, provider->GetChannels());
|
||||||
EXPECT_EQ(48000, provider->GetNumSamples());
|
EXPECT_EQ(48000, provider->GetNumSamples());
|
||||||
|
@ -378,6 +379,7 @@ TEST(lagi_audio, pcm_simple) {
|
||||||
provider->GetAudio(&sample, i, 1);
|
provider->GetAudio(&sample, i, 1);
|
||||||
ASSERT_EQ(i, sample);
|
ASSERT_EQ(i, sample);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
agi::fs::Remove(path);
|
agi::fs::Remove(path);
|
||||||
}
|
}
|
||||||
|
@ -391,16 +393,17 @@ TEST(lagi_audio, pcm_truncated) {
|
||||||
|
|
||||||
char file[1000];
|
char file[1000];
|
||||||
|
|
||||||
{ bfs::ifstream s(path); s.read(file, sizeof file); }
|
{ bfs::ifstream s(path, std::ios_base::binary); s.read(file, sizeof file); }
|
||||||
{ bfs::ofstream s(path); s.write(file, sizeof file); }
|
{ bfs::ofstream s(path, std::ios_base::binary); s.write(file, sizeof file); }
|
||||||
|
|
||||||
|
{
|
||||||
auto provider = agi::CreatePCMAudioProvider(path, nullptr);
|
auto provider = agi::CreatePCMAudioProvider(path, nullptr);
|
||||||
|
|
||||||
// Should still report full duration
|
// Should still report full duration
|
||||||
EXPECT_EQ(48000, provider->GetNumSamples());
|
EXPECT_EQ(48000, provider->GetNumSamples());
|
||||||
|
|
||||||
// And should zero-pad past the end
|
// And should zero-pad past the end
|
||||||
auto sample_count = (1000 - 44) / 2;
|
int64_t sample_count = (1000 - 44) / 2;
|
||||||
uint16_t sample;
|
uint16_t sample;
|
||||||
|
|
||||||
provider->GetAudio(&sample, sample_count - 1, 1);
|
provider->GetAudio(&sample, sample_count - 1, 1);
|
||||||
|
@ -408,6 +411,7 @@ TEST(lagi_audio, pcm_truncated) {
|
||||||
|
|
||||||
provider->GetAudio(&sample, sample_count, 1);
|
provider->GetAudio(&sample, sample_count, 1);
|
||||||
EXPECT_EQ(0, sample);
|
EXPECT_EQ(0, sample);
|
||||||
|
}
|
||||||
|
|
||||||
agi::fs::Remove(path);
|
agi::fs::Remove(path);
|
||||||
}
|
}
|
||||||
|
@ -415,7 +419,7 @@ TEST(lagi_audio, pcm_truncated) {
|
||||||
#define RIFF "RIFF\0\0\0\x60WAVE"
|
#define RIFF "RIFF\0\0\0\x60WAVE"
|
||||||
#define FMT_VALID "fmt \20\0\0\0\1\0\1\0\20\0\0\0\0\0\0\0\0\0\20\0"
|
#define FMT_VALID "fmt \20\0\0\0\1\0\1\0\20\0\0\0\0\0\0\0\0\0\20\0"
|
||||||
#define DATA_VALID "data\1\0\0\0\0\0"
|
#define DATA_VALID "data\1\0\0\0\0\0"
|
||||||
#define WRITE(str) do { bfs::ofstream s(path); s.write(str, sizeof(str) - 1); } while (false)
|
#define WRITE(str) do { bfs::ofstream s(path, std::ios_base::binary); s.write(str, sizeof(str) - 1); } while (false)
|
||||||
|
|
||||||
TEST(lagi_audio, pcm_incomplete) {
|
TEST(lagi_audio, pcm_incomplete) {
|
||||||
auto path = agi::Path().Decode("?temp/pcm_incomplete");
|
auto path = agi::Path().Decode("?temp/pcm_incomplete");
|
||||||
|
@ -423,7 +427,7 @@ TEST(lagi_audio, pcm_incomplete) {
|
||||||
agi::fs::Remove(path);
|
agi::fs::Remove(path);
|
||||||
ASSERT_THROW(agi::CreatePCMAudioProvider(path, nullptr), agi::fs::FileNotFound);
|
ASSERT_THROW(agi::CreatePCMAudioProvider(path, nullptr), agi::fs::FileNotFound);
|
||||||
|
|
||||||
bfs::ofstream{path};
|
{bfs::ofstream(path, std::ios_base::binary); }
|
||||||
ASSERT_THROW(agi::CreatePCMAudioProvider(path, nullptr), agi::AudioDataNotFound);
|
ASSERT_THROW(agi::CreatePCMAudioProvider(path, nullptr), agi::AudioDataNotFound);
|
||||||
|
|
||||||
// Invalid tags
|
// Invalid tags
|
||||||
|
@ -438,8 +442,10 @@ TEST(lagi_audio, pcm_incomplete) {
|
||||||
|
|
||||||
// -1 for nul term, -3 so that longest file is still invalid
|
// -1 for nul term, -3 so that longest file is still invalid
|
||||||
for (size_t i = 0; i < sizeof(valid_file) - 4; ++i) {
|
for (size_t i = 0; i < sizeof(valid_file) - 4; ++i) {
|
||||||
bfs::ofstream s(path);
|
{
|
||||||
|
bfs::ofstream s(path, std::ios_base::binary);
|
||||||
s.write(valid_file, i);
|
s.write(valid_file, i);
|
||||||
|
}
|
||||||
ASSERT_THROW(agi::CreatePCMAudioProvider(path, nullptr), agi::AudioDataNotFound);
|
ASSERT_THROW(agi::CreatePCMAudioProvider(path, nullptr), agi::AudioDataNotFound);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -463,6 +469,7 @@ TEST(lagi_audio, multiple_data_chunks) {
|
||||||
|
|
||||||
WRITE(RIFF FMT_VALID "data\2\0\0\0\1\0" "data\2\0\0\0\2\0" "data\2\0\0\0\3\0");
|
WRITE(RIFF FMT_VALID "data\2\0\0\0\1\0" "data\2\0\0\0\2\0" "data\2\0\0\0\3\0");
|
||||||
|
|
||||||
|
{
|
||||||
auto provider = agi::CreatePCMAudioProvider(path, nullptr);
|
auto provider = agi::CreatePCMAudioProvider(path, nullptr);
|
||||||
ASSERT_EQ(3, provider->GetNumSamples());
|
ASSERT_EQ(3, provider->GetNumSamples());
|
||||||
|
|
||||||
|
@ -485,6 +492,7 @@ TEST(lagi_audio, multiple_data_chunks) {
|
||||||
provider->GetAudio(samples, 0, 1);
|
provider->GetAudio(samples, 0, 1);
|
||||||
EXPECT_EQ(1, samples[0]);
|
EXPECT_EQ(1, samples[0]);
|
||||||
EXPECT_EQ(5, samples[1]);
|
EXPECT_EQ(5, samples[1]);
|
||||||
|
}
|
||||||
|
|
||||||
agi::fs::Remove(path);
|
agi::fs::Remove(path);
|
||||||
}
|
}
|
||||||
|
@ -504,6 +512,7 @@ TEST(lagi_audio, wave64_simple) {
|
||||||
auto path = agi::Path().Decode("?temp/w64_valid");
|
auto path = agi::Path().Decode("?temp/w64_valid");
|
||||||
WRITE(WAVE64_FILE);
|
WRITE(WAVE64_FILE);
|
||||||
|
|
||||||
|
{
|
||||||
auto provider = agi::CreatePCMAudioProvider(path, nullptr);
|
auto provider = agi::CreatePCMAudioProvider(path, nullptr);
|
||||||
ASSERT_EQ(2, provider->GetNumSamples());
|
ASSERT_EQ(2, provider->GetNumSamples());
|
||||||
|
|
||||||
|
@ -511,6 +520,7 @@ TEST(lagi_audio, wave64_simple) {
|
||||||
provider->GetAudio(samples, 0, 2);
|
provider->GetAudio(samples, 0, 2);
|
||||||
EXPECT_EQ(1, samples[0]);
|
EXPECT_EQ(1, samples[0]);
|
||||||
EXPECT_EQ(2, samples[1]);
|
EXPECT_EQ(2, samples[1]);
|
||||||
|
}
|
||||||
|
|
||||||
agi::fs::Remove(path);
|
agi::fs::Remove(path);
|
||||||
}
|
}
|
||||||
|
@ -520,13 +530,15 @@ TEST(lagi_audio, wave64_truncated) {
|
||||||
|
|
||||||
// Should be invalid until there's an entire sample
|
// Should be invalid until there's an entire sample
|
||||||
for (size_t i = 0; i < sizeof(WAVE64_FILE) - 4; ++i) {
|
for (size_t i = 0; i < sizeof(WAVE64_FILE) - 4; ++i) {
|
||||||
bfs::ofstream s(path);
|
{
|
||||||
|
bfs::ofstream s(path, std::ios_base::binary);
|
||||||
s.write(WAVE64_FILE, i);
|
s.write(WAVE64_FILE, i);
|
||||||
|
}
|
||||||
ASSERT_THROW(agi::CreatePCMAudioProvider(path, nullptr), agi::AudioDataNotFound);
|
ASSERT_THROW(agi::CreatePCMAudioProvider(path, nullptr), agi::AudioDataNotFound);
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
bfs::ofstream s(path);
|
bfs::ofstream s(path, std::ios_base::binary);
|
||||||
s.write(WAVE64_FILE, sizeof(WAVE64_FILE) - 3);
|
s.write(WAVE64_FILE, sizeof(WAVE64_FILE) - 3);
|
||||||
}
|
}
|
||||||
ASSERT_NO_THROW(agi::CreatePCMAudioProvider(path, nullptr));
|
ASSERT_NO_THROW(agi::CreatePCMAudioProvider(path, nullptr));
|
||||||
|
|
|
@ -172,9 +172,18 @@ TEST(lagi_path, make_relative_on_dummy_url) {
|
||||||
EXPECT_UNCHANGED("?dummy:23.976000:40000:1280:720:47:163:254:", MakeRelative);
|
EXPECT_UNCHANGED("?dummy:23.976000:40000:1280:720:47:163:254:", MakeRelative);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
TEST(lagi_path, encode) {
|
||||||
|
Path p;
|
||||||
|
p.SetToken("?user", "C:\\a\\b\\c");
|
||||||
|
p.SetToken("?local", "C:\\a\\b\\c\\d");
|
||||||
|
EXPECT_EQ("?local\\e", p.Encode("C:\\a\\b\\c\\d\\e"));
|
||||||
|
}
|
||||||
|
#else
|
||||||
TEST(lagi_path, encode) {
|
TEST(lagi_path, encode) {
|
||||||
Path p;
|
Path p;
|
||||||
p.SetToken("?user", "/a/b/c");
|
p.SetToken("?user", "/a/b/c");
|
||||||
p.SetToken("?local", "/a/b/c/d");
|
p.SetToken("?local", "/a/b/c/d");
|
||||||
EXPECT_EQ("?local/e", p.Encode("/a/b/c/d/e"));
|
EXPECT_EQ("?local/e", p.Encode("/a/b/c/d/e"));
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue