summaryrefslogtreecommitdiff
path: root/test/sound_asset_writer_test.cc
diff options
context:
space:
mode:
Diffstat (limited to 'test/sound_asset_writer_test.cc')
-rw-r--r--test/sound_asset_writer_test.cc117
1 files changed, 117 insertions, 0 deletions
diff --git a/test/sound_asset_writer_test.cc b/test/sound_asset_writer_test.cc
new file mode 100644
index 00000000..32ab06b5
--- /dev/null
+++ b/test/sound_asset_writer_test.cc
@@ -0,0 +1,117 @@
+/*
+ Copyright (C) 2023 Carl Hetherington <cth@carlh.net>
+
+ This file is part of libdcp.
+
+ libdcp is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ libdcp is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with libdcp. If not, see <http://www.gnu.org/licenses/>.
+
+ In addition, as a special exception, the copyright holders give
+ permission to link the code of portions of this program with the
+ OpenSSL library under certain conditions as described in each
+ individual source file, and distribute linked combinations
+ including the two.
+
+ You must obey the GNU General Public License in all respects
+ for all of the code used other than OpenSSL. If you modify
+ file(s) with this exception, you may extend this exception to your
+ version of the file(s), but you are not obligated to do so. If you
+ do not wish to do so, delete this exception statement from your
+ version. If you delete this exception statement from all source
+ files in the program, then also delete it here.
+*/
+
+
+#include "sound_asset.h"
+#include "sound_asset_writer.h"
+#include <boost/filesystem.hpp>
+#include <boost/random.hpp>
+#include <boost/test/unit_test.hpp>
+
+
+BOOST_AUTO_TEST_CASE(sound_asset_writer_no_padding_test)
+{
+ auto path = boost::filesystem::path("build/test/sound_asset_writer_no_padding_test.mxf");
+ dcp::SoundAsset asset({24, 1}, 48000, 6, dcp::LanguageTag{"en-GB"}, dcp::Standard::SMPTE);
+ auto writer = asset.start_write(path);
+
+ boost::random::mt19937 rng(1);
+ boost::random::uniform_int_distribution<> dist(0, 32767);
+
+ std::vector<std::vector<float>> buffers(6);
+ float* pointers[6];
+ for (auto channel = 0; channel < 6; ++channel) {
+ buffers[channel].resize(2000);
+ for (int sample = 0; sample < 2000; ++sample) {
+ buffers[channel][sample] = static_cast<float>(dist(rng)) / (1 << 23);
+ }
+ pointers[channel] = buffers[channel].data();
+ }
+
+ writer->write(pointers, 6, 2000);
+ writer->finalize();
+
+ dcp::SoundAsset check(path);
+ auto reader = check.start_read();
+ auto frame = reader->get_frame(0);
+
+ rng.seed(1);
+
+ for (auto channel = 0; channel < 6; ++channel) {
+ for (auto sample = 0; sample < 2000; ++sample) {
+ BOOST_REQUIRE_EQUAL(frame->get(channel, sample), dist(rng));
+ }
+ }
+}
+
+
+BOOST_AUTO_TEST_CASE(sound_asset_writer_padding_test)
+{
+ auto path = boost::filesystem::path("build/test/sound_asset_writer_padding_test.mxf");
+ dcp::SoundAsset asset({24, 1}, 48000, 14, dcp::LanguageTag{"en-GB"}, dcp::Standard::SMPTE);
+ auto writer = asset.start_write(path);
+
+ boost::random::mt19937 rng(1);
+ boost::random::uniform_int_distribution<> dist(0, 32767);
+
+ std::vector<std::vector<float>> buffers(6);
+ float* pointers[6];
+ for (auto channel = 0; channel < 6; ++channel) {
+ buffers[channel].resize(2000);
+ for (int sample = 0; sample < 2000; ++sample) {
+ buffers[channel][sample] = static_cast<float>(dist(rng)) / (1 << 23);
+ }
+ pointers[channel] = buffers[channel].data();
+ }
+
+ writer->write(pointers, 6, 2000);
+ writer->finalize();
+
+ dcp::SoundAsset check(path);
+ auto reader = check.start_read();
+ auto frame = reader->get_frame(0);
+
+ rng.seed(1);
+
+ for (auto channel = 0; channel < 6; ++channel) {
+ for (auto sample = 0; sample < 2000; ++sample) {
+ BOOST_REQUIRE_EQUAL(frame->get(channel, sample), dist(rng));
+ }
+ }
+
+ for (auto channel = 7; channel < 14; ++channel) {
+ for (auto sample = 0; sample < 2000; ++sample) {
+ BOOST_REQUIRE_EQUAL(frame->get(channel, sample), 0);
+ }
+ }
+}