xref: /freebsd/contrib/kyua/utils/stream_test.cpp (revision b0d29bc4)
1*b0d29bc4SBrooks Davis // Copyright 2011 The Kyua Authors.
2*b0d29bc4SBrooks Davis // All rights reserved.
3*b0d29bc4SBrooks Davis //
4*b0d29bc4SBrooks Davis // Redistribution and use in source and binary forms, with or without
5*b0d29bc4SBrooks Davis // modification, are permitted provided that the following conditions are
6*b0d29bc4SBrooks Davis // met:
7*b0d29bc4SBrooks Davis //
8*b0d29bc4SBrooks Davis // * Redistributions of source code must retain the above copyright
9*b0d29bc4SBrooks Davis //   notice, this list of conditions and the following disclaimer.
10*b0d29bc4SBrooks Davis // * Redistributions in binary form must reproduce the above copyright
11*b0d29bc4SBrooks Davis //   notice, this list of conditions and the following disclaimer in the
12*b0d29bc4SBrooks Davis //   documentation and/or other materials provided with the distribution.
13*b0d29bc4SBrooks Davis // * Neither the name of Google Inc. nor the names of its contributors
14*b0d29bc4SBrooks Davis //   may be used to endorse or promote products derived from this software
15*b0d29bc4SBrooks Davis //   without specific prior written permission.
16*b0d29bc4SBrooks Davis //
17*b0d29bc4SBrooks Davis // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18*b0d29bc4SBrooks Davis // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19*b0d29bc4SBrooks Davis // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20*b0d29bc4SBrooks Davis // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21*b0d29bc4SBrooks Davis // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22*b0d29bc4SBrooks Davis // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23*b0d29bc4SBrooks Davis // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24*b0d29bc4SBrooks Davis // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25*b0d29bc4SBrooks Davis // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26*b0d29bc4SBrooks Davis // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27*b0d29bc4SBrooks Davis // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*b0d29bc4SBrooks Davis 
29*b0d29bc4SBrooks Davis #include "utils/stream.hpp"
30*b0d29bc4SBrooks Davis 
31*b0d29bc4SBrooks Davis #include <cstdlib>
32*b0d29bc4SBrooks Davis #include <sstream>
33*b0d29bc4SBrooks Davis 
34*b0d29bc4SBrooks Davis #include <atf-c++.hpp>
35*b0d29bc4SBrooks Davis 
36*b0d29bc4SBrooks Davis #include "utils/fs/path.hpp"
37*b0d29bc4SBrooks Davis 
38*b0d29bc4SBrooks Davis namespace fs = utils::fs;
39*b0d29bc4SBrooks Davis 
40*b0d29bc4SBrooks Davis 
41*b0d29bc4SBrooks Davis ATF_TEST_CASE_WITHOUT_HEAD(open_ostream__stdout);
ATF_TEST_CASE_BODY(open_ostream__stdout)42*b0d29bc4SBrooks Davis ATF_TEST_CASE_BODY(open_ostream__stdout)
43*b0d29bc4SBrooks Davis {
44*b0d29bc4SBrooks Davis     const pid_t pid = atf::utils::fork();
45*b0d29bc4SBrooks Davis     if (pid == 0) {
46*b0d29bc4SBrooks Davis         std::auto_ptr< std::ostream > output = utils::open_ostream(
47*b0d29bc4SBrooks Davis             fs::path("/dev/stdout"));
48*b0d29bc4SBrooks Davis         (*output) << "Message to stdout\n";
49*b0d29bc4SBrooks Davis         output.reset();
50*b0d29bc4SBrooks Davis         std::exit(EXIT_SUCCESS);
51*b0d29bc4SBrooks Davis     }
52*b0d29bc4SBrooks Davis     atf::utils::wait(pid, EXIT_SUCCESS, "Message to stdout\n", "");
53*b0d29bc4SBrooks Davis }
54*b0d29bc4SBrooks Davis 
55*b0d29bc4SBrooks Davis 
56*b0d29bc4SBrooks Davis ATF_TEST_CASE_WITHOUT_HEAD(open_ostream__stderr);
ATF_TEST_CASE_BODY(open_ostream__stderr)57*b0d29bc4SBrooks Davis ATF_TEST_CASE_BODY(open_ostream__stderr)
58*b0d29bc4SBrooks Davis {
59*b0d29bc4SBrooks Davis     const pid_t pid = atf::utils::fork();
60*b0d29bc4SBrooks Davis     if (pid == 0) {
61*b0d29bc4SBrooks Davis         std::auto_ptr< std::ostream > output = utils::open_ostream(
62*b0d29bc4SBrooks Davis             fs::path("/dev/stderr"));
63*b0d29bc4SBrooks Davis         (*output) << "Message to stderr\n";
64*b0d29bc4SBrooks Davis         output.reset();
65*b0d29bc4SBrooks Davis         std::exit(EXIT_SUCCESS);
66*b0d29bc4SBrooks Davis     }
67*b0d29bc4SBrooks Davis     atf::utils::wait(pid, EXIT_SUCCESS, "", "Message to stderr\n");
68*b0d29bc4SBrooks Davis }
69*b0d29bc4SBrooks Davis 
70*b0d29bc4SBrooks Davis 
71*b0d29bc4SBrooks Davis ATF_TEST_CASE_WITHOUT_HEAD(open_ostream__other);
ATF_TEST_CASE_BODY(open_ostream__other)72*b0d29bc4SBrooks Davis ATF_TEST_CASE_BODY(open_ostream__other)
73*b0d29bc4SBrooks Davis {
74*b0d29bc4SBrooks Davis     const pid_t pid = atf::utils::fork();
75*b0d29bc4SBrooks Davis     if (pid == 0) {
76*b0d29bc4SBrooks Davis         std::auto_ptr< std::ostream > output = utils::open_ostream(
77*b0d29bc4SBrooks Davis             fs::path("some-file.txt"));
78*b0d29bc4SBrooks Davis         (*output) << "Message to other file\n";
79*b0d29bc4SBrooks Davis         output.reset();
80*b0d29bc4SBrooks Davis         std::exit(EXIT_SUCCESS);
81*b0d29bc4SBrooks Davis     }
82*b0d29bc4SBrooks Davis     atf::utils::wait(pid, EXIT_SUCCESS, "", "");
83*b0d29bc4SBrooks Davis     atf::utils::compare_file("some-file.txt", "Message to other file\n");
84*b0d29bc4SBrooks Davis }
85*b0d29bc4SBrooks Davis 
86*b0d29bc4SBrooks Davis 
87*b0d29bc4SBrooks Davis ATF_TEST_CASE_WITHOUT_HEAD(stream_length__empty);
ATF_TEST_CASE_BODY(stream_length__empty)88*b0d29bc4SBrooks Davis ATF_TEST_CASE_BODY(stream_length__empty)
89*b0d29bc4SBrooks Davis {
90*b0d29bc4SBrooks Davis     std::istringstream input("");
91*b0d29bc4SBrooks Davis     ATF_REQUIRE_EQ(0, utils::stream_length(input));
92*b0d29bc4SBrooks Davis }
93*b0d29bc4SBrooks Davis 
94*b0d29bc4SBrooks Davis 
95*b0d29bc4SBrooks Davis ATF_TEST_CASE_WITHOUT_HEAD(stream_length__some);
ATF_TEST_CASE_BODY(stream_length__some)96*b0d29bc4SBrooks Davis ATF_TEST_CASE_BODY(stream_length__some)
97*b0d29bc4SBrooks Davis {
98*b0d29bc4SBrooks Davis     const std::string contents(8192, 'x');
99*b0d29bc4SBrooks Davis     std::istringstream input(contents);
100*b0d29bc4SBrooks Davis     ATF_REQUIRE_EQ(
101*b0d29bc4SBrooks Davis         contents.length(),
102*b0d29bc4SBrooks Davis         static_cast< std::string::size_type >(utils::stream_length(input)));
103*b0d29bc4SBrooks Davis }
104*b0d29bc4SBrooks Davis 
105*b0d29bc4SBrooks Davis 
106*b0d29bc4SBrooks Davis ATF_TEST_CASE_WITHOUT_HEAD(read_file__ok);
ATF_TEST_CASE_BODY(read_file__ok)107*b0d29bc4SBrooks Davis ATF_TEST_CASE_BODY(read_file__ok)
108*b0d29bc4SBrooks Davis {
109*b0d29bc4SBrooks Davis     const char* contents = "These are\nsome file contents";
110*b0d29bc4SBrooks Davis     atf::utils::create_file("input.txt", contents);
111*b0d29bc4SBrooks Davis     ATF_REQUIRE_EQ(contents, utils::read_file(fs::path("input.txt")));
112*b0d29bc4SBrooks Davis }
113*b0d29bc4SBrooks Davis 
114*b0d29bc4SBrooks Davis 
115*b0d29bc4SBrooks Davis ATF_TEST_CASE_WITHOUT_HEAD(read_file__missing_file);
ATF_TEST_CASE_BODY(read_file__missing_file)116*b0d29bc4SBrooks Davis ATF_TEST_CASE_BODY(read_file__missing_file)
117*b0d29bc4SBrooks Davis {
118*b0d29bc4SBrooks Davis     ATF_REQUIRE_THROW_RE(std::runtime_error,
119*b0d29bc4SBrooks Davis                          "Failed to open 'foo.txt' for read",
120*b0d29bc4SBrooks Davis                          utils::read_file(fs::path("foo.txt")));
121*b0d29bc4SBrooks Davis }
122*b0d29bc4SBrooks Davis 
123*b0d29bc4SBrooks Davis 
124*b0d29bc4SBrooks Davis ATF_TEST_CASE_WITHOUT_HEAD(read_stream__empty);
ATF_TEST_CASE_BODY(read_stream__empty)125*b0d29bc4SBrooks Davis ATF_TEST_CASE_BODY(read_stream__empty)
126*b0d29bc4SBrooks Davis {
127*b0d29bc4SBrooks Davis     std::istringstream input("");
128*b0d29bc4SBrooks Davis     ATF_REQUIRE_EQ("", utils::read_stream(input));
129*b0d29bc4SBrooks Davis }
130*b0d29bc4SBrooks Davis 
131*b0d29bc4SBrooks Davis 
132*b0d29bc4SBrooks Davis ATF_TEST_CASE_WITHOUT_HEAD(read_stream__some);
ATF_TEST_CASE_BODY(read_stream__some)133*b0d29bc4SBrooks Davis ATF_TEST_CASE_BODY(read_stream__some)
134*b0d29bc4SBrooks Davis {
135*b0d29bc4SBrooks Davis     std::string contents;
136*b0d29bc4SBrooks Davis     for (int i = 0; i < 1000; i++)
137*b0d29bc4SBrooks Davis         contents += "abcdef";
138*b0d29bc4SBrooks Davis     std::istringstream input(contents);
139*b0d29bc4SBrooks Davis     ATF_REQUIRE_EQ(contents, utils::read_stream(input));
140*b0d29bc4SBrooks Davis }
141*b0d29bc4SBrooks Davis 
142*b0d29bc4SBrooks Davis 
ATF_INIT_TEST_CASES(tcs)143*b0d29bc4SBrooks Davis ATF_INIT_TEST_CASES(tcs)
144*b0d29bc4SBrooks Davis {
145*b0d29bc4SBrooks Davis     ATF_ADD_TEST_CASE(tcs, open_ostream__stdout);
146*b0d29bc4SBrooks Davis     ATF_ADD_TEST_CASE(tcs, open_ostream__stderr);
147*b0d29bc4SBrooks Davis     ATF_ADD_TEST_CASE(tcs, open_ostream__other);
148*b0d29bc4SBrooks Davis 
149*b0d29bc4SBrooks Davis     ATF_ADD_TEST_CASE(tcs, stream_length__empty);
150*b0d29bc4SBrooks Davis     ATF_ADD_TEST_CASE(tcs, stream_length__some);
151*b0d29bc4SBrooks Davis 
152*b0d29bc4SBrooks Davis     ATF_ADD_TEST_CASE(tcs, read_file__ok);
153*b0d29bc4SBrooks Davis     ATF_ADD_TEST_CASE(tcs, read_file__missing_file);
154*b0d29bc4SBrooks Davis 
155*b0d29bc4SBrooks Davis     ATF_ADD_TEST_CASE(tcs, read_stream__empty);
156*b0d29bc4SBrooks Davis     ATF_ADD_TEST_CASE(tcs, read_stream__some);
157*b0d29bc4SBrooks Davis }
158