projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fill test disk partitions with random noise to expose more bugs.
[dcpomatic.git]
/
test
/
audio_processor_delay_test.cc
diff --git
a/test/audio_processor_delay_test.cc
b/test/audio_processor_delay_test.cc
index 78f8e689596272ae8551233a9a945f08d27b7232..47a1cc8adfb344112ca01c8c22456ebbc2034599 100644
(file)
--- a/
test/audio_processor_delay_test.cc
+++ b/
test/audio_processor_delay_test.cc
@@
-1,5
+1,5
@@
/*
/*
- Copyright (C) 2015 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2015
-2021
Carl Hetherington <cth@carlh.net>
This file is part of DCP-o-matic.
This file is part of DCP-o-matic.
@@
-18,15
+18,25
@@
*/
*/
-#include "lib/audio_delay.h"
+
+/** @file test/audio_processor_delay_test.cc
+ * @brief Test the AudioDelay class.
+ * @ingroup selfcontained
+ */
+
+
#include "lib/audio_buffers.h"
#include "lib/audio_buffers.h"
+#include "lib/audio_delay.h"
#include <boost/test/unit_test.hpp>
#include <cmath>
#include <iostream>
#include <boost/test/unit_test.hpp>
#include <cmath>
#include <iostream>
+
using std::cerr;
using std::cout;
using std::cerr;
using std::cout;
-using boost::shared_ptr;
+using std::make_shared;
+using std::shared_ptr;
+
#define CHECK_SAMPLE(c,f,r) \
if (fabs(out->data(c)[f] - (r)) > 0.1) { \
#define CHECK_SAMPLE(c,f,r) \
if (fabs(out->data(c)[f] - (r)) > 0.1) { \
@@
-34,6
+44,7
@@
using boost::shared_ptr;
BOOST_REQUIRE (fabs(out->data(c)[f] - (r)) <= 0.1); \
}
BOOST_REQUIRE (fabs(out->data(c)[f] - (r)) <= 0.1); \
}
+
/** Block size greater than delay */
BOOST_AUTO_TEST_CASE (audio_processor_delay_test1)
{
/** Block size greater than delay */
BOOST_AUTO_TEST_CASE (audio_processor_delay_test1)
{
@@
-41,14
+52,14
@@
BOOST_AUTO_TEST_CASE (audio_processor_delay_test1)
int const C = 2;
int const C = 2;
-
shared_ptr<AudioBuffers> in (new AudioBuffers (C, 256)
);
+
auto in = make_shared<AudioBuffers>(C, 256
);
for (int i = 0; i < C; ++i) {
for (int j = 0; j < 256; ++j) {
in->data(i)[j] = j;
}
}
for (int i = 0; i < C; ++i) {
for (int j = 0; j < 256; ++j) {
in->data(i)[j] = j;
}
}
-
shared_ptr<AudioBuffers>
out = delay.run (in);
+
auto
out = delay.run (in);
BOOST_REQUIRE_EQUAL (out->frames(), in->frames());
/* Silence at the start */
BOOST_REQUIRE_EQUAL (out->frames(), in->frames());
/* Silence at the start */
@@
-81,6
+92,7
@@
BOOST_AUTO_TEST_CASE (audio_processor_delay_test1)
}
}
}
}
+
/** Block size less than delay */
BOOST_AUTO_TEST_CASE (audio_processor_delay_test2)
{
/** Block size less than delay */
BOOST_AUTO_TEST_CASE (audio_processor_delay_test2)
{
@@
-91,14
+103,14
@@
BOOST_AUTO_TEST_CASE (audio_processor_delay_test2)
/* Feeding 4 blocks of 64 should give silence each time */
for (int i = 0; i < 4; ++i) {
/* Feeding 4 blocks of 64 should give silence each time */
for (int i = 0; i < 4; ++i) {
-
shared_ptr<AudioBuffers> in (new AudioBuffers (C, 64)
);
+
auto in = make_shared<AudioBuffers>(C, 64
);
for (int j = 0; j < C; ++j) {
for (int k = 0; k < 64; ++k) {
in->data(j)[k] = k + i * 64;
}
}
for (int j = 0; j < C; ++j) {
for (int k = 0; k < 64; ++k) {
in->data(j)[k] = k + i * 64;
}
}
-
shared_ptr<AudioBuffers>
out = delay.run (in);
+
auto
out = delay.run (in);
BOOST_REQUIRE_EQUAL (out->frames(), in->frames());
/* Check for silence */
BOOST_REQUIRE_EQUAL (out->frames(), in->frames());
/* Check for silence */
@@
-112,9
+124,9
@@
BOOST_AUTO_TEST_CASE (audio_processor_delay_test2)
/* Now feed 4 blocks of silence and we should see the data */
for (int i = 0; i < 4; ++i) {
/* Feed some silence */
/* Now feed 4 blocks of silence and we should see the data */
for (int i = 0; i < 4; ++i) {
/* Feed some silence */
-
shared_ptr<AudioBuffers> in (new AudioBuffers (C, 64)
);
+
auto in = make_shared<AudioBuffers>(C, 64
);
in->make_silent ();
in->make_silent ();
-
shared_ptr<AudioBuffers>
out = delay.run (in);
+
auto
out = delay.run (in);
/* Should now see the delayed data */
for (int j = 0; j < C; ++j) {
/* Should now see the delayed data */
for (int j = 0; j < C; ++j) {