diff --git a/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sCustomResourceWrapper.kt b/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sCustomResourceWrapper.kt
new file mode 100644
index 0000000000000000000000000000000000000000..a20018dd4ec050a6a20adde3f0e4d5b595a61585
--- /dev/null
+++ b/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sCustomResourceWrapper.kt
@@ -0,0 +1,34 @@
+package theodolite.k8s
+
+import io.fabric8.kubernetes.client.CustomResource
+import io.fabric8.kubernetes.client.NamespacedKubernetesClient
+import io.fabric8.kubernetes.client.dsl.base.CustomResourceDefinitionContext
+
+class K8sCustomResourceWrapper(private val map : Map<String,String>) : CustomResource() {
+
+
+    fun deploy(client : NamespacedKubernetesClient){
+        val kind = this.map["kind"]
+        val crds = client.apiextensions().v1beta1().customResourceDefinitions().list()
+        crds.items
+            .filter { crd -> crd.toString().contains("kind=$kind") }
+            .map { crd -> CustomResourceDefinitionContext.fromCrd(crd) }
+            .forEach { context ->
+                client.customResource(context).createOrReplace(client.configuration.namespace,this.map as Map<String, Any>)
+            }
+    }
+
+    fun delete(client : NamespacedKubernetesClient){
+        val kind = this.map["kind"]
+        val metadata = this.map["metadata"] as HashMap<String,String>
+        val name = metadata["name"]
+
+        val crds = client.apiextensions().v1beta1().customResourceDefinitions().list()
+        crds.items
+            .filter { crd -> crd.toString().contains("kind=$kind") }
+            .map { crd -> CustomResourceDefinitionContext.fromCrd(crd)   }
+            .forEach { context ->
+                client.customResource(context).delete(client.configuration.namespace,name) }
+    }
+
+}
\ No newline at end of file
diff --git a/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sManager.kt b/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sManager.kt
index 6a4c5827afdb5e0b40120ca72cc165b2310a71e2..38a07545513d7713f61e484702cb48143ab3aed0 100644
--- a/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sManager.kt
+++ b/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sManager.kt
@@ -7,6 +7,7 @@ import io.fabric8.kubernetes.api.model.apps.Deployment
 import io.fabric8.kubernetes.api.model.apps.StatefulSet
 import io.fabric8.kubernetes.client.NamespacedKubernetesClient
 
+
 class K8sManager(private val client: NamespacedKubernetesClient) {
     fun deploy(resource: KubernetesResource) {
         when (resource) {
@@ -18,6 +19,7 @@ class K8sManager(private val client: NamespacedKubernetesClient) {
                 this.client.configMaps().createOrReplace(resource)
             is StatefulSet ->
                 this.client.apps().statefulSets().createOrReplace(resource)
+            is K8sCustomResourceWrapper -> resource.deploy(client)
             else -> throw IllegalArgumentException("Unknown Kubernetes resource.")
         }
     }
@@ -32,6 +34,7 @@ class K8sManager(private val client: NamespacedKubernetesClient) {
                 this.client.configMaps().delete(resource)
             is StatefulSet ->
                 this.client.apps().statefulSets().delete(resource)
+            is K8sCustomResourceWrapper -> resource.delete(client)
             else -> throw IllegalArgumentException("Unknown Kubernetes resource.")
         }
     }
diff --git a/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sResourceLoader.kt b/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sResourceLoader.kt
index dbc31de96df4d1a4a48347c5f33853c0c98e1f95..658af46611ec7e1e784d286391ecf1e25a25366e 100644
--- a/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sResourceLoader.kt
+++ b/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sResourceLoader.kt
@@ -3,10 +3,10 @@ package theodolite.k8s
 import io.fabric8.kubernetes.api.model.ConfigMap
 import io.fabric8.kubernetes.api.model.KubernetesResource
 import io.fabric8.kubernetes.api.model.Service
-import io.fabric8.kubernetes.api.model.apiextensions.v1beta1.CustomResourceDefinition
 import io.fabric8.kubernetes.api.model.apps.Deployment
 import io.fabric8.kubernetes.client.NamespacedKubernetesClient
 import mu.KotlinLogging
+import theodolite.util.YamlParser
 
 private val logger = KotlinLogging.logger {}
 
@@ -22,12 +22,12 @@ class K8sResourceLoader(private val client: NamespacedKubernetesClient) {
     }
 
     /**
-     * Parses a Service from a service yaml
+     * Parses a CustomResource from a yaml
      * @param path of the yaml file
-     * @return service from fabric8
+     * @return customResource from fabric8
      */
-    private fun loadServiceMonitor(path: String): CustomResourceDefinition {
-        return loadGenericResource(path) { x: String -> client.customResourceDefinitions().load(x).get() }
+    fun loadCustomResource(path: String): K8sCustomResourceWrapper {
+        return loadGenericResource(path) { x: String -> K8sCustomResourceWrapper(YamlParser().parse(path, HashMap<String, String>()::class.java)!!) }
     }
 
     /**
@@ -73,9 +73,17 @@ class K8sResourceLoader(private val client: NamespacedKubernetesClient) {
         return when (kind) {
             "Deployment" -> loadDeployment(path)
             "Service" -> loadService(path)
-            "ServiceMonitor" -> loadServiceMonitor(path)
+            "ServiceMonitor" -> loadCustomResource(path)
             "ConfigMap" -> loadConfigmap(path)
-            else -> throw IllegalArgumentException("Unknown resource with type $kind located in $path")
+            else -> {
+                    logger.warn { "Try to load $kind from $path as Custom ressource" }
+                    try{
+                        loadCustomResource(path)
+                    } catch (e:Exception){
+                        logger.error { "Error during loading of unspecified CustomResource: $e" }
+                        throw e
+                    }
+            }
         }
     }
 }
diff --git a/theodolite-quarkus/src/main/resources/yaml/BenchmarkType.yaml b/theodolite-quarkus/src/main/resources/yaml/BenchmarkType.yaml
index 8f6ee0e05efd4cbb8f6a5cb08d6fc048f1a8ee8a..442434d1818f27c82d784a403c3d12223a44f5b4 100644
--- a/theodolite-quarkus/src/main/resources/yaml/BenchmarkType.yaml
+++ b/theodolite-quarkus/src/main/resources/yaml/BenchmarkType.yaml
@@ -3,6 +3,7 @@ appResource:
   - "uc1-kstreams-deployment.yaml"
   - "aggregation-service.yaml"
   - "jmx-configmap.yaml"
+  - "uc1-service-monitor.yaml"
 loadGenResource:
   - "uc1-load-generator-deployment.yaml"
   - "uc1-load-generator-service.yaml"
diff --git a/theodolite-quarkus/src/main/resources/yaml/service-monitor.yaml b/theodolite-quarkus/src/main/resources/yaml/uc1-service-monitor.yaml
similarity index 100%
rename from theodolite-quarkus/src/main/resources/yaml/service-monitor.yaml
rename to theodolite-quarkus/src/main/resources/yaml/uc1-service-monitor.yaml