Remove unnecessary include.
[libdcp.git] / test / test.cc
1 /*
2     Copyright (C) 2012-2015 Carl Hetherington <cth@carlh.net>
3
4     This file is part of libdcp.
5
6     libdcp is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     libdcp is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with libdcp.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #define BOOST_TEST_DYN_LINK
21 #define BOOST_TEST_MODULE libdcp_test
22 #include "util.h"
23 #include "test.h"
24 #include <libxml++/libxml++.h>
25 #include <boost/test/unit_test.hpp>
26 #include <cstdio>
27
28 using std::string;
29 using std::min;
30 using std::list;
31
32 boost::filesystem::path private_test;
33
34 struct TestConfig
35 {
36         TestConfig()
37         {
38                 dcp::init ();
39                 if (boost::unit_test::framework::master_test_suite().argc >= 2) {
40                         private_test = boost::unit_test::framework::master_test_suite().argv[1];
41                 }
42         }
43 };
44
45 void
46 check_xml (xmlpp::Element* ref, xmlpp::Element* test, list<string> ignore)
47 {
48         BOOST_CHECK_EQUAL (ref->get_name (), test->get_name ());
49         BOOST_CHECK_EQUAL (ref->get_namespace_prefix (), test->get_namespace_prefix ());
50
51         if (find (ignore.begin(), ignore.end(), ref->get_name()) != ignore.end ()) {
52                 return;
53         }
54
55         xmlpp::Element::NodeList ref_children = ref->get_children ();
56         xmlpp::Element::NodeList test_children = test->get_children ();
57         BOOST_REQUIRE_EQUAL (ref_children.size (), test_children.size ());
58
59         xmlpp::Element::NodeList::iterator k = ref_children.begin ();
60         xmlpp::Element::NodeList::iterator l = test_children.begin ();
61         while (k != ref_children.end ()) {
62
63                 /* XXX: should be doing xmlpp::EntityReference, xmlpp::XIncludeEnd, xmlpp::XIncludeStart */
64
65                 xmlpp::Element* ref_el = dynamic_cast<xmlpp::Element*> (*k);
66                 xmlpp::Element* test_el = dynamic_cast<xmlpp::Element*> (*l);
67                 BOOST_CHECK ((ref_el && test_el) || (!ref_el && !test_el));
68                 if (ref_el && test_el) {
69                         check_xml (ref_el, test_el, ignore);
70                 }
71
72                 xmlpp::ContentNode* ref_cn = dynamic_cast<xmlpp::ContentNode*> (*k);
73                 xmlpp::ContentNode* test_cn = dynamic_cast<xmlpp::ContentNode*> (*l);
74                 BOOST_CHECK ((ref_cn && test_cn) || (!ref_cn && !test_cn));
75                 if (ref_cn && test_cn) {
76                         BOOST_CHECK_EQUAL (ref_cn->get_content(), test_cn->get_content ());
77                 }
78
79                 ++k;
80                 ++l;
81         }
82
83         xmlpp::Element::AttributeList ref_attributes = ref->get_attributes ();
84         xmlpp::Element::AttributeList test_attributes = test->get_attributes ();
85         BOOST_CHECK_EQUAL (ref_attributes.size(), test_attributes.size ());
86
87         xmlpp::Element::AttributeList::const_iterator m = ref_attributes.begin();
88         xmlpp::Element::AttributeList::const_iterator n = test_attributes.begin();
89         while (m != ref_attributes.end ()) {
90                 BOOST_CHECK_EQUAL ((*m)->get_name(), (*n)->get_name());
91                 BOOST_CHECK_EQUAL ((*m)->get_value(), (*n)->get_value());
92
93                 ++m;
94                 ++n;
95         }
96 }
97
98 void
99 check_xml (string ref, string test, list<string> ignore)
100 {
101         xmlpp::DomParser* ref_parser = new xmlpp::DomParser ();
102         ref_parser->parse_memory (ref);
103         xmlpp::Element* ref_root = ref_parser->get_document()->get_root_node ();
104         xmlpp::DomParser* test_parser = new xmlpp::DomParser ();
105         test_parser->parse_memory (test);
106         xmlpp::Element* test_root = test_parser->get_document()->get_root_node ();
107
108         check_xml (ref_root, test_root, ignore);
109 }
110
111 void
112 check_file (boost::filesystem::path ref, boost::filesystem::path check)
113 {
114         uintmax_t N = boost::filesystem::file_size (ref);
115         BOOST_CHECK_EQUAL (N, boost::filesystem::file_size (check));
116         FILE* ref_file = dcp::fopen_boost (ref, "rb");
117         BOOST_CHECK (ref_file);
118         FILE* check_file = dcp::fopen_boost (check, "rb");
119         BOOST_CHECK (check_file);
120
121         int const buffer_size = 65536;
122         uint8_t* ref_buffer = new uint8_t[buffer_size];
123         uint8_t* check_buffer = new uint8_t[buffer_size];
124
125         string error;
126         error = "File " + check.string() + " differs from reference " + ref.string();
127
128         while (N) {
129                 uintmax_t this_time = min (uintmax_t (buffer_size), N);
130                 size_t r = fread (ref_buffer, 1, this_time, ref_file);
131                 BOOST_CHECK_EQUAL (r, this_time);
132                 r = fread (check_buffer, 1, this_time, check_file);
133                 BOOST_CHECK_EQUAL (r, this_time);
134
135                 BOOST_CHECK_MESSAGE (memcmp (ref_buffer, check_buffer, this_time) == 0, error);
136                 if (memcmp (ref_buffer, check_buffer, this_time)) {
137                         break;
138                 }
139
140                 N -= this_time;
141         }
142
143         delete[] ref_buffer;
144         delete[] check_buffer;
145
146         fclose (ref_file);
147         fclose (check_file);
148 }
149
150 BOOST_GLOBAL_FIXTURE (TestConfig);