1*b0d29bc4SBrooks Davis // Copyright 2010 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/cmdline/ui_mock.hpp"
30*b0d29bc4SBrooks Davis
31*b0d29bc4SBrooks Davis #include <iostream>
32*b0d29bc4SBrooks Davis
33*b0d29bc4SBrooks Davis #include "utils/optional.ipp"
34*b0d29bc4SBrooks Davis
35*b0d29bc4SBrooks Davis using utils::cmdline::ui_mock;
36*b0d29bc4SBrooks Davis using utils::none;
37*b0d29bc4SBrooks Davis using utils::optional;
38*b0d29bc4SBrooks Davis
39*b0d29bc4SBrooks Davis
40*b0d29bc4SBrooks Davis /// Constructs a new mock UI.
41*b0d29bc4SBrooks Davis ///
42*b0d29bc4SBrooks Davis /// \param screen_width_ The width of the screen to use for testing purposes.
43*b0d29bc4SBrooks Davis /// Defaults to 0 to prevent uncontrolled wrapping on our tests.
ui_mock(const std::size_t screen_width_)44*b0d29bc4SBrooks Davis ui_mock::ui_mock(const std::size_t screen_width_) :
45*b0d29bc4SBrooks Davis _screen_width(screen_width_)
46*b0d29bc4SBrooks Davis {
47*b0d29bc4SBrooks Davis }
48*b0d29bc4SBrooks Davis
49*b0d29bc4SBrooks Davis
50*b0d29bc4SBrooks Davis /// Writes a line to stderr and records it for further inspection.
51*b0d29bc4SBrooks Davis ///
52*b0d29bc4SBrooks Davis /// \param message The line to print and record, without the trailing newline
53*b0d29bc4SBrooks Davis /// character.
54*b0d29bc4SBrooks Davis /// \param newline Whether to append a newline to the message or not.
55*b0d29bc4SBrooks Davis void
err(const std::string & message,const bool newline)56*b0d29bc4SBrooks Davis ui_mock::err(const std::string& message, const bool newline)
57*b0d29bc4SBrooks Davis {
58*b0d29bc4SBrooks Davis if (newline)
59*b0d29bc4SBrooks Davis std::cerr << message << "\n";
60*b0d29bc4SBrooks Davis else {
61*b0d29bc4SBrooks Davis std::cerr << message << "\n";
62*b0d29bc4SBrooks Davis std::cerr.flush();
63*b0d29bc4SBrooks Davis }
64*b0d29bc4SBrooks Davis _err_log.push_back(message);
65*b0d29bc4SBrooks Davis }
66*b0d29bc4SBrooks Davis
67*b0d29bc4SBrooks Davis
68*b0d29bc4SBrooks Davis /// Writes a line to stdout and records it for further inspection.
69*b0d29bc4SBrooks Davis ///
70*b0d29bc4SBrooks Davis /// \param message The line to print and record, without the trailing newline
71*b0d29bc4SBrooks Davis /// character.
72*b0d29bc4SBrooks Davis /// \param newline Whether to append a newline to the message or not.
73*b0d29bc4SBrooks Davis void
out(const std::string & message,const bool newline)74*b0d29bc4SBrooks Davis ui_mock::out(const std::string& message, const bool newline)
75*b0d29bc4SBrooks Davis {
76*b0d29bc4SBrooks Davis if (newline)
77*b0d29bc4SBrooks Davis std::cout << message << "\n";
78*b0d29bc4SBrooks Davis else {
79*b0d29bc4SBrooks Davis std::cout << message << "\n";
80*b0d29bc4SBrooks Davis std::cout.flush();
81*b0d29bc4SBrooks Davis }
82*b0d29bc4SBrooks Davis _out_log.push_back(message);
83*b0d29bc4SBrooks Davis }
84*b0d29bc4SBrooks Davis
85*b0d29bc4SBrooks Davis
86*b0d29bc4SBrooks Davis /// Queries the width of the screen.
87*b0d29bc4SBrooks Davis ///
88*b0d29bc4SBrooks Davis /// \return Always none, as we do not want to depend on line wrapping in our
89*b0d29bc4SBrooks Davis /// tests.
90*b0d29bc4SBrooks Davis optional< std::size_t >
screen_width(void) const91*b0d29bc4SBrooks Davis ui_mock::screen_width(void) const
92*b0d29bc4SBrooks Davis {
93*b0d29bc4SBrooks Davis return _screen_width > 0 ? optional< std::size_t >(_screen_width) : none;
94*b0d29bc4SBrooks Davis }
95*b0d29bc4SBrooks Davis
96*b0d29bc4SBrooks Davis
97*b0d29bc4SBrooks Davis /// Gets all the lines written to stderr.
98*b0d29bc4SBrooks Davis ///
99*b0d29bc4SBrooks Davis /// \return The printed lines.
100*b0d29bc4SBrooks Davis const std::vector< std::string >&
err_log(void) const101*b0d29bc4SBrooks Davis ui_mock::err_log(void) const
102*b0d29bc4SBrooks Davis {
103*b0d29bc4SBrooks Davis return _err_log;
104*b0d29bc4SBrooks Davis }
105*b0d29bc4SBrooks Davis
106*b0d29bc4SBrooks Davis
107*b0d29bc4SBrooks Davis /// Gets all the lines written to stdout.
108*b0d29bc4SBrooks Davis ///
109*b0d29bc4SBrooks Davis /// \return The printed lines.
110*b0d29bc4SBrooks Davis const std::vector< std::string >&
out_log(void) const111*b0d29bc4SBrooks Davis ui_mock::out_log(void) const
112*b0d29bc4SBrooks Davis {
113*b0d29bc4SBrooks Davis return _out_log;
114*b0d29bc4SBrooks Davis }
115