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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
|
// Copyright (C) 2018 Internet Systems Consortium, Inc. ("ISC")
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
#include <config.h>
#include <yang/translator_logger.h>
#include <yang/yang_models.h>
#include <yang/tests/sysrepo_setup.h>
#include <gtest/gtest.h>
using namespace std;
using namespace isc;
using namespace isc::data;
using namespace isc::yang;
using namespace isc::yang::test;
#ifndef HAVE_PRE_0_7_6_SYSREPO
using namespace sysrepo;
#endif
namespace {
/// @brief Translator name.
extern char const logger_list[] = "logger list";
/// @brief Test fixture class for @ref TranslatorLoggers.
class TranslatorLoggersTest :
public GenericTranslatorTest<logger_list, TranslatorLoggers> {
public:
/// Constructor.
TranslatorLoggersTest() { }
/// Destructor (does nothing).
virtual ~TranslatorLoggersTest() { }
};
// This test verifies that an empty logger list can be properly
// translated from YANG to JSON.
TEST_F(TranslatorLoggersTest, getEmpty) {
useModel(KEA_DHCP4_SERVER);
// Get empty.
const string& xpath = "/kea-dhcp4-server:config";
ConstElementPtr loggers;
EXPECT_NO_THROW(loggers = t_obj_->getLoggers(xpath));
ASSERT_TRUE(loggers);
EXPECT_EQ(0, loggers->size());
}
// This test verifies that one logger can be properly
// translated from YANG to JSON.
TEST_F(TranslatorLoggersTest, get) {
useModel(KEA_DHCP6_SERVER);
// Set a value.
const string& xpath = "/kea-dhcp6-server:config";
const string& xlogger = xpath + "/logger[name='foo']";
const string& xseverity = xlogger + "/severity";
const string& xoption = xlogger + "/output-option[output='/bar']";
const string& xmaxver = xoption + "/maxver";
S_Val s_severity(new Val("WARN", SR_ENUM_T));
EXPECT_NO_THROW(sess_->set_item(xseverity.c_str(), s_severity));
uint32_t max_ver = 10;
S_Val s_maxver(new Val(max_ver, SR_UINT32_T));
EXPECT_NO_THROW(sess_->set_item(xmaxver.c_str(), s_maxver));
// Get empty.
ConstElementPtr loggers;
EXPECT_NO_THROW(loggers = t_obj_->getLoggers(xpath));
ASSERT_TRUE(loggers);
ASSERT_EQ(1, loggers->size());
ConstElementPtr logger = loggers->get(0);
ASSERT_TRUE(logger);
EXPECT_EQ(3, logger->size());
ConstElementPtr name = logger->get("name");
ASSERT_TRUE(name);
ASSERT_EQ(Element::string, name->getType());
EXPECT_EQ("foo", name->stringValue());
ConstElementPtr severity = logger->get("severity");
ASSERT_TRUE(severity);
ASSERT_EQ(Element::string, severity->getType());
EXPECT_EQ("WARN", severity->stringValue());
ConstElementPtr options = logger->get("output_options");
ASSERT_TRUE(options);
ASSERT_EQ(1, options->size());
ConstElementPtr option = options->get(0);
ASSERT_TRUE(option);
EXPECT_EQ(2, option->size());
ConstElementPtr output = option->get("output");
ASSERT_TRUE(output);
ASSERT_EQ(Element::string, output->getType());
EXPECT_EQ("/bar", output->stringValue());
ConstElementPtr maxver = option->get("maxver");
ASSERT_TRUE(maxver);
ASSERT_EQ(Element::integer, maxver->getType());
EXPECT_EQ(max_ver, maxver->intValue());
}
// This test verifies that one logger can be properly
// translated from JSON to YANG.
TEST_F(TranslatorLoggersTest, set) {
useModel(KEA_DHCP4_SERVER);
// Set a value.
const string& xpath = "/kea-dhcp4-server:config";
ElementPtr option = Element::createMap();
option->set("output", Element::create(string("/bar")));
option->set("maxver", Element::create(10));
ElementPtr options = Element::createList();
options->add(option);
ElementPtr logger = Element::createMap();
logger->set("name", Element::create(string("foo")));
logger->set("severity", Element::create(string("WARN")));
logger->set("output_options", options);
ElementPtr loggers = Element::createList();
loggers->add(logger);
ASSERT_NO_THROW(t_obj_->setLoggers(xpath, loggers));
// Get it back.
ConstElementPtr gots;
EXPECT_NO_THROW(gots = t_obj_->getLoggers(xpath));
ASSERT_TRUE(gots);
ASSERT_EQ(1, gots->size());
ConstElementPtr got = gots->get(0);
ASSERT_TRUE(got);
EXPECT_EQ(3, got->size());
ConstElementPtr name = got->get("name");
ASSERT_TRUE(name);
ASSERT_EQ(Element::string, name->getType());
EXPECT_EQ("foo", name->stringValue());
ConstElementPtr severity = logger->get("severity");
ASSERT_TRUE(severity);
ASSERT_EQ(Element::string, severity->getType());
EXPECT_EQ("WARN", severity->stringValue());
ConstElementPtr got_os = logger->get("output_options");
ASSERT_TRUE(got_os);
ASSERT_EQ(1, got_os->size());
ConstElementPtr got_o = got_os->get(0);
ASSERT_TRUE(got_o);
EXPECT_EQ(2, got_o->size());
ConstElementPtr output = got_o->get("output");
ASSERT_TRUE(output);
ASSERT_EQ(Element::string, output->getType());
EXPECT_EQ("/bar", output->stringValue());
ConstElementPtr maxver = got_o->get("maxver");
ASSERT_TRUE(maxver);
ASSERT_EQ(Element::integer, maxver->getType());
EXPECT_EQ(10, maxver->intValue());
// Check the tree representation.
S_Tree tree;
EXPECT_NO_THROW(tree = sess_->get_subtree("/kea-dhcp4-server:config"));
ASSERT_TRUE(tree);
string expected =
"kea-dhcp4-server:config (container)\n"
" |\n"
" -- logger (list instance)\n"
" |\n"
" -- name = foo\n"
" |\n"
" -- output-option (list instance)\n"
" | |\n"
" | -- output = /bar\n"
" | |\n"
" | -- maxver = 10\n"
" |\n"
" -- severity = WARN\n";
EXPECT_EQ(expected, tree->to_string(100));
// Check it validates.
EXPECT_NO_THROW(sess_->validate());
}
/// @todo: Implement a test that will cover multiple loggers.
}; // end of anonymous namespace
|