X-Git-Url: https://osm.etsi.org/gitweb/?p=osm%2Fdevops.git;a=blobdiff_plain;f=installers%2Fcharm%2Flcm%2Ftests%2Ftest_charm.py;h=bff3cee2c00446cba6533c41c7781171350f79fd;hp=25e2cd649afee30bcb143338cf85bc7deda5c52c;hb=49379ced23b5e344a773ce77ac9cb59c1864e19b;hpb=e5fd208248a496cd798a66cb27216e83f2852a76 diff --git a/installers/charm/lcm/tests/test_charm.py b/installers/charm/lcm/tests/test_charm.py index 25e2cd64..bff3cee2 100644 --- a/installers/charm/lcm/tests/test_charm.py +++ b/installers/charm/lcm/tests/test_charm.py @@ -1,5 +1,5 @@ #!/usr/bin/env python3 -# Copyright 2020 Canonical Ltd. +# Copyright 2021 Canonical Ltd. # # 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 @@ -20,108 +20,82 @@ # osm-charmers@lists.launchpad.net ## +import sys from typing import NoReturn import unittest -from ops.model import BlockedStatus - +from ops.model import ActiveStatus, BlockedStatus from ops.testing import Harness from charm import LcmCharm class TestCharm(unittest.TestCase): - """LCM Charm unit tests.""" + """Prometheus Charm unit tests.""" def setUp(self) -> NoReturn: """Test setup""" + self.image_info = sys.modules["oci_image"].OCIImageResource().fetch() self.harness = Harness(LcmCharm) self.harness.set_leader(is_leader=True) self.harness.begin() + self.config = { + "vca_host": "192.168.0.13", + "vca_port": 17070, + "vca_user": "admin", + "vca_password": "admin", + "vca_pubkey": "key", + "vca_cacert": "cacert", + "vca_cloud": "cloud", + "vca_k8s_cloud": "k8scloud", + "database_commonkey": "commonkey", + "log_level": "INFO", + } + self.harness.update_config(self.config) - def test_on_start_without_relations(self) -> NoReturn: - """Test installation without any relation.""" - self.harness.charm.on.start.emit() + def test_config_changed_no_relations( + self, + ) -> NoReturn: + """Test ingress resources without HTTP.""" - # Verifying status - self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus) + self.harness.charm.on.config_changed.emit() - # Verifying status message - self.assertGreater(len(self.harness.charm.unit.status.message), 0) + # Assertions + self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus) self.assertTrue( - self.harness.charm.unit.status.message.startswith("Waiting for ") + all( + relation in self.harness.charm.unit.status.message + for relation in ["mongodb", "kafka", "ro"] + ) ) - self.assertIn("kafka", self.harness.charm.unit.status.message) - self.assertIn("mongodb", self.harness.charm.unit.status.message) - self.assertIn("ro", self.harness.charm.unit.status.message) - self.assertTrue(self.harness.charm.unit.status.message.endswith(" relations")) - - def test_on_start_with_relations(self) -> NoReturn: - """Test deployment without keystone.""" - expected_result = { - "version": 3, - "containers": [ - { - "name": "lcm", - "imageDetails": self.harness.charm.image.fetch(), - "imagePullPolicy": "Always", - "ports": [ - { - "name": "lcm", - "containerPort": 9999, - "protocol": "TCP", - } - ], - "envConfig": { - "ALLOW_ANONYMOUS_LOGIN": "yes", - "OSMLCM_GLOBAL_LOGLEVEL": "INFO", - "OSMLCM_RO_HOST": "ro", - "OSMLCM_RO_PORT": 9090, - "OSMLCM_RO_TENANT": "osm", - "OSMLCM_MESSAGE_DRIVER": "kafka", - "OSMLCM_MESSAGE_HOST": "kafka", - "OSMLCM_MESSAGE_PORT": 9092, - "OSMLCM_DATABASE_DRIVER": "mongo", - "OSMLCM_DATABASE_URI": "mongodb://mongo:27017", - "OSMLCM_DATABASE_COMMONKEY": "osm", - "OSMLCM_STORAGE_DRIVER": "mongo", - "OSMLCM_STORAGE_PATH": "/app/storage", - "OSMLCM_STORAGE_COLLECTION": "files", - "OSMLCM_STORAGE_URI": "mongodb://mongo:27017", - "OSMLCM_VCA_HOST": "admin", - "OSMLCM_VCA_PORT": 17070, - "OSMLCM_VCA_USER": "admin", - "OSMLCM_VCA_PUBKEY": "secret", - "OSMLCM_VCA_SECRET": "secret", - "OSMLCM_VCA_CACERT": "", - "OSMLCM_VCA_CLOUD": "localhost", - "OSMLCM_VCA_K8S_CLOUD": "k8scloud", - }, - } - ], - "kubernetesResources": {"ingressResources": []}, - } - - self.harness.charm.on.start.emit() - # Check if kafka datastore is initialized - self.assertIsNone(self.harness.charm.state.message_host) - self.assertIsNone(self.harness.charm.state.message_port) - - # Check if mongodb datastore is initialized - self.assertIsNone(self.harness.charm.state.database_uri) - - # Check if RO datastore is initialized - self.assertIsNone(self.harness.charm.state.ro_host) - self.assertIsNone(self.harness.charm.state.ro_port) + def test_config_changed_non_leader( + self, + ) -> NoReturn: + """Test ingress resources without HTTP.""" + self.harness.set_leader(is_leader=False) + self.harness.charm.on.config_changed.emit() + + # Assertions + self.assertIsInstance(self.harness.charm.unit.status, ActiveStatus) + + def test_with_relations( + self, + ) -> NoReturn: + "Test with relations (internal)" + self.initialize_kafka_relation() + self.initialize_mongo_relation() + self.initialize_ro_relation() + # Verifying status + self.assertNotIsInstance(self.harness.charm.unit.status, BlockedStatus) - # Initializing the kafka relation + def initialize_kafka_relation(self): kafka_relation_id = self.harness.add_relation("kafka", "kafka") self.harness.add_relation_unit(kafka_relation_id, "kafka/0") self.harness.update_relation_data( kafka_relation_id, "kafka/0", {"host": "kafka", "port": 9092} ) - # Initializing the mongo relation + def initialize_mongo_relation(self): mongodb_relation_id = self.harness.add_relation("mongodb", "mongodb") self.harness.add_relation_unit(mongodb_relation_id, "mongodb/0") self.harness.update_relation_data( @@ -130,116 +104,231 @@ class TestCharm(unittest.TestCase): {"connection_string": "mongodb://mongo:27017"}, ) - # Initializing the RO relation - ro_relation_id = self.harness.add_relation("ro", "ro") - self.harness.add_relation_unit(ro_relation_id, "ro/0") - self.harness.update_relation_data( - ro_relation_id, "ro/0", {"host": "ro", "port": 9090} - ) - - # Checking if kafka data is stored - self.assertEqual(self.harness.charm.state.message_host, "kafka") - self.assertEqual(self.harness.charm.state.message_port, 9092) - - # Checking if mongodb data is stored - self.assertEqual(self.harness.charm.state.database_uri, "mongodb://mongo:27017") - - # Checking if RO data is stored - self.assertEqual(self.harness.charm.state.ro_host, "ro") - self.assertEqual(self.harness.charm.state.ro_port, 9090) - - # Verifying status - self.assertNotIsInstance(self.harness.charm.unit.status, BlockedStatus) - - pod_spec, _ = self.harness.get_pod_spec() - - self.assertDictEqual(expected_result, pod_spec) - - def test_on_kafka_relation_unit_changed(self) -> NoReturn: - """Test to see if kafka relation is updated.""" - self.harness.charm.on.start.emit() - - self.assertIsNone(self.harness.charm.state.message_host) - self.assertIsNone(self.harness.charm.state.message_port) - - relation_id = self.harness.add_relation("kafka", "kafka") - self.harness.add_relation_unit(relation_id, "kafka/0") - self.harness.update_relation_data( - relation_id, "kafka/0", {"host": "kafka", "port": 9092} - ) - - self.assertEqual(self.harness.charm.state.message_host, "kafka") - self.assertEqual(self.harness.charm.state.message_port, 9092) - - # Verifying status - self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus) - - # Verifying status message - self.assertGreater(len(self.harness.charm.unit.status.message), 0) - self.assertTrue( - self.harness.charm.unit.status.message.startswith("Waiting for ") - ) - self.assertNotIn("kafka", self.harness.charm.unit.status.message) - self.assertIn("mongodb", self.harness.charm.unit.status.message) - self.assertIn("ro", self.harness.charm.unit.status.message) - self.assertTrue(self.harness.charm.unit.status.message.endswith(" relations")) - - def test_on_mongodb_unit_relation_changed(self) -> NoReturn: - """Test to see if mongodb relation is updated.""" - self.harness.charm.on.start.emit() - - self.assertIsNone(self.harness.charm.state.database_uri) - - relation_id = self.harness.add_relation("mongodb", "mongodb") - self.harness.add_relation_unit(relation_id, "mongodb/0") - self.harness.update_relation_data( - relation_id, "mongodb/0", {"connection_string": "mongodb://mongo:27017"} - ) - - self.assertEqual(self.harness.charm.state.database_uri, "mongodb://mongo:27017") - - # Verifying status - self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus) - - # Verifying status message - self.assertGreater(len(self.harness.charm.unit.status.message), 0) - self.assertTrue( - self.harness.charm.unit.status.message.startswith("Waiting for ") - ) - self.assertIn("kafka", self.harness.charm.unit.status.message) - self.assertNotIn("mongodb", self.harness.charm.unit.status.message) - self.assertIn("ro", self.harness.charm.unit.status.message) - self.assertTrue(self.harness.charm.unit.status.message.endswith(" relations")) - - def test_on_ro_unit_relation_changed(self) -> NoReturn: - """Test to see if RO relation is updated.""" - self.harness.charm.on.start.emit() - - self.assertIsNone(self.harness.charm.state.ro_host) - self.assertIsNone(self.harness.charm.state.ro_port) - - relation_id = self.harness.add_relation("ro", "ro") - self.harness.add_relation_unit(relation_id, "ro/0") + def initialize_ro_relation(self): + http_relation_id = self.harness.add_relation("ro", "ro") + self.harness.add_relation_unit(http_relation_id, "ro") self.harness.update_relation_data( - relation_id, "ro/0", {"host": "ro", "port": 9090} + http_relation_id, + "ro", + {"host": "ro", "port": 9090}, ) - self.assertEqual(self.harness.charm.state.ro_host, "ro") - self.assertEqual(self.harness.charm.state.ro_port, 9090) - # Verifying status - self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus) +if __name__ == "__main__": + unittest.main() - # Verifying status message - self.assertGreater(len(self.harness.charm.unit.status.message), 0) - self.assertTrue( - self.harness.charm.unit.status.message.startswith("Waiting for ") - ) - self.assertIn("kafka", self.harness.charm.unit.status.message) - self.assertIn("mongodb", self.harness.charm.unit.status.message) - self.assertNotIn("ro", self.harness.charm.unit.status.message) - self.assertTrue(self.harness.charm.unit.status.message.endswith(" relations")) + +# class TestCharm(unittest.TestCase): +# """LCM Charm unit tests.""" + +# def setUp(self) -> NoReturn: +# """Test setup""" +# self.harness = Harness(LcmCharm) +# self.harness.set_leader(is_leader=True) +# self.harness.begin() + +# def test_on_start_without_relations(self) -> NoReturn: +# """Test installation without any relation.""" +# self.harness.charm.on.start.emit() + +# # Verifying status +# self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus) + +# # Verifying status message +# self.assertGreater(len(self.harness.charm.unit.status.message), 0) +# self.assertTrue( +# self.harness.charm.unit.status.message.startswith("Waiting for ") +# ) +# self.assertIn("kafka", self.harness.charm.unit.status.message) +# self.assertIn("mongodb", self.harness.charm.unit.status.message) +# self.assertIn("ro", self.harness.charm.unit.status.message) +# self.assertTrue(self.harness.charm.unit.status.message.endswith(" relations")) + +# def test_on_start_with_relations(self) -> NoReturn: +# """Test deployment without keystone.""" +# expected_result = { +# "version": 3, +# "containers": [ +# { +# "name": "lcm", +# "imageDetails": self.harness.charm.image.fetch(), +# "imagePullPolicy": "Always", +# "ports": [ +# { +# "name": "lcm", +# "containerPort": 9999, +# "protocol": "TCP", +# } +# ], +# "envConfig": { +# "ALLOW_ANONYMOUS_LOGIN": "yes", +# "OSMLCM_GLOBAL_LOGLEVEL": "INFO", +# "OSMLCM_RO_HOST": "ro", +# "OSMLCM_RO_PORT": 9090, +# "OSMLCM_RO_TENANT": "osm", +# "OSMLCM_MESSAGE_DRIVER": "kafka", +# "OSMLCM_MESSAGE_HOST": "kafka", +# "OSMLCM_MESSAGE_PORT": 9092, +# "OSMLCM_DATABASE_DRIVER": "mongo", +# "OSMLCM_DATABASE_URI": "mongodb://mongo:27017", +# "OSMLCM_DATABASE_COMMONKEY": "osm", +# "OSMLCM_STORAGE_DRIVER": "mongo", +# "OSMLCM_STORAGE_PATH": "/app/storage", +# "OSMLCM_STORAGE_COLLECTION": "files", +# "OSMLCM_STORAGE_URI": "mongodb://mongo:27017", +# "OSMLCM_VCA_HOST": "admin", +# "OSMLCM_VCA_PORT": 17070, +# "OSMLCM_VCA_USER": "admin", +# "OSMLCM_VCA_PUBKEY": "secret", +# "OSMLCM_VCA_SECRET": "secret", +# "OSMLCM_VCA_CACERT": "", +# "OSMLCM_VCA_CLOUD": "localhost", +# "OSMLCM_VCA_K8S_CLOUD": "k8scloud", +# }, +# } +# ], +# "kubernetesResources": {"ingressResources": []}, +# } + +# self.harness.charm.on.start.emit() + +# # Check if kafka datastore is initialized +# self.assertIsNone(self.harness.charm.state.message_host) +# self.assertIsNone(self.harness.charm.state.message_port) + +# # Check if mongodb datastore is initialized +# self.assertIsNone(self.harness.charm.state.database_uri) + +# # Check if RO datastore is initialized +# self.assertIsNone(self.harness.charm.state.ro_host) +# self.assertIsNone(self.harness.charm.state.ro_port) + +# # Initializing the kafka relation +# kafka_relation_id = self.harness.add_relation("kafka", "kafka") +# self.harness.add_relation_unit(kafka_relation_id, "kafka/0") +# self.harness.update_relation_data( +# kafka_relation_id, "kafka/0", {"host": "kafka", "port": 9092} +# ) + +# # Initializing the mongo relation +# mongodb_relation_id = self.harness.add_relation("mongodb", "mongodb") +# self.harness.add_relation_unit(mongodb_relation_id, "mongodb/0") +# self.harness.update_relation_data( +# mongodb_relation_id, +# "mongodb/0", +# {"connection_string": "mongodb://mongo:27017"}, +# ) + +# # Initializing the RO relation +# ro_relation_id = self.harness.add_relation("ro", "ro") +# self.harness.add_relation_unit(ro_relation_id, "ro/0") +# self.harness.update_relation_data( +# ro_relation_id, "ro/0", {"host": "ro", "port": 9090} +# ) + +# # Checking if kafka data is stored +# self.assertEqual(self.harness.charm.state.message_host, "kafka") +# self.assertEqual(self.harness.charm.state.message_port, 9092) + +# # Checking if mongodb data is stored +# self.assertEqual(self.harness.charm.state.database_uri, "mongodb://mongo:27017") + +# # Checking if RO data is stored +# self.assertEqual(self.harness.charm.state.ro_host, "ro") +# self.assertEqual(self.harness.charm.state.ro_port, 9090) + +# # Verifying status +# self.assertNotIsInstance(self.harness.charm.unit.status, BlockedStatus) + +# pod_spec, _ = self.harness.get_pod_spec() + +# self.assertDictEqual(expected_result, pod_spec) + +# def test_on_kafka_relation_unit_changed(self) -> NoReturn: +# """Test to see if kafka relation is updated.""" +# self.harness.charm.on.start.emit() + +# self.assertIsNone(self.harness.charm.state.message_host) +# self.assertIsNone(self.harness.charm.state.message_port) + +# relation_id = self.harness.add_relation("kafka", "kafka") +# self.harness.add_relation_unit(relation_id, "kafka/0") +# self.harness.update_relation_data( +# relation_id, "kafka/0", {"host": "kafka", "port": 9092} +# ) + +# self.assertEqual(self.harness.charm.state.message_host, "kafka") +# self.assertEqual(self.harness.charm.state.message_port, 9092) + +# # Verifying status +# self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus) + +# # Verifying status message +# self.assertGreater(len(self.harness.charm.unit.status.message), 0) +# self.assertTrue( +# self.harness.charm.unit.status.message.startswith("Waiting for ") +# ) +# self.assertNotIn("kafka", self.harness.charm.unit.status.message) +# self.assertIn("mongodb", self.harness.charm.unit.status.message) +# self.assertIn("ro", self.harness.charm.unit.status.message) +# self.assertTrue(self.harness.charm.unit.status.message.endswith(" relations")) + +# def test_on_mongodb_unit_relation_changed(self) -> NoReturn: +# """Test to see if mongodb relation is updated.""" +# self.harness.charm.on.start.emit() + +# self.assertIsNone(self.harness.charm.state.database_uri) + +# relation_id = self.harness.add_relation("mongodb", "mongodb") +# self.harness.add_relation_unit(relation_id, "mongodb/0") +# self.harness.update_relation_data( +# relation_id, "mongodb/0", {"connection_string": "mongodb://mongo:27017"} +# ) + +# self.assertEqual(self.harness.charm.state.database_uri, "mongodb://mongo:27017") + +# # Verifying status +# self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus) + +# # Verifying status message +# self.assertGreater(len(self.harness.charm.unit.status.message), 0) +# self.assertTrue( +# self.harness.charm.unit.status.message.startswith("Waiting for ") +# ) +# self.assertIn("kafka", self.harness.charm.unit.status.message) +# self.assertNotIn("mongodb", self.harness.charm.unit.status.message) +# self.assertIn("ro", self.harness.charm.unit.status.message) +# self.assertTrue(self.harness.charm.unit.status.message.endswith(" relations")) + +# def test_on_ro_unit_relation_changed(self) -> NoReturn: +# """Test to see if RO relation is updated.""" +# self.harness.charm.on.start.emit() + +# self.assertIsNone(self.harness.charm.state.ro_host) +# self.assertIsNone(self.harness.charm.state.ro_port) + +# relation_id = self.harness.add_relation("ro", "ro") +# self.harness.add_relation_unit(relation_id, "ro/0") +# self.harness.update_relation_data( +# relation_id, "ro/0", {"host": "ro", "port": 9090} +# ) + +# self.assertEqual(self.harness.charm.state.ro_host, "ro") +# self.assertEqual(self.harness.charm.state.ro_port, 9090) + +# # Verifying status +# self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus) + +# # Verifying status message +# self.assertGreater(len(self.harness.charm.unit.status.message), 0) +# self.assertTrue( +# self.harness.charm.unit.status.message.startswith("Waiting for ") +# ) +# self.assertIn("kafka", self.harness.charm.unit.status.message) +# self.assertIn("mongodb", self.harness.charm.unit.status.message) +# self.assertNotIn("ro", self.harness.charm.unit.status.message) +# self.assertTrue(self.harness.charm.unit.status.message.endswith(" relations")) -if __name__ == "__main__": - unittest.main() +# if __name__ == "__main__": +# unittest.main()