diff options
| author | Carl Hetherington <cth@carlh.net> | 2020-02-19 16:02:24 +0000 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2020-02-19 16:02:27 +0000 |
| commit | 3443fdbc38f56f4c83776d000f6aa61d00305cc8 (patch) | |
| tree | e1e2d16512e7bd3b684c49213e3447f7e2f66afe /test | |
| parent | aac56f99cc6b649e75e0466d1ef1baf4f3937fff (diff) | |
New way of checking for 2D content mislabelled as 3D (#1565).
Required because of the change to the way video frame timing
is done.
Diffstat (limited to 'test')
| -rw-r--r-- | test/frame_interval_checker_test.cc | 138 | ||||
| -rw-r--r-- | test/wscript | 1 |
2 files changed, 139 insertions, 0 deletions
diff --git a/test/frame_interval_checker_test.cc b/test/frame_interval_checker_test.cc new file mode 100644 index 000000000..77cf7ca5d --- /dev/null +++ b/test/frame_interval_checker_test.cc @@ -0,0 +1,138 @@ +/* + Copyright (C) 2020 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/frame_interval_checker.h" +#include <boost/test/unit_test.hpp> + +/** Test of 2D-ish frame timings */ +BOOST_AUTO_TEST_CASE (frame_interval_checker_test1) +{ + FrameIntervalChecker checker; + ContentTime t(3888); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4012); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4000); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4000); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(3776); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(3779); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4010); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4085); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4085); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4012); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4000); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4000); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(3776); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(3779); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4010); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4085); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4085); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::PROBABLY_NOT_3D); +} + +/** Test of 3D-ish frame timings */ +BOOST_AUTO_TEST_CASE (frame_interval_checker_test2) +{ + FrameIntervalChecker checker; + ContentTime t(3888); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(0); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4000); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(0); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(3776); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(50); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4010); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(2); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4011); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(0); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4000); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(0); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(3776); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(50); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4010); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(2); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::AGAIN); + t += ContentTime(4011); + checker.feed (t, 24); + BOOST_CHECK (checker.guess() == FrameIntervalChecker::PROBABLY_3D); +} + + diff --git a/test/wscript b/test/wscript index db773fb46..34f6c84ab 100644 --- a/test/wscript +++ b/test/wscript @@ -76,6 +76,7 @@ def build(bld): file_log_test.cc file_naming_test.cc film_metadata_test.cc + frame_interval_checker_test.cc frame_rate_test.cc image_content_fade_test.cc image_filename_sorter_test.cc |
