X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fdcp_time_test.cc;h=0ebddb29ddf1b4701c3fc67ed9efbb5d69c1753b;hb=287d8bb5eb247e8746718a919091fff09b0b624d;hp=52ff43c67df6e1bbcb039a6caa44359406d79abf;hpb=6d7dc1a2b650a74f23b772d215bb43d5f7b3e173;p=libdcp.git diff --git a/test/dcp_time_test.cc b/test/dcp_time_test.cc index 52ff43c6..0ebddb29 100644 --- a/test/dcp_time_test.cc +++ b/test/dcp_time_test.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2015 Carl Hetherington This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -23,65 +23,69 @@ /** Check that libdcp::Time works */ BOOST_AUTO_TEST_CASE (dcp_time) { - libdcp::Time t (977143, 24); + /* tcr of 250 makes the editable event length the same as an Interop `tick' */ + libdcp::Time t (977143, 24, 250); - BOOST_CHECK_EQUAL (t.t, 73); + BOOST_CHECK_EQUAL (t.e, 73); BOOST_CHECK_EQUAL (t.s, 34); BOOST_CHECK_EQUAL (t.m, 18); BOOST_CHECK_EQUAL (t.h, 11); BOOST_CHECK_EQUAL (t.to_string(), "11:18:34:73"); - BOOST_CHECK_EQUAL (t.to_ticks(), 10178573); - libdcp::Time a (3, 2, 3, 4); - libdcp::Time b (2, 3, 4, 5); + /* Use a tcr of 24 so that the editable event is a frame */ + libdcp::Time a (3, 2, 3, 4, 24); + libdcp::Time b (2, 3, 4, 5, 24); libdcp::Time r = a - b; BOOST_CHECK_EQUAL (r.h, 0); BOOST_CHECK_EQUAL (r.m, 58); BOOST_CHECK_EQUAL (r.s, 58); - BOOST_CHECK_EQUAL (r.t, 249); - BOOST_CHECK_EQUAL (r.to_string(), "0:58:58:249"); - BOOST_CHECK_EQUAL (r.to_ticks(), 884749); + BOOST_CHECK_EQUAL (r.e, 23); + BOOST_CHECK_EQUAL (r.to_string(), "0:58:58:23"); - a = libdcp::Time (1, 58, 56, 240); - b = libdcp::Time (1, 7, 12, 120); + /* Different tcr (25) */ + a = libdcp::Time (1, 58, 56, 2, 25); + b = libdcp::Time (1, 7, 12, 1, 25); r = a + b; BOOST_CHECK_EQUAL (r.h, 3); BOOST_CHECK_EQUAL (r.m, 6); - BOOST_CHECK_EQUAL (r.s, 9); - BOOST_CHECK_EQUAL (r.t, 110); - BOOST_CHECK_EQUAL (r.to_string(), "3:6:9:110"); - BOOST_CHECK_EQUAL (r.to_ticks(), 2792360); + BOOST_CHECK_EQUAL (r.s, 8); + BOOST_CHECK_EQUAL (r.e, 3); + BOOST_CHECK_EQUAL (r.to_string(), "3:6:8:3"); - a = libdcp::Time (24, 12, 6, 3); - b = libdcp::Time (16, 8, 4, 2); + /* Another arbitrary tcr (30) */ + a = libdcp::Time (24, 12, 6, 3, 30); + b = libdcp::Time (16, 8, 4, 2, 30); BOOST_CHECK_CLOSE (a / b, 1.5, 1e-5); - BOOST_CHECK_EQUAL (libdcp::Time (4128391203LL).to_ticks(), 4128391203LL); - BOOST_CHECK_EQUAL (libdcp::Time (60000).to_ticks(), 60000); - - a = libdcp::Time (3600 * 24, 24); + a = libdcp::Time (3600 * 24, 24, 250); BOOST_CHECK_EQUAL (a.h, 1); BOOST_CHECK_EQUAL (a.m, 0); BOOST_CHECK_EQUAL (a.s, 0); - BOOST_CHECK_EQUAL (a.t, 0); + BOOST_CHECK_EQUAL (a.e, 0); - a = libdcp::Time (60 * 24, 24); + a = libdcp::Time (60 * 24, 24, 250); BOOST_CHECK_EQUAL (a.h, 0); BOOST_CHECK_EQUAL (a.m, 1); BOOST_CHECK_EQUAL (a.s, 0); - BOOST_CHECK_EQUAL (a.t, 0); + BOOST_CHECK_EQUAL (a.e, 0); /* Check rounding; 3424 is 142.666666666... seconds or 0.166666666... ticks */ - a = libdcp::Time (3424, 24); + a = libdcp::Time (3424, 24, 250); BOOST_CHECK_EQUAL (a.h, 0); BOOST_CHECK_EQUAL (a.m, 2); BOOST_CHECK_EQUAL (a.s, 22); - BOOST_CHECK_EQUAL (a.t, 167); + BOOST_CHECK_EQUAL (a.e, 167); - a = libdcp::Time (3425, 24); + a = libdcp::Time (3425, 24, 250); BOOST_CHECK_EQUAL (a.h, 0); BOOST_CHECK_EQUAL (a.m, 2); BOOST_CHECK_EQUAL (a.s, 22); - BOOST_CHECK_EQUAL (a.t, 177); + BOOST_CHECK_EQUAL (a.e, 177); + + /* Check addition of times with different tcrs */ + a = libdcp::Time (0, 0, 0, 3, 24); + b = libdcp::Time (0, 0, 0, 4, 48); + r = a + b; + BOOST_CHECK_EQUAL (r, libdcp::Time (0, 0, 0, 240, 1152)); }