From 956ebf936e49025b0b3983f3fc36fff8219257fe Mon Sep 17 00:00:00 2001 From: Shayan Patel Date: Wed, 4 Dec 2024 21:10:41 +0000 Subject: [PATCH 1/2] Minor adjustments while standarding shared code with the router vm charm --- src/abstract_charm.py | 20 +++++--------------- src/kubernetes_charm.py | 7 ++++--- 2 files changed, 9 insertions(+), 18 deletions(-) diff --git a/src/abstract_charm.py b/src/abstract_charm.py index 3958b7b22..bb01307f0 100644 --- a/src/abstract_charm.py +++ b/src/abstract_charm.py @@ -110,7 +110,7 @@ def _read_only_endpoints(self) -> str: @property @abc.abstractmethod - def _exposed_read_write_endpoint(self) -> typing.Optional[str]: + def _exposed_read_write_endpoints(self) -> typing.Optional[str]: """The exposed read-write endpoint. Only defined in vm charm. @@ -118,7 +118,7 @@ def _exposed_read_write_endpoint(self) -> typing.Optional[str]: @property @abc.abstractmethod - def _exposed_read_only_endpoint(self) -> typing.Optional[str]: + def _exposed_read_only_endpoints(self) -> typing.Optional[str]: """The exposed read-only endpoint. Only defined in vm charm. @@ -134,10 +134,7 @@ def is_externally_accessible(self, *, event) -> typing.Optional[bool]: @property @abc.abstractmethod def _status(self) -> ops.StatusBase: - """Status of the charm. - - Only applies to Kubernetes charm - """ + """Status of the charm.""" @property def _tls_certificate_saved(self) -> bool: @@ -258,13 +255,6 @@ def _reconcile_service(self) -> None: Only applies to Kubernetes charm """ - def _check_service_connectivity(self) -> bool: - """Check if the service is available (connectable with a socket). - - Returns false if Machine charm. Overridden in Kubernetes charm. - """ - return False - @abc.abstractmethod def _reconcile_ports(self, *, event) -> None: """Reconcile exposed ports. @@ -364,8 +354,8 @@ def reconcile(self, event=None) -> None: # noqa: C901 event=event, router_read_write_endpoints=self._read_write_endpoints, router_read_only_endpoints=self._read_only_endpoints, - exposed_read_write_endpoint=self._exposed_read_write_endpoint, - exposed_read_only_endpoint=self._exposed_read_only_endpoint, + exposed_read_write_endpoints=self._exposed_read_write_endpoints, + exposed_read_only_endpoints=self._exposed_read_only_endpoints, shell=workload_.shell, ) self._update_endpoints() diff --git a/src/kubernetes_charm.py b/src/kubernetes_charm.py index 9e502d6ee..0415cd122 100755 --- a/src/kubernetes_charm.py +++ b/src/kubernetes_charm.py @@ -126,7 +126,7 @@ def _status(self) -> ops.StatusBase: return ops.BlockedStatus("K8s service not connectible") def is_externally_accessible(self, *, event) -> typing.Optional[bool]: - """No-op since this charm is exposed with node-port""" + """No-op since this charm is exposed with the expose-external config.""" def _get_service(self) -> typing.Optional[lightkube.resources.core_v1.Service]: """Get the managed k8s service.""" @@ -251,6 +251,7 @@ def _reconcile_service(self) -> None: logger.info(f"Request to create desired service {desired_service_type=} dispatched") def _check_service_connectivity(self) -> bool: + """Check if the service is available (connectable with a socket).""" if not self._get_service() or not isinstance( self.get_workload(event=None), workload.AuthenticatedWorkload ): @@ -402,12 +403,12 @@ def _read_only_endpoints(self) -> str: return self._get_hosts_ports("ro") @property - def _exposed_read_write_endpoint(self) -> typing.Optional[str]: + def _exposed_read_write_endpoints(self) -> typing.Optional[str]: """Only applies to VM charm, so no-op.""" pass @property - def _exposed_read_only_endpoint(self) -> typing.Optional[str]: + def _exposed_read_only_endpoints(self) -> typing.Optional[str]: """Only applies to VM charm, so no-op.""" pass From 6098662c0dbe755b645e7018e21cb12b854e91cd Mon Sep 17 00:00:00 2001 From: Shayan Patel Date: Thu, 5 Dec 2024 11:40:01 +0000 Subject: [PATCH 2/2] Update data platform workflows to v23.1.1 --- .github/workflows/ci.yaml | 4 ++-- .github/workflows/release.yaml | 4 ++-- .github/workflows/sync_docs.yaml | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml index a2857b961..654a9ff0b 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci.yaml @@ -64,7 +64,7 @@ jobs: build: name: Build charm - uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v23.1.0 + uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v23.1.1 with: cache: true @@ -96,7 +96,7 @@ jobs: - lint - unit-test - build - uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v23.1.0 + uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v23.1.1 with: artifact-prefix: ${{ needs.build.outputs.artifact-prefix }} architecture: ${{ matrix.architecture }} diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index ad6ce0146..efe4cce81 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -15,14 +15,14 @@ jobs: build: name: Build charm - uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v23.1.0 + uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v23.1.1 release: name: Release charm needs: - ci-tests - build - uses: canonical/data-platform-workflows/.github/workflows/release_charm.yaml@v23.1.0 + uses: canonical/data-platform-workflows/.github/workflows/release_charm.yaml@v23.1.1 with: channel: 8.0/edge artifact-prefix: ${{ needs.build.outputs.artifact-prefix }} diff --git a/.github/workflows/sync_docs.yaml b/.github/workflows/sync_docs.yaml index 173f04567..ce5c8a908 100644 --- a/.github/workflows/sync_docs.yaml +++ b/.github/workflows/sync_docs.yaml @@ -10,7 +10,7 @@ on: jobs: sync-docs: name: Sync docs from Discourse - uses: canonical/data-platform-workflows/.github/workflows/sync_docs.yaml@v23.1.0 + uses: canonical/data-platform-workflows/.github/workflows/sync_docs.yaml@v23.1.1 with: reviewers: a-velasco,izmalk permissions: