NewParseTest.cpp
1.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#include "app_helper.hpp"
#include "gmock/gmock.h"
#include <complex>
using ::testing::HasSubstr;
typedef std::complex<double> cx;
CLI::Option* add_option(CLI::App& app,
std::string name, cx& variable,
std::string description="", bool defaulted=false) {
CLI::callback_t fun = [&variable](CLI::results_t res){
if(res.size()!=2)
return false;
double x,y;
bool worked = CLI::detail::lexical_cast(res[0], x)
&& CLI::detail::lexical_cast(res[1], y);
if(worked)
variable = cx(x,y);
return worked;
};
CLI::Option* opt = app.add_option(name, fun, description, defaulted);
opt->set_custom_option("COMPLEX", 2);
if(defaulted) {
std::stringstream out;
out << variable;
opt->set_default_val(out.str());
}
return opt;
}
TEST_F(TApp, AddingComplexParser) {
cx comp {0, 0};
add_option(app, "-c,--complex", comp);
args = {"-c", "1.5", "2.5"};
run();
EXPECT_EQ(cx(1.5,2.5), comp);
}
TEST_F(TApp, DefaultComplex) {
cx comp {1, 2};
add_option(app, "-c,--complex", comp, "", true);
args = {"-c", "4", "3"};
std::string help = app.help();
EXPECT_THAT(help, HasSubstr("1"));
EXPECT_THAT(help, HasSubstr("2"));
EXPECT_EQ(cx(1,2), comp);
run();
EXPECT_EQ(cx(4,3), comp);
}