X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fdcpomatic_time_test.cc;h=38b4d31a99c74d880e81c6e7969264ed07811683;hb=3b00a59febd1920037cb0a6027b3757edaaaff2b;hp=f49d29a57caae5c7c77a046acea746c0ce82e9b4;hpb=67a68bd971ebe1b35daa3f75873b4ccb53c00ba0;p=dcpomatic.git diff --git a/test/dcpomatic_time_test.cc b/test/dcpomatic_time_test.cc index f49d29a57..38b4d31a9 100644 --- a/test/dcpomatic_time_test.cc +++ b/test/dcpomatic_time_test.cc @@ -24,10 +24,13 @@ */ #include "lib/dcpomatic_time.h" +#include "lib/dcpomatic_time_coalesce.h" #include #include +#include using std::list; +using std::cout; BOOST_AUTO_TEST_CASE (dcpomatic_time_test) { @@ -214,3 +217,86 @@ BOOST_AUTO_TEST_CASE (dcpomatic_time_period_subtract_test7) ++i; BOOST_REQUIRE (i == r.end ()); } + +BOOST_AUTO_TEST_CASE (dcpomatic_time_period_subtract_test8) +{ + DCPTimePeriod A (DCPTime(0), DCPTime(32000)); + list B; + B.push_back (DCPTimePeriod (DCPTime(8000), DCPTime(20000))); + B.push_back (DCPTimePeriod (DCPTime(28000), DCPTime(32000))); + list r = subtract (A, B); + list::const_iterator i = r.begin (); + BOOST_REQUIRE (i != r.end ()); + BOOST_CHECK (*i == DCPTimePeriod(DCPTime(0), DCPTime(8000))); + ++i; + BOOST_REQUIRE (i != r.end ()); + BOOST_CHECK (*i == DCPTimePeriod(DCPTime(20000), DCPTime(28000))); + ++i; + BOOST_REQUIRE (i == r.end ()); +} + +BOOST_AUTO_TEST_CASE (dcpomatic_time_period_coalesce_test1) +{ + DCPTimePeriod A (DCPTime(14), DCPTime(29)); + DCPTimePeriod B (DCPTime(45), DCPTime(91)); + list p; + p.push_back (A); + p.push_back (B); + list q = coalesce (p); + BOOST_REQUIRE_EQUAL (q.size(), 2); + BOOST_CHECK (q.front() == DCPTimePeriod(DCPTime(14), DCPTime(29))); + BOOST_CHECK (q.back () == DCPTimePeriod(DCPTime(45), DCPTime(91))); +} + +BOOST_AUTO_TEST_CASE (dcpomatic_time_period_coalesce_test2) +{ + DCPTimePeriod A (DCPTime(14), DCPTime(29)); + DCPTimePeriod B (DCPTime(26), DCPTime(91)); + list p; + p.push_back (A); + p.push_back (B); + list q = coalesce (p); + BOOST_REQUIRE_EQUAL (q.size(), 1); + BOOST_CHECK (q.front() == DCPTimePeriod(DCPTime(14), DCPTime(91))); +} + +BOOST_AUTO_TEST_CASE (dcpomatic_time_period_coalesce_test3) +{ + DCPTimePeriod A (DCPTime(14), DCPTime(29)); + DCPTimePeriod B (DCPTime(29), DCPTime(91)); + list p; + p.push_back (A); + p.push_back (B); + list q = coalesce (p); + BOOST_REQUIRE_EQUAL (q.size(), 1); + BOOST_CHECK (q.front() == DCPTimePeriod(DCPTime(14), DCPTime(91))); +} + +BOOST_AUTO_TEST_CASE (dcpomatic_time_period_coalesce_test4) +{ + DCPTimePeriod A (DCPTime(14), DCPTime(29)); + DCPTimePeriod B (DCPTime(20), DCPTime(91)); + DCPTimePeriod C (DCPTime(35), DCPTime(106)); + list p; + p.push_back (A); + p.push_back (B); + p.push_back (C); + list q = coalesce (p); + BOOST_REQUIRE_EQUAL (q.size(), 1); + BOOST_CHECK (q.front() == DCPTimePeriod(DCPTime(14), DCPTime(106))); +} + +BOOST_AUTO_TEST_CASE (dcpomatic_time_period_coalesce_test5) +{ + DCPTimePeriod A (DCPTime(14), DCPTime(29)); + DCPTimePeriod B (DCPTime(20), DCPTime(91)); + DCPTimePeriod C (DCPTime(100), DCPTime(106)); + list p; + p.push_back (A); + p.push_back (B); + p.push_back (C); + list q = coalesce (p); + BOOST_REQUIRE_EQUAL (q.size(), 2); + BOOST_CHECK (q.front() == DCPTimePeriod(DCPTime(14), DCPTime(91))); + BOOST_CHECK (q.back() == DCPTimePeriod(DCPTime(100), DCPTime(106))); +}