]> git.saurik.com Git - apt.git/blobdiff - test/libapt/configuration_test.cc
CMake: Add coverage build type
[apt.git] / test / libapt / configuration_test.cc
index 647d8a4af6377010a55f3fa2d3c632156a3be88a..bdc17cbf4ca0f1d32e2c8d19b78df8c5b7df725f 100644 (file)
@@ -112,6 +112,34 @@ TEST(ConfigurationTest,DirsAndFiles)
        EXPECT_EQ("/rootdir/dev/null", Cnf.FindDir("Dir::State"));
        EXPECT_EQ("/rootdir/dev/null", Cnf.FindDir("Dir::State::lists"));
 }
        EXPECT_EQ("/rootdir/dev/null", Cnf.FindDir("Dir::State"));
        EXPECT_EQ("/rootdir/dev/null", Cnf.FindDir("Dir::State::lists"));
 }
+TEST(ConfigurationTest,DevNullInPaths)
+{
+       Configuration Cnf;
+       EXPECT_EQ("", Cnf.FindFile("Dir"));
+       EXPECT_EQ("", Cnf.FindFile("Dir::State"));
+       EXPECT_EQ("", Cnf.FindFile("Dir::State::status"));
+       Cnf.Set("Dir::State", "/dev/null");
+       EXPECT_EQ("/dev/null", Cnf.FindFile("Dir::State"));
+       Cnf.Set("Dir", "/");
+       Cnf.Set("Dir::State::status", "status");
+       EXPECT_EQ("/dev/null", Cnf.FindFile("Dir::State"));
+       EXPECT_EQ("/dev/null", Cnf.FindFile("Dir::State::status"));
+       Cnf.Set("Dir::State", "");
+       EXPECT_EQ("", Cnf.FindFile("Dir::State"));
+       EXPECT_EQ("/status", Cnf.FindFile("Dir::State::status"));
+       Cnf.Set("Dir", "/dev/null");
+       EXPECT_EQ("/dev/null", Cnf.FindFile("Dir"));
+       EXPECT_EQ("", Cnf.FindFile("Dir::State"));
+       EXPECT_EQ("/dev/null", Cnf.FindFile("Dir::State::status"));
+       Cnf.Set("Dir", "/rootdir");
+       EXPECT_EQ("/rootdir", Cnf.FindFile("Dir"));
+       EXPECT_EQ("", Cnf.FindFile("Dir::State"));
+       EXPECT_EQ("/rootdir/status", Cnf.FindFile("Dir::State::status"));
+       Cnf.Set("Dir::State::status", "/foo/status");
+       EXPECT_EQ("/rootdir", Cnf.FindFile("Dir"));
+       EXPECT_EQ("", Cnf.FindFile("Dir::State"));
+       EXPECT_EQ("/foo/status", Cnf.FindFile("Dir::State::status"));
+}
 TEST(ConfigurationTest,Vector)
 {
        Configuration Cnf;
 TEST(ConfigurationTest,Vector)
 {
        Configuration Cnf;
@@ -144,3 +172,26 @@ TEST(ConfigurationTest,Vector)
        EXPECT_EQ("abel", vec[0]);
        EXPECT_EQ("bravo", vec[1]);
 }
        EXPECT_EQ("abel", vec[0]);
        EXPECT_EQ("bravo", vec[1]);
 }
+TEST(ConfigurationTest,Merge)
+{
+       Configuration Cnf;
+       Cnf.Set("Binary::apt::option::foo", "bar");
+       Cnf.Set("Binary::apt::option::empty", "");
+       Cnf.Set("option::foo", "foo");
+
+       Cnf.MoveSubTree("Binary::apt", "Binary::apt2");
+       EXPECT_FALSE(Cnf.Exists("Binary::apt::option"));
+       EXPECT_TRUE(Cnf.Exists("option"));
+       EXPECT_EQ("foo", Cnf.Find("option::foo"));
+       EXPECT_EQ("bar", Cnf.Find("Binary::apt2::option::foo"));
+
+       EXPECT_FALSE(Cnf.Exists("option::empty"));
+       EXPECT_TRUE(Cnf.Exists("Binary::apt2::option::empty"));
+       Cnf.Set("option::empty", "not");
+
+       Cnf.MoveSubTree("Binary::apt2", NULL);
+       EXPECT_FALSE(Cnf.Exists("Binary::apt2::option"));
+       EXPECT_TRUE(Cnf.Exists("option"));
+       EXPECT_EQ("bar", Cnf.Find("option::foo"));
+       EXPECT_EQ("", Cnf.Find("option::empty"));
+}