summaryrefslogtreecommitdiff
path: root/tests/test_conf.py
diff options
context:
space:
mode:
authorBen Howard <ben.howard@ubuntu.com>2015-08-14 16:40:41 -0600
committerusd-importer <ubuntu-server@lists.ubuntu.com>2015-08-15 14:33:21 +0000
commitade966c05615a08ba26a66d777b68821b65cabf2 (patch)
tree6328073598925959bf62e5227e6f88f0575d86a3 /tests/test_conf.py
parent0d1d620c8c7947e4aa3b330bb667583413146984 (diff)
parent4298c5d285f55ff0b3a45e8b9139a96c64d3ffc0 (diff)
downloadvyos-walinuxagent-ade966c05615a08ba26a66d777b68821b65cabf2.tar.gz
vyos-walinuxagent-ade966c05615a08ba26a66d777b68821b65cabf2.zip
Import patches-applied version 2.1.1-0ubuntu1 to applied/ubuntu/wily-proposed
Imported using git-ubuntu import. Changelog parent: 0d1d620c8c7947e4aa3b330bb667583413146984 Unapplied parent: 4298c5d285f55ff0b3a45e8b9139a96c64d3ffc0 New changelog entries: * New upstream release for Ubuntu. - Switch to Python3 - Applies Ubuntu specific patches
Diffstat (limited to 'tests/test_conf.py')
-rw-r--r--tests/test_conf.py69
1 files changed, 69 insertions, 0 deletions
diff --git a/tests/test_conf.py b/tests/test_conf.py
new file mode 100644
index 0000000..204e4f5
--- /dev/null
+++ b/tests/test_conf.py
@@ -0,0 +1,69 @@
+# Copyright 2014 Microsoft Corporation
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# Requires Python 2.4+ and Openssl 1.0+
+#
+# Implements parts of RFC 2131, 1541, 1497 and
+# http://msdn.microsoft.com/en-us/library/cc227282%28PROT.10%29.aspx
+# http://msdn.microsoft.com/en-us/library/cc227259%28PROT.13%29.aspx
+
+import os
+import tests.env
+import uuid
+import unittest
+import tests.tools as tools
+import azurelinuxagent.utils.fileutil as fileutil
+import azurelinuxagent.conf as conf
+from azurelinuxagent.exception import *
+
+TestConf="""\
+#
+# This is comment
+#
+foo.bar.switch=y
+foo.bar.switch2=n
+foo.bar.str=foobar
+foo.bar.int=300
+
+"""
+
+class TestConfiguration(unittest.TestCase):
+ def test_parse_conf(self):
+ config = conf.ConfigurationProvider()
+ config.load(TestConf)
+ self.assertEquals(True, config.get_switch("foo.bar.switch"))
+ self.assertEquals(False, config.get_switch("foo.bar.switch2"))
+ self.assertEquals(False, config.get_switch("foo.bar.switch3"))
+ self.assertEquals(True, config.get_switch("foo.bar.switch4", True))
+ self.assertEquals("foobar", config.get("foo.bar.str"))
+ self.assertEquals("foobar1", config.get("foo.bar.str1", "foobar1"))
+ self.assertEquals(300, config.get_int("foo.bar.int"))
+ self.assertEquals(-1, config.get_int("foo.bar.int2"))
+ self.assertEquals(-1, config.get_int("foo.bar.str"))
+
+ def test_parse_malformed_conf(self):
+ config = conf.ConfigurationProvider()
+ self.assertRaises(AgentConfigError, config.load, None)
+
+ def test_load_conf_file(self):
+ with open('/tmp/test_conf', 'w') as F:
+ F.write(TestConf)
+ F.close()
+
+ config = conf.ConfigurationProvider()
+ conf.load_conf('/tmp/test_conf', conf=config)
+ self.assertEquals(True, config.get_switch("foo.bar.switch"), False)
+
+if __name__ == '__main__':
+ unittest.main()