summaryrefslogtreecommitdiff
path: root/tests/test_ext.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/test_ext.py')
-rw-r--r--tests/test_ext.py178
1 files changed, 178 insertions, 0 deletions
diff --git a/tests/test_ext.py b/tests/test_ext.py
new file mode 100644
index 0000000..126c0ec
--- /dev/null
+++ b/tests/test_ext.py
@@ -0,0 +1,178 @@
+# 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 tests.env
+from tests.tools import *
+import uuid
+import unittest
+import os
+import json
+import azurelinuxagent.logger as logger
+from azurelinuxagent.utils.osutil import OSUTIL
+import azurelinuxagent.utils.fileutil as fileutil
+import azurelinuxagent.protocol as prot
+import azurelinuxagent.distro.default.extension as ext
+
+ext_sample_json = {
+ "name":"TestExt",
+ "properties":{
+ "version":"2.0",
+ "state":"enabled",
+ "upgradePolicy":"auto",
+ "extensions":[{
+ "sequenceNumber": 0,
+ "publicSettings": "",
+ "protectedSettings": "",
+ "certificateThumbprint": ""
+ }],
+ "versionUris":[{
+ "version":"2.1",
+ "uris":["http://foo.bar"]
+ },{
+ "version":"2.0",
+ "uris":["http://foo.bar"]
+ }]
+ }
+}
+ext_sample = prot.Extension()
+prot.set_properties(ext_sample, ext_sample_json)
+
+pkd_list_sample_str={
+ "versions": [{
+ "version": "2.0",
+ "uris":[{
+ "uri":"http://foo.bar"
+ }]
+ },{
+ "version": "2.1",
+ "uris":[{
+ "uri":"http://foo.bar"
+ }]
+ }]
+}
+pkg_list_sample = prot.ExtensionPackageList()
+prot.set_properties(pkg_list_sample, pkd_list_sample_str)
+
+manifest_sample_str = {
+ "handlerManifest":{
+ "installCommand": "echo 'install'",
+ "uninstallCommand": "echo 'uninstall'",
+ "updateCommand": "echo 'update'",
+ "enableCommand": "echo 'enable'",
+ "disableCommand": "echo 'disable'",
+ }
+}
+manifest_sample = ext.HandlerManifest(manifest_sample_str)
+
+def mock_load_manifest(self):
+ return manifest_sample
+
+mock_launch_command = MockFunc()
+mock_set_handler_status = MockFunc()
+
+def mock_download(self):
+ fileutil.mkdir(self.get_base_dir())
+ fileutil.write_file(self.get_manifest_file(), json.dumps(manifest_sample_str))
+
+#logger.LoggerInit("/dev/null", "/dev/stdout")
+class TestExtensions(unittest.TestCase):
+
+ def test_load_ext(self):
+ libDir = OSUTIL.get_lib_dir()
+ test_ext1 = os.path.join(libDir, 'TestExt-1.0')
+ test_ext2 = os.path.join(libDir, 'TestExt-2.0')
+ test_ext2 = os.path.join(libDir, 'TestExt-2.1')
+ for path in [test_ext1, test_ext2]:
+ if not os.path.isdir(path):
+ os.mkdir(path)
+ test_ext = ext.get_installed_version('TestExt')
+ self.assertEqual('2.1', test_ext)
+
+ def test_getters(self):
+ test_ext = ext.ExtensionInstance(ext_sample, pkg_list_sample,
+ ext_sample.properties.version, False)
+ self.assertEqual("/tmp/TestExt-2.0", test_ext.get_base_dir())
+ self.assertEqual("/tmp/TestExt-2.0/status", test_ext.get_status_dir())
+ self.assertEqual("/tmp/TestExt-2.0/status/0.status",
+ test_ext.get_status_file())
+ self.assertEqual("/tmp/TestExt-2.0/config/HandlerState",
+ test_ext.get_handler_state_file())
+ self.assertEqual("/tmp/TestExt-2.0/config", test_ext.get_conf_dir())
+ self.assertEqual("/tmp/TestExt-2.0/config/0.settings",
+ test_ext.get_settings_file())
+ self.assertEqual("/tmp/TestExt-2.0/heartbeat.log",
+ test_ext.get_heartbeat_file())
+ self.assertEqual("/tmp/TestExt-2.0/HandlerManifest.json",
+ test_ext.get_manifest_file())
+ self.assertEqual("/tmp/TestExt-2.0/HandlerEnvironment.json",
+ test_ext.get_env_file())
+ self.assertEqual("/tmp/log/TestExt/2.0", test_ext.get_log_dir())
+
+ test_ext = ext.ExtensionInstance(ext_sample, pkg_list_sample, "2.1", False)
+ self.assertEqual("/tmp/TestExt-2.1", test_ext.get_base_dir())
+ self.assertEqual("2.1", test_ext.get_target_version())
+
+ @mock(ext.ExtensionInstance, 'load_manifest', mock_load_manifest)
+ @mock(ext.ExtensionInstance, 'launch_command', mock_launch_command)
+ @mock(ext.ExtensionInstance, 'set_handler_status', mock_set_handler_status)
+ def test_handle_uninstall(self):
+ mock_launch_command.args = None
+ mock_set_handler_status.args = None
+ test_ext = ext.ExtensionInstance(ext_sample, pkg_list_sample,
+ ext_sample.properties.version, False)
+ test_ext.handle_uninstall()
+ self.assertEqual(None, mock_launch_command.args)
+ self.assertEqual(None, mock_set_handler_status.args)
+ self.assertEqual(None, test_ext.get_curr_op())
+
+ test_ext = ext.ExtensionInstance(ext_sample, pkg_list_sample,
+ ext_sample.properties.version, True)
+ test_ext.handle_uninstall()
+ self.assertEqual(manifest_sample.get_uninstall_command(), mock_launch_command.args[0])
+ self.assertEqual("UnInstall", test_ext.get_curr_op())
+ self.assertEqual("NotReady", mock_set_handler_status.args[0])
+
+ @mock(ext.ExtensionInstance, 'load_manifest', mock_load_manifest)
+ @mock(ext.ExtensionInstance, 'launch_command', mock_launch_command)
+ @mock(ext.ExtensionInstance, 'download', mock_download)
+ @mock(ext.ExtensionInstance, 'get_handler_status', MockFunc(retval="enabled"))
+ @mock(ext.ExtensionInstance, 'set_handler_status', mock_set_handler_status)
+ def test_handle(self):
+ #Test enable
+ test_ext = ext.ExtensionInstance(ext_sample, pkg_list_sample,
+ ext_sample.properties.version, False)
+ test_ext.init_logger()
+ self.assertEqual(1, len(test_ext.logger.appenders) - len(logger.DEFAULT_LOGGER.appenders))
+ test_ext.handle()
+
+ #Test upgrade
+ test_ext = ext.ExtensionInstance(ext_sample, pkg_list_sample,
+ ext_sample.properties.version, False)
+ test_ext.init_logger()
+ self.assertEqual(1, len(test_ext.logger.appenders) - len(logger.DEFAULT_LOGGER.appenders))
+ test_ext.handle()
+
+ def test_status_convert(self):
+ ext_status = json.loads('[{"status": {"status": "success", "formattedMessage": {"lang": "en-US", "message": "Script is finished"}, "operation": "Enable", "code": "0", "name": "Microsoft.OSTCExtensions.CustomScriptForLinux"}, "version": "1.0", "timestampUTC": "2015-06-27T08:34:50Z"}]')
+ ext.ext_status_to_v2(ext_status[0], 0)
+
+
+if __name__ == '__main__':
+ unittest.main()