From f78b9650d0e7b008d430673a075aad95dda863be Mon Sep 17 00:00:00 2001 From: Ben Howard Date: Fri, 14 Aug 2015 16:40:41 -0600 Subject: Import patches-unapplied version 2.1.1-0ubuntu1 to ubuntu/wily-proposed Imported using git-ubuntu import. Changelog parent: 0afc048f2a6ff3638ecfa33e7ded5dc8dddf041a New changelog entries: * New upstream release for Ubuntu. - Switch to Python3 - Applies Ubuntu specific patches --- tests/test_conf.py | 69 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 tests/test_conf.py (limited to 'tests/test_conf.py') 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() -- cgit v1.2.3