From 85db117c4f39040facce7321dd96f46ea5146b5f Mon Sep 17 00:00:00 2001 From: Pietro Pasotti Date: Wed, 31 Jul 2024 12:49:07 +0200 Subject: [PATCH 1/3] fixes to make storage tests pass --- src/charm.py | 6 ++--- tests/unit/test_charm.py | 58 ++++++++++++++++++++++++++++++++++------ 2 files changed, 53 insertions(+), 11 deletions(-) diff --git a/src/charm.py b/src/charm.py index cfc8977..fda3c03 100755 --- a/src/charm.py +++ b/src/charm.py @@ -223,9 +223,9 @@ def _generate_self_signed_certificates(self) -> None: ) cert = generate_certificate(csr=csr, ca=ca, ca_key=ca_pk) - self.container.push(f"{WORKLOAD_PATH}/{CONFIG_MOUNT}/ca.pem", ca) - self.container.push(f"{WORKLOAD_PATH}/{CONFIG_MOUNT}/certificate.pem", cert) - self.container.push(f"{WORKLOAD_PATH}/{CONFIG_MOUNT}/private_key.pem", pk) + self.container.push(f"{WORKLOAD_PATH}/{CONFIG_MOUNT}/ca.pem", ca, make_dirs=True) + self.container.push(f"{WORKLOAD_PATH}/{CONFIG_MOUNT}/certificate.pem", cert, make_dirs=True) + self.container.push(f"{WORKLOAD_PATH}/{CONFIG_MOUNT}/private_key.pem", pk, make_dirs=True) logger.info("[GoCert] Created self signed certificates.") diff --git a/tests/unit/test_charm.py b/tests/unit/test_charm.py index 5915047..b90504e 100644 --- a/tests/unit/test_charm.py +++ b/tests/unit/test_charm.py @@ -2,6 +2,7 @@ # See LICENSE file for licensing details. from typing import Dict, List +from unittest.mock import patch import ops import ops.testing @@ -13,7 +14,9 @@ class TestCharm: @pytest.fixture(scope="function", autouse=True) def context(self): - yield Context(GocertCharm) + # prevent the charm from writing to your host machine filesystem + with patch.object(GocertCharm, "_configure_gocert_config_file"): + yield Context(GocertCharm) @pytest.mark.parametrize( "storages_state", @@ -26,12 +29,10 @@ def context(self): @pytest.mark.parametrize( "containers_state", [ - pytest.param([], id="no-containers"), - pytest.param([{"name": "gocert", "can_connect": False}], id="container-cant-connect"), pytest.param([{"name": "gocert", "can_connect": True}], id="container-can-connect"), ], ) - def test_storage_attached_event( + def test_storage_attached_event_happy_path( self, storages_state: List[Dict[str, str]], containers_state: List[Dict[str, str]], @@ -43,19 +44,60 @@ def test_storage_attached_event( Container(name=container.get("name"), can_connect=container.get("can_connect")) for container in containers_state ], - relations=[Relation(endpoint="juju-info", interface="juju-info")], - networks={"juju-info": Network.default(private_address="4.4.4.4")}, leader=True, ) for storage in storages_state: out = context.run( Event( - f"{storage.get("name")}-storage-attached", + f"{storage.get('name')}-storage-attached", storage=Storage(name=storage.get("name")), ), state, ) - assert out.unit_status == ops.BlockedStatus() + assert out.unit_status == ops.BlockedStatus("storages not yet available") + + @pytest.mark.parametrize( + "storages_state", + [ + pytest.param([{"name": "config"}], id="config-storage"), + pytest.param([{"name": "database"}], id="database-storage"), + pytest.param([{"name": "config"}, {"name": "database"}], id="both-storages"), + ], + ) + @pytest.mark.parametrize( + "containers_state", + [ + # this SHOULD fail, it's ok + pytest.param([], id="no-containers"), + # this SHOULD NOT fail, it currently fails because your charm is missing a leader guard (there's a bug!) + pytest.param([{"name": "gocert", "can_connect": False}], id="container-cant-connect"), + ], + ) + def test_storage_attached_event_errors( + self, + storages_state: List[Dict[str, str]], + containers_state: List[Dict[str, str]], + context: Context, + ): + state = State( + storage=[Storage(name=storage.get("name")) for storage in storages_state], + containers=[ + Container(name=container.get("name"), can_connect=container.get("can_connect")) + for container in containers_state + ], + leader=True, + ) + for storage in storages_state: + # todo catch specific exception + with pytest.raises(Exception): + out = context.run( + Event( + f"{storage.get('name')}-storage-attached", + storage=Storage(name=storage.get("name")), + ), + state, + ) + def test_config_changed_event(self, context: Context): pass From cb8825da2115abd7ed7cb5b24493bde65d42cbc1 Mon Sep 17 00:00:00 2001 From: Pietro Pasotti Date: Wed, 31 Jul 2024 12:50:58 +0200 Subject: [PATCH 2/3] tox env --- tox.ini | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/tox.ini b/tox.ini index 20e0744..7a68f4d 100644 --- a/tox.ini +++ b/tox.ini @@ -79,3 +79,18 @@ commands = --log-cli-level=INFO \ {posargs} \ {[vars]tests_path}/integration + +[testenv:scenario] +description = Scenario tests +deps = + coverage[toml] + pytest + # FIXME unpin as soon as that pr merges + ops-scenario>=6.1.4 + git+http://github.com/canonical/ops-scenario@fix-juju-info-network-get + -r{toxinidir}/requirements.txt +commands = + coverage run \ + --source={[vars]src_path} \ + -m pytest -v --tb native --log-cli-level=INFO -s {posargs} {[vars]tests_path}/unit + coverage report From 3ec4df92fffa22abb88f0d796b1abb6907ed603f Mon Sep 17 00:00:00 2001 From: Pietro Pasotti Date: Wed, 31 Jul 2024 12:57:24 +0200 Subject: [PATCH 3/3] removed useless patch --- tests/unit/test_charm.py | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/tests/unit/test_charm.py b/tests/unit/test_charm.py index b90504e..0d397ca 100644 --- a/tests/unit/test_charm.py +++ b/tests/unit/test_charm.py @@ -14,9 +14,7 @@ class TestCharm: @pytest.fixture(scope="function", autouse=True) def context(self): - # prevent the charm from writing to your host machine filesystem - with patch.object(GocertCharm, "_configure_gocert_config_file"): - yield Context(GocertCharm) + yield Context(GocertCharm) @pytest.mark.parametrize( "storages_state",