Merge branch 'master' into 12bit
[dcpomatic.git] / test / util_test.cc
1 /*
2     Copyright (C) 2012 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 #include <boost/test/unit_test.hpp>
21 #include "lib/util.h"
22 #include "lib/exceptions.h"
23
24 using std::string;
25 using std::vector;
26 using boost::shared_ptr;
27
28 BOOST_AUTO_TEST_CASE (split_at_spaces_considering_quotes_test)
29 {
30         string t = "Hello this is a string \"with quotes\" and indeed without them";
31         vector<string> b = split_at_spaces_considering_quotes (t);
32         vector<string>::iterator i = b.begin ();
33         BOOST_CHECK_EQUAL (*i++, "Hello");
34         BOOST_CHECK_EQUAL (*i++, "this");
35         BOOST_CHECK_EQUAL (*i++, "is");
36         BOOST_CHECK_EQUAL (*i++, "a");
37         BOOST_CHECK_EQUAL (*i++, "string");
38         BOOST_CHECK_EQUAL (*i++, "with quotes");
39         BOOST_CHECK_EQUAL (*i++, "and");
40         BOOST_CHECK_EQUAL (*i++, "indeed");
41         BOOST_CHECK_EQUAL (*i++, "without");
42         BOOST_CHECK_EQUAL (*i++, "them");
43 }
44
45 BOOST_AUTO_TEST_CASE (md5_digest_test)
46 {
47         vector<boost::filesystem::path> p;
48         p.push_back ("test/data/md5.test");
49         string const t = md5_digest (p, shared_ptr<Job> ());
50         BOOST_CHECK_EQUAL (t, "15058685ba99decdc4398c7634796eb0");
51
52         p.clear ();
53         p.push_back ("foobar");
54         BOOST_CHECK_THROW (md5_digest (p, shared_ptr<Job> ()), std::runtime_error);
55 }
56
57 BOOST_AUTO_TEST_CASE (divide_with_round_test)
58 {
59         BOOST_CHECK_EQUAL (divide_with_round (0, 4), 0);
60         BOOST_CHECK_EQUAL (divide_with_round (1, 4), 0);
61         BOOST_CHECK_EQUAL (divide_with_round (2, 4), 1);
62         BOOST_CHECK_EQUAL (divide_with_round (3, 4), 1);
63         BOOST_CHECK_EQUAL (divide_with_round (4, 4), 1);
64         BOOST_CHECK_EQUAL (divide_with_round (5, 4), 1);
65         BOOST_CHECK_EQUAL (divide_with_round (6, 4), 2);
66
67         BOOST_CHECK_EQUAL (divide_with_round (1000, 500), 2);
68 }
69
70 BOOST_AUTO_TEST_CASE (seconds_to_approximate_hms_test)
71 {
72         BOOST_CHECK_EQUAL (seconds_to_approximate_hms (1), "1 second");
73         BOOST_CHECK_EQUAL (seconds_to_approximate_hms (2), "2 seconds");
74         BOOST_CHECK_EQUAL (seconds_to_approximate_hms (60), "1 minute");
75         BOOST_CHECK_EQUAL (seconds_to_approximate_hms (1.5 * 60), "1 minute 30 seconds");
76         BOOST_CHECK_EQUAL (seconds_to_approximate_hms (2 * 60), "2 minutes");
77         BOOST_CHECK_EQUAL (seconds_to_approximate_hms (17 * 60 + 20), "17 minutes");
78         BOOST_CHECK_EQUAL (seconds_to_approximate_hms (1 * 3600), "1 hour");
79         BOOST_CHECK_EQUAL (seconds_to_approximate_hms (3600 + 40 * 60), "1 hour 40 minutes");
80         BOOST_CHECK_EQUAL (seconds_to_approximate_hms (13 * 3600 + 40 * 60), "14 hours");
81 }