Module materialize.cloudtest.k8s.api.k8s_secret

Expand source code Browse git
# Copyright Materialize, Inc. and contributors. All rights reserved.
#
# Use of this software is governed by the Business Source License
# included in the LICENSE file at the root of this repository.
#
# As of the Change Date specified in that file, in accordance with
# the Business Source License, use of this software will be governed
# by the Apache License, Version 2.0.


from kubernetes.client import V1Secret
from kubernetes.client.exceptions import ApiException

from materialize.cloudtest import DEFAULT_K8S_NAMESPACE
from materialize.cloudtest.k8s.api.k8s_resource import K8sResource


class K8sSecret(K8sResource):
    secret = V1Secret

    def __init__(self, namespace: str = DEFAULT_K8S_NAMESPACE):
        super().__init__(namespace)

    def kind(self) -> str:
        return "secret"

    # kubectl delete all -all does not clean up secrets
    def create(self) -> None:
        core_v1_api = self.api()

        try:
            assert self.secret.metadata is not None
            assert self.secret.metadata.name is not None
            core_v1_api.delete_namespaced_secret(
                name=self.secret.metadata.name, namespace=self.namespace()
            )
        except ApiException:
            pass
        core_v1_api.create_namespaced_secret(
            body=self.secret, namespace=self.namespace()  # type: ignore
        )

Classes

class K8sSecret (namespace: str = 'default')
Expand source code Browse git
class K8sSecret(K8sResource):
    secret = V1Secret

    def __init__(self, namespace: str = DEFAULT_K8S_NAMESPACE):
        super().__init__(namespace)

    def kind(self) -> str:
        return "secret"

    # kubectl delete all -all does not clean up secrets
    def create(self) -> None:
        core_v1_api = self.api()

        try:
            assert self.secret.metadata is not None
            assert self.secret.metadata.name is not None
            core_v1_api.delete_namespaced_secret(
                name=self.secret.metadata.name, namespace=self.namespace()
            )
        except ApiException:
            pass
        core_v1_api.create_namespaced_secret(
            body=self.secret, namespace=self.namespace()  # type: ignore
        )

Ancestors

Class variables

var secret

NOTE: This class is auto generated by OpenAPI Generator. Ref: https://openapi-generator.tech

Do not edit the class manually.

Methods

def create(self) ‑> None
Expand source code Browse git
def create(self) -> None:
    core_v1_api = self.api()

    try:
        assert self.secret.metadata is not None
        assert self.secret.metadata.name is not None
        core_v1_api.delete_namespaced_secret(
            name=self.secret.metadata.name, namespace=self.namespace()
        )
    except ApiException:
        pass
    core_v1_api.create_namespaced_secret(
        body=self.secret, namespace=self.namespace()  # type: ignore
    )
def kind(self) ‑> str
Expand source code Browse git
def kind(self) -> str:
    return "secret"