diff options
| author | Carl Hetherington <cth@carlh.net> | 2023-03-23 00:29:40 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2023-03-23 16:51:38 +0100 |
| commit | f4fda1d705adfca0b7c8d3748c0c9df8e9da51bc (patch) | |
| tree | 583d0b6170b6aed83ef8d9577307cd6655480143 /test | |
| parent | e7d8a70a16f972de2861bb1464dec6df3d26c579 (diff) | |
Fix crashes when using templates in some cases (#2491).
If a template had content with N audio channels there would be various
problems if content with <N channels was subsequently added.
Diffstat (limited to 'test')
| m--------- | test/data | 0 | ||||
| -rw-r--r-- | test/template_test.cc | 47 | ||||
| -rw-r--r-- | test/wscript | 1 |
3 files changed, 48 insertions, 0 deletions
diff --git a/test/data b/test/data -Subproject 1bda4d6e0a3fd9c455166aa9a6b70ac348bc83d +Subproject c79ab114fdd6ca5f2f20a9d13d9203826f7f6c6 diff --git a/test/template_test.cc b/test/template_test.cc new file mode 100644 index 000000000..6af7751cb --- /dev/null +++ b/test/template_test.cc @@ -0,0 +1,47 @@ +/* + Copyright (C) 2023 Carl Hetherington <cth@carlh.net> + + This file is part of DCP-o-matic. + + DCP-o-matic 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. + + DCP-o-matic 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 DCP-o-matic. If not, see <http://www.gnu.org/licenses/>. + +*/ + + +#include "lib/audio_content.h" +#include "lib/config.h" +#include "lib/content_factory.h" +#include "lib/film.h" +#include "test.h" +#include <boost/test/unit_test.hpp> + + +/* Bug #2491 */ +BOOST_AUTO_TEST_CASE(template_wrong_channel_counts) +{ + ConfigRestorer cr; + + Config::override_path = "test/data"; + + auto film = new_test_film2("template_wrong_channel_counts", {}); + film->use_template("Bug"); + + auto mono = content_factory("test/data/C.wav").front(); + film->examine_and_add_content(mono); + BOOST_REQUIRE(!wait_for_jobs()); + + BOOST_REQUIRE_EQUAL(mono->audio->streams().size(), 1U); + BOOST_CHECK_EQUAL(mono->audio->streams()[0]->channels(), 1); +} + diff --git a/test/wscript b/test/wscript index 6c85def54..dc108acb6 100644 --- a/test/wscript +++ b/test/wscript @@ -149,6 +149,7 @@ def build(bld): subtitle_reel_number_test.cc subtitle_timing_test.cc subtitle_trim_test.cc + template_test.cc test.cc text_decoder_test.cc threed_test.cc |
