Library for easy testing of Kubernetes deployments and operators using Fabric8 API.
KubeResourceManager provides management of resources created during test phases.
Every Kubernetes resource created by KubeResourceManager is automatically deleted at the end of the test, whether the test passed or failed.
So the Kubernetes environment is clean before and after every test run and user do not need to handle it.
Working with Kubernetes resources using KubeResourceManager also provides proper wait for resource readiness.
Instance of KubeResourceManager contains accessible fabric8 kubernetes client and kubernetes cmd client.
These clients are initialized and connected to the test cluster based on the configuration provided by the env file, env variables, or kubeconfig.
For better clarity regarding the test logs, TestFrame library provides ASCII vial separation of tests and test classes.
The MetricsCollector is designed to facilitate the collection of metrics from Kubernetes pods.
It integrates seamlessly with Kubernetes environments to gather and process metrics data efficiently.
For more detailed documentation, see the MetricsCollector README.
LogCollector is utility for collecting logs from the Pods (and their containers), descriptions of Pods, and YAML
descriptions of resources specified by users, collected from the desired Namespaces.
To Log Collector's README contains detailed documentation about this component,
together with the usage and installation.
TestFrame contains also tweaks and utils for better working with kubernetes cluster.
<dependency>
    <groupId>io.skodjob</groupId>
    <artifactId>test-frame-common</artifactId>
    <version>1.1.0</version>
</dependency><repositories>
  <repository>
    <name>Central Portal Snapshots</name>
    <id>central-portal-snapshots</id>
    <url>https://central.sonatype.com/repository/maven-snapshots/</url>
    <releases>
      <enabled>false</enabled>
    </releases>
    <snapshots>
      <enabled>true</enabled>
    </snapshots>
  </repository>
</repositories>
...
<dependency>
    <groupId>io.skodjob</groupId>
    <artifactId>test-frame-common</artifactId>
    <version>1.2.0-SNAPSHOT</version>
</dependency>//...
@ResourceManager
@TestVisualSeparator
class Test {
    //...
}
//...//...
@ResourceManager(cleanResources = false)
@TestVisualSeparator
class Test {
    //...
}
//...//...
@ResourceManager
class Test {
    @Test
    void testMethod() {
        Namespace ns = new NamespaceBuilder().withNewMetadata().withName("test").endMetadata().build();
        KubeResourceManager.get().createResourceWithWait(ns);
        assertNotNull(KubeResourceManager.get().kubeCmdClient().get("namespace", "test"));
        ...
        KubeResourceManager.get().deleteResource(ns);
    }
}
//...KubeResourceManager always uses context default, if you want to use different configured kube cluster context use followed syntax.
//...
@ResourceManager
class Test {
    @Test
    void testMethod() {
        Namespace ns = new NamespaceBuilder().withNewMetadata().withName("test").endMetadata().build();
        KubeResourceManager.get().createResourceWithWait(ns);
        assertNotNull(KubeResourceManager.get().kubeCmdClient().withTimeout(2000).get("namespace", "test"));
        try (var ctx = KubeResourceManager.get().useContext("prod")) {
            Namespace ns = new NamespaceBuilder().withNewMetadata().withName("test-prod").endMetadata().build();
            KubeResourceManager.get().createResourceWithWait(ns);
            assertNotNull(KubeResourceManager.get().kubeCmdClient().get("namespace", "test-prod"));
        }
    }
}
//...Include test-frame-kubernetes or for openshift specific resources include also test-frame-openshift package.
...
<dependency>
    <groupId>io.skodjob</groupId>
    <artifactId>test-frame-common</artifactId>
    <version>1.1.0</version>
</dependency>
<dependency>
    <groupId>io.skodjob</groupId>
    <artifactId>test-frame-kubernetes</artifactId>
    <version>1.1.0</version>
</dependency>
<dependency>
    <groupId>io.skodjob</groupId>
    <artifactId>test-frame-openshift</artifactId>
    <version>1.1.0</version>
</dependency>
...Then register resources which will be handled specifically by KubeResourceManager.
If resource is not registered then it is handled as common kubernetes resource with no special readiness check.
If you have any own resource for your operator then you can implement ResourceType interface with your specific readiness and handling.
KubeResourceManager.get().setResourceTypes(
        new NamespaceType(),
        new JobType(),
        new NetworkPolicyType(),
        new SubsciptionType(),
        new OperatorGroupType()
);Examples are stored in test-frame-test-examples module.
- ENV_FILE - path to YAML file with env variables values
- KUBE_TOKEN - token of Kube access (use instead of username/password)
- KUBE_URL - URL of the cluster (API URL)
- KUBECONFIG - Path to kubeconfig (Overwrites token and url)
- CLIENT_TYPE - Switch between kubectloroccmd client
- KUBE_TOKEN_XXX - token of Kube access (additional cluster use suffix like PROD, DEV, TEST)
- KUBE_URL_XXX - URL of the cluster (additional cluster use suffix like PROD, DEV, TEST)
- KUBECONFIG_XXX - Path to kubeconfig (additional cluster use suffix like PROD, DEV, TEST)
- opendatahub.io operator test suite - odh-e2e
- strimzi.io Strimzi Kafka operator - e2e
- strimzi.io Kafka access operator - e2e
- debezium.io Debezium Operator - e2e
- streamshub Streams E2E - e2e