1edebbb8eSjmmv //
2edebbb8eSjmmv // Automated Testing Framework (atf)
3edebbb8eSjmmv //
4*a551a20fSjmmv // Copyright (c) 2007 The NetBSD Foundation, Inc.
5edebbb8eSjmmv // All rights reserved.
6edebbb8eSjmmv //
7edebbb8eSjmmv // Redistribution and use in source and binary forms, with or without
8edebbb8eSjmmv // modification, are permitted provided that the following conditions
9edebbb8eSjmmv // are met:
10edebbb8eSjmmv // 1. Redistributions of source code must retain the above copyright
11edebbb8eSjmmv // notice, this list of conditions and the following disclaimer.
12edebbb8eSjmmv // 2. Redistributions in binary form must reproduce the above copyright
13edebbb8eSjmmv // notice, this list of conditions and the following disclaimer in the
14edebbb8eSjmmv // documentation and/or other materials provided with the distribution.
15edebbb8eSjmmv //
16edebbb8eSjmmv // THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND
17edebbb8eSjmmv // CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
18edebbb8eSjmmv // INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19edebbb8eSjmmv // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20edebbb8eSjmmv // IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS BE LIABLE FOR ANY
21edebbb8eSjmmv // DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22edebbb8eSjmmv // DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
23edebbb8eSjmmv // GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24edebbb8eSjmmv // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
25edebbb8eSjmmv // IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
26edebbb8eSjmmv // OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
27edebbb8eSjmmv // IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28edebbb8eSjmmv //
29edebbb8eSjmmv
30edebbb8eSjmmv #include <cstring>
31edebbb8eSjmmv #include <iostream>
32edebbb8eSjmmv
33895f502bSjmmv #include "config.hpp"
34895f502bSjmmv #include "macros.hpp"
35edebbb8eSjmmv
36895f502bSjmmv #include "detail/env.hpp"
37895f502bSjmmv #include "detail/exceptions.hpp"
38895f502bSjmmv #include "detail/test_helpers.hpp"
39edebbb8eSjmmv
40edebbb8eSjmmv static const char *test_value = "env-value";
41edebbb8eSjmmv
42edebbb8eSjmmv static struct varnames {
43edebbb8eSjmmv const char *lc;
44edebbb8eSjmmv const char *uc;
45edebbb8eSjmmv bool can_be_empty;
46edebbb8eSjmmv } all_vars[] = {
47edebbb8eSjmmv { "atf_build_cc", "ATF_BUILD_CC", false },
48edebbb8eSjmmv { "atf_build_cflags", "ATF_BUILD_CFLAGS", true },
49edebbb8eSjmmv { "atf_build_cpp", "ATF_BUILD_CPP", false },
50edebbb8eSjmmv { "atf_build_cppflags", "ATF_BUILD_CPPFLAGS", true },
51edebbb8eSjmmv { "atf_build_cxx", "ATF_BUILD_CXX", false },
52edebbb8eSjmmv { "atf_build_cxxflags", "ATF_BUILD_CXXFLAGS", true },
53edebbb8eSjmmv { "atf_includedir", "ATF_INCLUDEDIR", false },
54895f502bSjmmv { "atf_libexecdir", "ATF_LIBEXECDIR", false },
55edebbb8eSjmmv { "atf_pkgdatadir", "ATF_PKGDATADIR", false },
56edebbb8eSjmmv { "atf_shell", "ATF_SHELL", false },
57edebbb8eSjmmv { "atf_workdir", "ATF_WORKDIR", false },
58edebbb8eSjmmv { NULL, NULL, false }
59edebbb8eSjmmv };
60edebbb8eSjmmv
61edebbb8eSjmmv // ------------------------------------------------------------------------
62edebbb8eSjmmv // Auxiliary functions.
63edebbb8eSjmmv // ------------------------------------------------------------------------
64edebbb8eSjmmv
65edebbb8eSjmmv namespace atf {
66edebbb8eSjmmv namespace config {
67edebbb8eSjmmv void __reinit(void);
68edebbb8eSjmmv }
69edebbb8eSjmmv }
70edebbb8eSjmmv
71edebbb8eSjmmv static
72edebbb8eSjmmv void
set_env_var(const char * name,const char * val)73edebbb8eSjmmv set_env_var(const char* name, const char* val)
74edebbb8eSjmmv {
75edebbb8eSjmmv try {
76edebbb8eSjmmv atf::env::set(name, val);
77895f502bSjmmv } catch (const atf::system_error&) {
78edebbb8eSjmmv ATF_FAIL(std::string("set_env_var(") + name + ", " + val +
79edebbb8eSjmmv ") failed");
80edebbb8eSjmmv }
81edebbb8eSjmmv }
82edebbb8eSjmmv
83edebbb8eSjmmv static
84edebbb8eSjmmv void
unset_env_var(const char * name)85edebbb8eSjmmv unset_env_var(const char* name)
86edebbb8eSjmmv {
87edebbb8eSjmmv try {
88edebbb8eSjmmv atf::env::unset(name);
89895f502bSjmmv } catch (const atf::system_error&) {
90edebbb8eSjmmv ATF_FAIL(std::string("unset_env_var(") + name + ") failed");
91edebbb8eSjmmv }
92edebbb8eSjmmv }
93edebbb8eSjmmv
94edebbb8eSjmmv static
95edebbb8eSjmmv size_t
all_vars_count(void)96edebbb8eSjmmv all_vars_count(void)
97edebbb8eSjmmv {
98edebbb8eSjmmv size_t count = 0;
99edebbb8eSjmmv for (const struct varnames* v = all_vars; v->lc != NULL; v++)
100edebbb8eSjmmv count++;
101edebbb8eSjmmv return count;
102edebbb8eSjmmv }
103edebbb8eSjmmv
104edebbb8eSjmmv static
105edebbb8eSjmmv void
unset_all(void)106edebbb8eSjmmv unset_all(void)
107edebbb8eSjmmv {
108edebbb8eSjmmv for (const struct varnames* v = all_vars; v->lc != NULL; v++)
109edebbb8eSjmmv unset_env_var(v->uc);
110edebbb8eSjmmv }
111edebbb8eSjmmv
112edebbb8eSjmmv static
113edebbb8eSjmmv void
compare_one(const char * var,const char * expvalue)114edebbb8eSjmmv compare_one(const char* var, const char* expvalue)
115edebbb8eSjmmv {
116895f502bSjmmv std::cout << "Checking that " << var << " is set to " << expvalue << "\n";
117edebbb8eSjmmv
118edebbb8eSjmmv for (const struct varnames* v = all_vars; v->lc != NULL; v++) {
119edebbb8eSjmmv if (std::strcmp(v->lc, var) == 0)
120895f502bSjmmv ATF_REQUIRE_EQ(atf::config::get(v->lc), test_value);
121edebbb8eSjmmv else
122895f502bSjmmv ATF_REQUIRE(atf::config::get(v->lc) != test_value);
123edebbb8eSjmmv }
124edebbb8eSjmmv }
125edebbb8eSjmmv
126edebbb8eSjmmv // ------------------------------------------------------------------------
127edebbb8eSjmmv // Test cases for the free functions.
128edebbb8eSjmmv // ------------------------------------------------------------------------
129edebbb8eSjmmv
130edebbb8eSjmmv ATF_TEST_CASE(get);
ATF_TEST_CASE_HEAD(get)131edebbb8eSjmmv ATF_TEST_CASE_HEAD(get)
132edebbb8eSjmmv {
133edebbb8eSjmmv set_md_var("descr", "Tests the config::get function");
134edebbb8eSjmmv }
ATF_TEST_CASE_BODY(get)135edebbb8eSjmmv ATF_TEST_CASE_BODY(get)
136edebbb8eSjmmv {
137edebbb8eSjmmv // Unset all known environment variables and make sure the built-in
138edebbb8eSjmmv // values do not match the bogus value we will use for testing.
139edebbb8eSjmmv unset_all();
140edebbb8eSjmmv atf::config::__reinit();
141edebbb8eSjmmv for (const struct varnames* v = all_vars; v->lc != NULL; v++)
142895f502bSjmmv ATF_REQUIRE(atf::config::get(v->lc) != test_value);
143edebbb8eSjmmv
144edebbb8eSjmmv // Test the behavior of empty values.
145edebbb8eSjmmv for (const struct varnames* v = all_vars; v->lc != NULL; v++) {
146edebbb8eSjmmv unset_all();
147edebbb8eSjmmv if (!atf::config::get(v->lc).empty()) {
148edebbb8eSjmmv set_env_var(v->uc, "");
149edebbb8eSjmmv atf::config::__reinit();
150edebbb8eSjmmv if (v->can_be_empty)
151895f502bSjmmv ATF_REQUIRE(atf::config::get(v->lc).empty());
152edebbb8eSjmmv else
153895f502bSjmmv ATF_REQUIRE(!atf::config::get(v->lc).empty());
154edebbb8eSjmmv }
155edebbb8eSjmmv }
156edebbb8eSjmmv
157edebbb8eSjmmv // Check if the ATF_ARCH variable is recognized.
158edebbb8eSjmmv for (const struct varnames* v = all_vars; v->lc != NULL; v++) {
159edebbb8eSjmmv unset_all();
160edebbb8eSjmmv set_env_var(v->uc, test_value);
161edebbb8eSjmmv atf::config::__reinit();
162edebbb8eSjmmv compare_one(v->lc, test_value);
163edebbb8eSjmmv }
164edebbb8eSjmmv }
165edebbb8eSjmmv
166edebbb8eSjmmv ATF_TEST_CASE(get_all);
ATF_TEST_CASE_HEAD(get_all)167edebbb8eSjmmv ATF_TEST_CASE_HEAD(get_all)
168edebbb8eSjmmv {
169edebbb8eSjmmv set_md_var("descr", "Tests the config::get_all function");
170edebbb8eSjmmv }
ATF_TEST_CASE_BODY(get_all)171edebbb8eSjmmv ATF_TEST_CASE_BODY(get_all)
172edebbb8eSjmmv {
173edebbb8eSjmmv atf::config::__reinit();
174edebbb8eSjmmv
175edebbb8eSjmmv // Check that the valid variables, and only those, are returned.
176edebbb8eSjmmv std::map< std::string, std::string > vars = atf::config::get_all();
177895f502bSjmmv ATF_REQUIRE_EQ(vars.size(), all_vars_count());
178edebbb8eSjmmv for (const struct varnames* v = all_vars; v->lc != NULL; v++)
179895f502bSjmmv ATF_REQUIRE(vars.find(v->lc) != vars.end());
180edebbb8eSjmmv }
181edebbb8eSjmmv
182edebbb8eSjmmv ATF_TEST_CASE(has);
ATF_TEST_CASE_HEAD(has)183edebbb8eSjmmv ATF_TEST_CASE_HEAD(has)
184edebbb8eSjmmv {
185edebbb8eSjmmv set_md_var("descr", "Tests the config::has function");
186edebbb8eSjmmv }
ATF_TEST_CASE_BODY(has)187edebbb8eSjmmv ATF_TEST_CASE_BODY(has)
188edebbb8eSjmmv {
189edebbb8eSjmmv atf::config::__reinit();
190edebbb8eSjmmv
191edebbb8eSjmmv // Check for all the variables that must exist.
192edebbb8eSjmmv for (const struct varnames* v = all_vars; v->lc != NULL; v++)
193895f502bSjmmv ATF_REQUIRE(atf::config::has(v->lc));
194edebbb8eSjmmv
195edebbb8eSjmmv // Same as above, but using uppercase (which is incorrect).
196edebbb8eSjmmv for (const struct varnames* v = all_vars; v->lc != NULL; v++)
197895f502bSjmmv ATF_REQUIRE(!atf::config::has(v->uc));
198edebbb8eSjmmv
199edebbb8eSjmmv // Check for some other variables that cannot exist.
200895f502bSjmmv ATF_REQUIRE(!atf::config::has("foo"));
201895f502bSjmmv ATF_REQUIRE(!atf::config::has("BAR"));
202895f502bSjmmv ATF_REQUIRE(!atf::config::has("atf_foo"));
203895f502bSjmmv ATF_REQUIRE(!atf::config::has("ATF_BAR"));
204895f502bSjmmv ATF_REQUIRE(!atf::config::has("atf_shel"));
205895f502bSjmmv ATF_REQUIRE(!atf::config::has("atf_shells"));
206edebbb8eSjmmv }
207edebbb8eSjmmv
208edebbb8eSjmmv // ------------------------------------------------------------------------
209edebbb8eSjmmv // Tests cases for the header file.
210edebbb8eSjmmv // ------------------------------------------------------------------------
211edebbb8eSjmmv
212edebbb8eSjmmv HEADER_TC(include, "atf-c++/config.hpp");
213edebbb8eSjmmv
214edebbb8eSjmmv // ------------------------------------------------------------------------
215edebbb8eSjmmv // Main.
216edebbb8eSjmmv // ------------------------------------------------------------------------
217edebbb8eSjmmv
ATF_INIT_TEST_CASES(tcs)218edebbb8eSjmmv ATF_INIT_TEST_CASES(tcs)
219edebbb8eSjmmv {
220edebbb8eSjmmv // Add the test cases for the free functions.
221edebbb8eSjmmv ATF_ADD_TEST_CASE(tcs, has);
222edebbb8eSjmmv ATF_ADD_TEST_CASE(tcs, get);
223edebbb8eSjmmv ATF_ADD_TEST_CASE(tcs, get_all);
224edebbb8eSjmmv
225edebbb8eSjmmv // Add the test cases for the header file.
226edebbb8eSjmmv ATF_ADD_TEST_CASE(tcs, include);
227edebbb8eSjmmv }
228