Merge master.
[dcpomatic.git] / test / util_test.cc
1 /*
2     Copyright (C) 2012-2014 Carl Hetherington <cth@carlh.net>
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
18 */
19
20 /** @file  test/util_test.cc
21  *  @brief Test various utility methods.
22  */
23
24 #include <boost/test/unit_test.hpp>
25 #include "lib/util.h"
26 #include "lib/exceptions.h"
27
28 using std::string;
29 using std::vector;
30 using boost::shared_ptr;
31
32 BOOST_AUTO_TEST_CASE (split_at_spaces_considering_quotes_test)
33 {
34         string t = "Hello this is a string \"with quotes\" and indeed without them";
35         vector<string> b = split_at_spaces_considering_quotes (t);
36         vector<string>::iterator i = b.begin ();
37         BOOST_CHECK_EQUAL (*i++, "Hello");
38         BOOST_CHECK_EQUAL (*i++, "this");
39         BOOST_CHECK_EQUAL (*i++, "is");
40         BOOST_CHECK_EQUAL (*i++, "a");
41         BOOST_CHECK_EQUAL (*i++, "string");
42         BOOST_CHECK_EQUAL (*i++, "with quotes");
43         BOOST_CHECK_EQUAL (*i++, "and");
44         BOOST_CHECK_EQUAL (*i++, "indeed");
45         BOOST_CHECK_EQUAL (*i++, "without");
46         BOOST_CHECK_EQUAL (*i++, "them");
47 }
48
49 BOOST_AUTO_TEST_CASE (md5_digest_test)
50 {
51         vector<boost::filesystem::path> p;
52         p.push_back ("test/data/md5.test");
53         string const t = md5_digest (p, shared_ptr<Job> ());
54         BOOST_CHECK_EQUAL (t, "15058685ba99decdc4398c7634796eb0");
55
56         p.clear ();
57         p.push_back ("foobar");
58         BOOST_CHECK_THROW (md5_digest (p, shared_ptr<Job> ()), std::runtime_error);
59 }
60
61 /* Straightforward test of DCPTime::round_up */
62 BOOST_AUTO_TEST_CASE (dcptime_round_up_test)
63 {
64         BOOST_CHECK_EQUAL (DCPTime (0).round_up (DCPTime::HZ / 2), DCPTime (0));
65         BOOST_CHECK_EQUAL (DCPTime (1).round_up (DCPTime::HZ / 2), DCPTime (2));
66         BOOST_CHECK_EQUAL (DCPTime (2).round_up (DCPTime::HZ / 2), DCPTime (2));
67         BOOST_CHECK_EQUAL (DCPTime (3).round_up (DCPTime::HZ / 2), DCPTime (4));
68         
69         BOOST_CHECK_EQUAL (DCPTime (0).round_up (DCPTime::HZ / 42), DCPTime (0));
70         BOOST_CHECK_EQUAL (DCPTime (1).round_up (DCPTime::HZ / 42), DCPTime (42));
71         BOOST_CHECK_EQUAL (DCPTime (42).round_up (DCPTime::HZ / 42), DCPTime (42));
72         BOOST_CHECK_EQUAL (DCPTime (43).round_up (DCPTime::HZ / 42), DCPTime (84));
73
74         /* Check that rounding up to non-integer frame rates works */
75         BOOST_CHECK_EQUAL (DCPTime (45312).round_up (29.976), DCPTime (48045));
76 }
77
78
79 BOOST_AUTO_TEST_CASE (divide_with_round_test)
80 {
81         BOOST_CHECK_EQUAL (divide_with_round (0, 4), 0);
82         BOOST_CHECK_EQUAL (divide_with_round (1, 4), 0);
83         BOOST_CHECK_EQUAL (divide_with_round (2, 4), 1);
84         BOOST_CHECK_EQUAL (divide_with_round (3, 4), 1);
85         BOOST_CHECK_EQUAL (divide_with_round (4, 4), 1);
86         BOOST_CHECK_EQUAL (divide_with_round (5, 4), 1);
87         BOOST_CHECK_EQUAL (divide_with_round (6, 4), 2);
88
89         BOOST_CHECK_EQUAL (divide_with_round (1000, 500), 2);
90 }
91
92 BOOST_AUTO_TEST_CASE (timecode_test)
93 {
94         DCPTime t = DCPTime::from_seconds (2 * 60 * 60 + 4 * 60 + 31) + DCPTime::from_frames (19, 24);
95         BOOST_CHECK_EQUAL (t.timecode (24), "02:04:31:19");
96 }