blob: 7da9e81e149ed9fb3f610faa3a693fd7e4f4f00b [file] [log] [blame]
#!/usr/bin/env python3
############################################################################
# Copyright 2016 RIFT.io Inc #
# #
# 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. #
############################################################################
import argparse
import asyncio
import logging
from unittest import mock
import os
import sys
import unittest
import xmlrunner
import rift.mano.utils.juju_api as juju_api
class JujuClientTest(unittest.TestCase):
log = None
@classmethod
def set_logger(cls, log):
cls.log = log
@asyncio.coroutine
def juju_client_test(self, mock_jujuclient, loop):
api = juju_api.JujuApi(secret='test', loop=loop, version=1)
env = yield from api.get_env()
self.assertTrue(env.login.called,
"Login to Juju not called")
env.login.assert_called_with('test', user='user-admin')
charm = 'test-charm'
service = 'test-service'
yield from api.deploy_service(charm, service)
# self.assertTrue(env.deploy.called,
# "Deploy failed")
config = {
'test_param': 'test_value',
}
yield from api.apply_config(config, env=env)
self.assertTrue(env.set_config.called,
"Config failed")
try:
yield from api.resolve_error(env=env)
except KeyError as e:
# Since the status does have values, this throws error
pass
# resolved method will not be called due to error above
self.assertFalse(env.resolved.called,
"Resolve error failed")
action = 'test-action'
params = {}
api.units = ['test-service-0']
# yield from api.execute_action(action, params, service=service, env=env)
action_tag = 'test-123434352'
# yield from api.get_action_status(action_tag)
api.destroy_retries = 2
api.retry_delay = 0.1
try:
yield from api.destroy_service()
except Exception as e:
JujuClientTest.log.debug("Expected exception on destroy service: {}".
format(e))
self.assertTrue(env.destroy_service.called,
"Destroy failed")
@mock.patch('rift.mano.utils.juju_api.Env1', autospec=True)
def test_client(self, mock_jujuclient):
loop = asyncio.get_event_loop()
loop.run_until_complete(self.juju_client_test(mock_jujuclient,
loop))
loop.close()
def main(argv=sys.argv[1:]):
logging.basicConfig(format='TEST %(message)s')
runner = xmlrunner.XMLTestRunner(output=os.environ["RIFT_MODULE_TEST"])
parser = argparse.ArgumentParser()
parser.add_argument('-v', '--verbose', action='store_true')
parser.add_argument('-n', '--no-runner', action='store_true')
args, unknown = parser.parse_known_args(argv)
if args.no_runner:
runner = None
# Set the global logging level
log = logging.getLogger()
log.setLevel(logging.DEBUG if args.verbose else logging.ERROR)
JujuClientTest.set_logger(log)
# The unittest framework requires a program name, so use the name of this
# file instead (we do not want to have to pass a fake program name to main
# when this is called from the interpreter).
unittest.main(argv=[__file__] + unknown + ["-v"], testRunner=runner)
if __name__ == '__main__':
main()