sunbeam-charms/charms/placement-k8s/tests/unit/test_placement_charm.py
Hemanth Nakkina 4749f5331a Add osci yaml
Add project templates and variables to osci.yaml
Add rename script to change built charm name to
charm_build_name defined in osci.yaml

Change-Id: I2cafc03f48a978c30bbff1b21d6e3c2db309f5fe
2022-09-08 16:42:28 +05:30

121 lines
3.8 KiB
Python

#!/usr/bin/env python3
# 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 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 mock
import textwrap
import charm
import ops_sunbeam.test_utils as test_utils
class _PlacementXenaOperatorCharm(charm.PlacementXenaOperatorCharm):
def __init__(self, framework):
self.seen_events = []
super().__init__(framework)
def _log_event(self, event):
self.seen_events.append(type(event).__name__)
def configure_charm(self, event):
super().configure_charm(event)
self._log_event(event)
@property
def public_ingress_address(self):
return 'placement.juju'
class TestPlacementOperatorCharm(test_utils.CharmTestCase):
PATCHES = []
maxDiff = None
@mock.patch(
'charms.observability_libs.v0.kubernetes_service_patch.'
'KubernetesServicePatch')
def setUp(self, mock_patch):
super().setUp(charm, self.PATCHES)
self.harness = test_utils.get_harness(
_PlacementXenaOperatorCharm,
container_calls=self.container_calls)
# clean up events that were dynamically defined,
# otherwise we get issues because they'll be redefined,
# which is not allowed.
from charms.data_platform_libs.v0.database_requires import (
DatabaseEvents
)
for attr in (
"database_database_created",
"database_endpoints_changed",
"database_read_only_endpoints_changed",
):
try:
delattr(DatabaseEvents, attr)
except AttributeError:
pass
self.addCleanup(self.harness.cleanup)
test_utils.add_complete_ingress_relation(self.harness)
self.harness.begin()
def test_pebble_ready_handler(self):
self.assertEqual(self.harness.charm.seen_events, [])
test_utils.set_all_pebbles_ready(self.harness)
self.assertEqual(self.harness.charm.seen_events, ['PebbleReadyEvent'])
def test_all_relations(self):
self.harness.set_leader()
test_utils.set_all_pebbles_ready(self.harness)
test_utils.add_all_relations(self.harness)
setup_cmds = [
['a2ensite', 'wsgi-placement-api'],
['sudo', '-u', 'placement', 'placement-manage', 'db', 'sync']]
for cmd in setup_cmds:
self.assertIn(cmd, self.container_calls.execute['placement-api'])
self.check_file(
'placement-api',
'/etc/apache2/sites-available/wsgi-placement-api.conf')
expect_entries = """
[DEFAULT]
debug = False
use_syslog = true
[api]
auth_strategy = keystone
[placement_database]
connection = mysql+pymysql://foo:hardpassword@10.0.0.10/placement_api
[keystone_authtoken]
www_authenticate_uri = http://keystone.internal:5000
auth_url = http://keystone.internal:5000
auth_type = password
project_domain_name = None
user_domain_name = None
project_name = None
username = None
password = svcpass1
[placement]
randomize_allocation_candidates = true
"""
expect_string = textwrap.dedent(expect_entries).lstrip()
self.check_file(
'placement-api',
'/etc/placement/placement.conf',
contents=expect_string)