This is an automated email from the ASF dual-hosted git repository.

acosentino pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/camel-kamelets.git


The following commit(s) were added to refs/heads/main by this push:
     new 4f1dd7b8 chore: Remove experimental data type Kamelets
4f1dd7b8 is described below

commit 4f1dd7b8d11b3f965ace8342174f09f678a3e68f
Author: Christoph Deppisch <cdeppi...@redhat.com>
AuthorDate: Thu Mar 2 19:18:04 2023 +0100

    chore: Remove experimental data type Kamelets
    
    Remove AWS S3 and AWS DDB experimental Kamelets in favor of using the 
data-type-action Kamelet
---
 docs/modules/ROOT/nav.adoc                         |   2 -
 kamelets/aws-ddb-experimental-sink.kamelet.yaml    | 149 ---------------
 kamelets/aws-ddb-sink.kamelet.yaml                 |  21 ++-
 kamelets/aws-s3-experimental-source.kamelet.yaml   | 168 -----------------
 .../kamelets/catalog/KameletsCatalogTest.java      |  40 ++--
 .../transform/aws/ddb/JsonToDdbModelConverter.java | 201 ---------------------
 .../aws/ddb/JsonToDdbModelConverterTest.java       | 184 -------------------
 .../aws-ddb-experimental-sink.kamelet.yaml         | 149 ---------------
 .../resources/kamelets/aws-ddb-sink.kamelet.yaml   |  21 ++-
 .../aws-s3-experimental-source.kamelet.yaml        | 168 -----------------
 .../aws-ddb-sink-exp/amazonDDBClient.groovy        |  53 ------
 .../aws-ddb-sink-exp/aws-ddb-sink-binding.yaml     |  50 -----
 .../aws-ddb-sink-deleteItem.feature                |  61 -------
 .../aws-ddb-sink-exp/aws-ddb-sink-putItem.feature  |  60 ------
 .../aws-ddb-sink-updateItem.feature                |  64 -------
 test/experimental/aws-ddb-sink-exp/putItem.groovy  |  30 ---
 .../aws-ddb-sink-exp/verifyItems.groovy            |  30 ---
 .../experimental/aws-ddb-sink-exp/yaks-config.yaml |  65 -------
 test/experimental/aws-s3-exp/amazonS3Client.groovy |  36 ----
 .../aws-s3-exp/aws-s3-cloudevents.feature          |  50 -----
 .../experimental/aws-s3-exp/aws-s3-knative.feature |  49 -----
 .../experimental/aws-s3-exp/aws-s3-to-knative.yaml |  47 -----
 test/experimental/aws-s3-exp/yaks-config.yaml      |  67 -------
 23 files changed, 48 insertions(+), 1717 deletions(-)

diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc
index f09da690..3d1249e9 100644
--- a/docs/modules/ROOT/nav.adoc
+++ b/docs/modules/ROOT/nav.adoc
@@ -3,7 +3,6 @@
 * xref:avro-serialize-action.adoc[]
 * xref:aws-cloudtrail-source.adoc[]
 * xref:aws-cloudwatch-sink.adoc[]
-* xref:aws-ddb-experimental-sink.adoc[]
 * xref:aws-ddb-sink.adoc[]
 * xref:aws-ddb-streams-source.adoc[]
 * xref:aws-ec2-sink.adoc[]
@@ -15,7 +14,6 @@
 * xref:aws-redshift-sink.adoc[]
 * xref:aws-redshift-source.adoc[]
 * xref:aws-s3-cdc-source.adoc[]
-* xref:aws-s3-experimental-source.adoc[]
 * xref:aws-s3-sink.adoc[]
 * xref:aws-s3-source.adoc[]
 * xref:aws-s3-streaming-upload-sink.adoc[]
diff --git a/kamelets/aws-ddb-experimental-sink.kamelet.yaml 
b/kamelets/aws-ddb-experimental-sink.kamelet.yaml
deleted file mode 100644
index d2739afa..00000000
--- a/kamelets/aws-ddb-experimental-sink.kamelet.yaml
+++ /dev/null
@@ -1,149 +0,0 @@
-# ---------------------------------------------------------------------------
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements.  See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License.  You may obtain a copy of the License at
-#
-#      http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-# ---------------------------------------------------------------------------
-
-apiVersion: camel.apache.org/v1alpha1
-kind: Kamelet
-metadata:
-  name: aws-ddb-experimental-sink
-  annotations:
-    camel.apache.org/kamelet.support.level: "Experimental"
-    camel.apache.org/catalog.version: "4.0.0-SNAPSHOT"
-    camel.apache.org/kamelet.icon: 
"
 [...]
-    camel.apache.org/provider: "Apache Software Foundation"
-    camel.apache.org/kamelet.group: "AWS DynamoDB Streams"
-    camel.apache.org/kamelet.namespace: "AWS"
-  labels:
-    camel.apache.org/kamelet.type: "sink"
-spec:
-  definition:
-    title: "AWS DynamoDB Experimental Sink"
-    description: |-
-      Send data to Amazon DynamoDB. The sent data inserts, updates, or deletes 
an item on the specified AWS DynamoDB table.
-
-      The basic authentication method for the AWS DynamoDB service is to 
specify an access key and a secret key. These parameters are optional because 
the Kamelet provides a default credentials provider.
-
-      If you use the default credentials provider, the DynamoDB client loads 
the credentials through this provider and doesn't use the basic authentication 
method.
-
-      This Kamelet expects a JSON-formatted body and it must include the 
primary key values that define the DynamoDB item. The mapping between the JSON 
fields and table attribute values is done by key. For example, for  
'{"username":"oscerd", "city":"Rome"}' input, the Kamelet inserts or update an 
item in the specified AWS DynamoDB table and sets the values for the 'username' 
and 'city' attributes.
-      
-      This Kamelet supports experimental input format to specify the data type 
that that is given to this sink. The Kamelet will do best effort to convert the 
provided input type to the required input for the sink.
-    required:
-      - table
-      - region
-    type: object
-    properties:
-      table:
-        title: Table
-        description: The name of the DynamoDB table.
-        type: string
-      accessKey:
-        title: Access Key
-        description: The access key obtained from AWS.
-        type: string
-        format: password
-        x-descriptors:
-        - urn:alm:descriptor:com.tectonic.ui:password
-        - urn:camel:group:credentials
-      secretKey:
-        title: Secret Key
-        description: The secret key obtained from AWS.
-        type: string
-        format: password
-        x-descriptors:
-        - urn:alm:descriptor:com.tectonic.ui:password
-        - urn:camel:group:credentials
-      region:
-        title: AWS Region
-        description: The AWS region to access.
-        type: string
-        enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", 
"ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", 
"af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", 
"ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", 
"sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", 
"ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", 
"cn-northwest-1", "us-isob-east-1", "aws-global", "a [...]
-      operation:
-        title: Operation
-        description: "The operation to perform. The options are PutItem, 
UpdateItem, or DeleteItem."
-        type: string
-        default: PutItem
-        example: PutItem
-      writeCapacity:
-        title: Write Capacity
-        description: The provisioned throughput to reserve for writing 
resources to your table.
-        type: integer
-        default: 1
-      useDefaultCredentialsProvider:
-        title: Default Credentials Provider
-        description: If true, the DynamoDB client loads credentials through a 
default credentials provider. If false, it uses the basic authentication method 
(access key and secret key).
-        type: boolean
-        x-descriptors:
-          - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      uriEndpointOverride:
-        title: Overwrite Endpoint URI
-        description: The overriding endpoint URI. To use this option, you must 
also select the `overrideEndpoint` option.
-        type: string
-      overrideEndpoint:
-        title: Endpoint Overwrite
-        description: Select this option to override the endpoint URI. To use 
this option, you must also provide a URI for the `uriEndpointOverride` option.
-        type: boolean
-        x-descriptors:
-          - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      inputFormat:
-        title: Input Type
-        description: Specify the input type for this Kamelet. The Kamelet will 
automatically apply conversion logic in order to transform message content to 
this data type.
-        type: string
-        default: json
-        example: json
-  types:
-    in:
-      mediaType: application/json
-  dependencies:
-  - mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.0.0-SNAPSHOT
-  - "camel:core"
-  - "camel:jackson"
-  - "camel:aws2-ddb"
-  - "camel:kamelet"
-  template:
-    beans:
-    - name: dataTypeRegistry
-      type: 
"#class:org.apache.camel.kamelets.utils.format.DefaultDataTypeRegistry"
-    - name: inputTypeProcessor
-      type: "#class:org.apache.camel.kamelets.utils.format.DataTypeProcessor"
-      property:
-        - key: scheme
-          value: 'aws2-ddb'
-        - key: format
-          value: '{{inputFormat}}'
-        - key: registry
-          value: '#bean:{{dataTypeRegistry}}'
-    from:
-      uri: "kamelet:source"
-      steps:
-      - set-property:
-          name: operation
-          constant: "{{operation}}"
-      - process:
-          ref: "{{inputTypeProcessor}}"
-      - to:
-          uri: "aws2-ddb:{{table}}"
-          parameters:
-            secretKey: "{{?secretKey}}"
-            accessKey: "{{?accessKey}}"
-            region: "{{region}}"
-            operation: "{{operation}}"
-            writeCapacity: "{{?writeCapacity}}"
-            useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}"
-            uriEndpointOverride: "{{?uriEndpointOverride}}"
-            overrideEndpoint: "{{overrideEndpoint}}"
diff --git a/kamelets/aws-ddb-sink.kamelet.yaml 
b/kamelets/aws-ddb-sink.kamelet.yaml
index bc7a2933..07a7c3cb 100644
--- a/kamelets/aws-ddb-sink.kamelet.yaml
+++ b/kamelets/aws-ddb-sink.kamelet.yaml
@@ -38,7 +38,7 @@ spec:
 
       If you use the default credentials provider, the DynamoDB client loads 
the credentials through this provider and doesn't use the basic authentication 
method.
 
-      This Kamelet expects a JSON-formatted body and it must include the 
primary key values that define the DynamoDB item. The mapping between the JSON 
fields and table attribute values is done by key. For example, for  
'{"username":"oscerd", "city":"Rome"}' input, the Kamelet inserts or update an 
item in the specified AWS DynamoDB table and sets the values for the 'username' 
and 'city' attributes. 
+      This Kamelet expects a JSON-formatted body and it must include the 
primary key values that define the DynamoDB item. The mapping between the JSON 
fields and table attribute values is done by key. For example, for  
'{"username":"oscerd", "city":"Rome"}' input, the Kamelet inserts or update an 
item in the specified AWS DynamoDB table and sets the values for the 'username' 
and 'city' attributes.
     required:
       - table
       - region
@@ -108,17 +108,26 @@ spec:
   - "camel:aws2-ddb"
   - "camel:kamelet"
   template:
+    beans:
+      - name: dataTypeRegistry
+        type: 
"#class:org.apache.camel.kamelets.utils.format.DefaultDataTypeRegistry"
+      - name: dataTypeProcessor
+        type: "#class:org.apache.camel.kamelets.utils.format.DataTypeProcessor"
+        property:
+          - key: scheme
+            value: 'aws2-ddb'
+          - key: format
+            value: 'json'
+          - key: registry
+            value: '#bean:{{dataTypeRegistry}}'
     from:
       uri: "kamelet:source"
       steps:
       - set-property:
           name: operation
           constant: "{{operation}}"
-      - unmarshal:
-          json:
-            library: Jackson
-            unmarshalType: com.fasterxml.jackson.databind.JsonNode
-      - bean: 
"org.apache.camel.kamelets.utils.transform.aws.ddb.JsonToDdbModelConverter"
+      - process:
+          ref: "{{dataTypeProcessor}}"
       - to:
           uri: "aws2-ddb:{{table}}"
           parameters:
diff --git a/kamelets/aws-s3-experimental-source.kamelet.yaml 
b/kamelets/aws-s3-experimental-source.kamelet.yaml
deleted file mode 100644
index af435540..00000000
--- a/kamelets/aws-s3-experimental-source.kamelet.yaml
+++ /dev/null
@@ -1,168 +0,0 @@
-apiVersion: camel.apache.org/v1alpha1
-kind: Kamelet
-metadata:
-  name: aws-s3-experimental-source
-  annotations:
-    camel.apache.org/kamelet.support.level: "Experimental"
-    camel.apache.org/catalog.version: "4.0.0-SNAPSHOT"
-    camel.apache.org/kamelet.icon: 
"
 [...]
-    camel.apache.org/provider: "Apache Software Foundation"
-    camel.apache.org/kamelet.group: "AWS S3"
-    camel.apache.org/kamelet.namespace: "AWS"
-  labels:
-    camel.apache.org/kamelet.type: "source"
-spec:
-  definition:
-    title: "AWS S3 Experimental Source"
-    description: |-
-      Receive data from an Amazon S3 Bucket.
-
-      The basic authentication method for the S3 service is to specify an 
access key and a secret key. These parameters are optional because the Kamelet 
provides a default credentials provider.
-      
-      If you use the default credentials provider, the S3 client loads the 
credentials through this provider and doesn't use the basic authentication 
method.
-
-      Two headers will be duplicated with different names for clarity at sink 
level, CamelAwsS3Key will be duplicated into aws.s3.key and 
CamelAwsS3BucketName will be duplicated in aws.s3.bucket.name.
-      
-      This Kamelet supports experimental output format to specify the data 
type produced by this source. Users of the Kamelet are able to choose from 
different output types.
-    required:
-      - bucketNameOrArn
-      - region
-    type: object
-    properties:
-      bucketNameOrArn:
-        title: Bucket Name
-        description: The S3 Bucket name or Amazon Resource Name (ARN).
-        type: string
-      deleteAfterRead:
-        title: Auto-delete Objects
-        description: Specifies to delete objects after consuming them.
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: true
-      accessKey:
-        title: Access Key
-        description: The access key obtained from AWS.
-        type: string
-        format: password
-        x-descriptors:
-        - urn:alm:descriptor:com.tectonic.ui:password
-        - urn:camel:group:credentials
-      secretKey:
-        title: Secret Key
-        description: The secret key obtained from AWS.
-        type: string
-        format: password
-        x-descriptors:
-        - urn:alm:descriptor:com.tectonic.ui:password
-        - urn:camel:group:credentials
-      region:
-        title: AWS Region
-        description: The AWS region to access.
-        type: string
-        enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", 
"ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", 
"af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", 
"ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", 
"sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", 
"ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", 
"cn-northwest-1", "us-isob-east-1", "aws-global", "a [...]
-      autoCreateBucket:
-        title: Autocreate Bucket
-        description: Specifies to automatically create the S3 bucket.
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      includeBody:
-        title: Include Body
-        description: If true, the exchange is consumed and put into the body 
and closed. If false, the S3Object stream is put raw into the body and the 
headers are set with the S3 object metadata.
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: true
-      prefix:
-        title: Prefix
-        description: The AWS S3 bucket prefix to consider while searching.
-        type: string
-        example: 'folder/'
-      ignoreBody:
-        title: Ignore Body
-        description: If true, the S3 Object body is ignored. Setting this to 
true overrides any behavior defined by the `includeBody` option. If false, the 
S3 object is put in the body.
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      useDefaultCredentialsProvider:
-        title: Default Credentials Provider
-        description: If true, the S3 client loads credentials through a 
default credentials provider. If false, it uses the basic authentication method 
(access key and secret key).
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      uriEndpointOverride:
-        title: Overwrite Endpoint URI
-        description: The overriding endpoint URI. To use this option, you must 
also select the `overrideEndpoint` option.
-        type: string
-      overrideEndpoint:
-        title: Endpoint Overwrite
-        description: Select this option to override the endpoint URI. To use 
this option, you must also provide a URI for the `uriEndpointOverride` option.
-        type: boolean
-        x-descriptors:
-          - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      delay:
-        title: Delay
-        description: The number of milliseconds before the next poll of the 
selected bucket.
-        type: integer
-        default: 500
-      outputFormat:
-        title: Output Type
-        description: Choose the output type for this Kamelet. The Kamelet 
supports different output types and performs automatic message conversion 
according to this data type.
-        type: string
-        default: binary
-        example: binary
-  dependencies:
-    - "camel:core"
-    - "camel:aws2-s3"
-    - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.0.0-SNAPSHOT"
-    - "camel:kamelet"
-  template:
-    beans:
-      - name: dataTypeRegistry
-        type: 
"#class:org.apache.camel.kamelets.utils.format.DefaultDataTypeRegistry"
-      - name: outputTypeProcessor
-        type: "#class:org.apache.camel.kamelets.utils.format.DataTypeProcessor"
-        property:
-          - key: scheme
-            value: 'aws2-s3'
-          - key: format
-            value: '{{outputFormat}}'
-          - key: registry
-            value: '#bean:{{dataTypeRegistry}}'
-      - name: renameHeaders
-        type: 
"#class:org.apache.camel.kamelets.utils.headers.DuplicateNamingHeaders"
-        property:
-          - key: prefix
-            value: 'CamelAwsS3'
-          - key: renamingPrefix
-            value: 'aws.s3.'
-          - key: mode
-            value: 'filtering'
-          - key: selectedHeaders
-            value: 'CamelAwsS3Key,CamelAwsS3BucketName'
-    from:
-      uri: "aws2-s3:{{bucketNameOrArn}}"
-      parameters:
-        autoCreateBucket: "{{autoCreateBucket}}"
-        secretKey: "{{?secretKey}}"
-        accessKey: "{{?accessKey}}"
-        region: "{{region}}"
-        includeBody: "{{includeBody}}"
-        ignoreBody: "{{ignoreBody}}"
-        deleteAfterRead: "{{deleteAfterRead}}"
-        prefix: "{{?prefix}}"
-        useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}"
-        uriEndpointOverride: "{{?uriEndpointOverride}}"
-        overrideEndpoint: "{{overrideEndpoint}}"
-        delay: "{{delay}}"
-      steps:
-      - process:
-          ref: "{{renameHeaders}}"
-      - process:
-          ref: "{{outputTypeProcessor}}"
-      - to: "kamelet:sink"
diff --git 
a/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java
 
b/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java
index 74d06922..e38d8e9d 100644
--- 
a/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java
+++ 
b/library/camel-kamelets-catalog/src/test/java/org/apache/camel/kamelets/catalog/KameletsCatalogTest.java
@@ -16,21 +16,18 @@
  */
 package org.apache.camel.kamelets.catalog;
 
-import io.fabric8.camelk.v1alpha1.Kamelet;
+import java.util.List;
+import java.util.Map;
+
 import io.fabric8.camelk.v1alpha1.JSONSchemaProps;
+import io.fabric8.camelk.v1alpha1.Kamelet;
 import io.github.classgraph.ClassGraph;
 import org.apache.camel.kamelets.catalog.model.KameletTypeEnum;
 import org.apache.camel.tooling.model.ComponentModel;
 import org.junit.jupiter.api.BeforeAll;
 import org.junit.jupiter.api.Test;
 
-import static org.junit.jupiter.api.Assertions.assertEquals;
-import static org.junit.jupiter.api.Assertions.assertNotNull;
-import static org.junit.jupiter.api.Assertions.assertNull;
-import static org.junit.jupiter.api.Assertions.assertTrue;
-
-import java.util.List;
-import java.util.Map;
+import static org.junit.jupiter.api.Assertions.*;
 
 public class KameletsCatalogTest {
     static KameletsCatalog catalog;
@@ -43,20 +40,20 @@ public class KameletsCatalogTest {
     @Test
     void testGetKameletsName() throws Exception {
         List<String> names = catalog.getKameletsName();
-        assertTrue(!names.isEmpty());
+        assertFalse(names.isEmpty());
     }
 
     @Test
     void testGetKamelets() throws Exception {
         Map<String, Kamelet> kamelets = catalog.getKamelets();
-        assertTrue(!kamelets.isEmpty());
+        assertFalse(kamelets.isEmpty());
     }
-    
+
     @Test
     void testGetKameletsDefinition() throws Exception {
         JSONSchemaProps props = catalog.getKameletDefinition("aws-sqs-source");
         assertEquals(14, props.getProperties().keySet().size());
-        assertTrue(props.getProperties().keySet().contains("queueNameOrArn"));
+        assertTrue(props.getProperties().containsKey("queueNameOrArn"));
     }
 
     @Test
@@ -75,7 +72,7 @@ public class KameletsCatalogTest {
     @Test
     void testGetKameletsByProvider() throws Exception {
         List<Kamelet> c = catalog.getKameletByProvider("Apache Software 
Foundation");
-        assertTrue(!c.isEmpty());
+        assertFalse(c.isEmpty());
         c = catalog.getKameletByProvider("Eclipse");
         assertTrue(c.isEmpty());
     }
@@ -83,19 +80,19 @@ public class KameletsCatalogTest {
     @Test
     void testGetKameletsByType() throws Exception {
         List<Kamelet> c = 
catalog.getKameletsByType(KameletTypeEnum.SOURCE.type());
-        assertTrue(!c.isEmpty());
+        assertFalse(c.isEmpty());
         c = catalog.getKameletsByType(KameletTypeEnum.SINK.type());
-        assertTrue(!c.isEmpty());
+        assertFalse(c.isEmpty());
         c = catalog.getKameletsByType(KameletTypeEnum.ACTION.type());
-        assertTrue(!c.isEmpty());
+        assertFalse(c.isEmpty());
     }
 
     @Test
     void testGetKameletsByGroup() throws Exception {
         List<Kamelet> c = catalog.getKameletsByGroups("AWS S3");
-        assertTrue(!c.isEmpty());
+        assertFalse(c.isEmpty());
         c = catalog.getKameletsByGroups("AWS SQS");
-        assertTrue(!c.isEmpty());
+        assertFalse(c.isEmpty());
         c = catalog.getKameletsByGroups("Not-existing-group");
         assertTrue(c.isEmpty());
     }
@@ -103,8 +100,8 @@ public class KameletsCatalogTest {
     @Test
     void testGetKameletsByNamespace() throws Exception {
         List<Kamelet> c = catalog.getKameletsByNamespace("AWS");
-        assertTrue(!c.isEmpty());
-        assertTrue(c.size() == 27);
+        assertFalse(c.isEmpty());
+        assertEquals(25, c.size());
         c = catalog.getKameletsByGroups("Not-existing-group");
         assertTrue(c.isEmpty());
     }
@@ -123,7 +120,7 @@ public class KameletsCatalogTest {
         Map<String, Object> template = 
catalog.getKameletTemplate("aws-sqs-source");
         assertNotNull(template);
     }
-    
+
     @Test
     void testAllKameletFilesLoaded() throws Exception {
         int numberOfKameletFiles = new ClassGraph().acceptPaths("/" + 
KameletsCatalog.KAMELETS_DIR + "/").scan().getAllResources().size();
@@ -263,7 +260,6 @@ public class KameletsCatalogTest {
         assertEquals(expected, headers.size());
     }
 
-
     @Test
     void testGetKameletScheme() throws Exception {
         assertEquals("aws2-s3", catalog.getKameletScheme("aws-s3"));
diff --git 
a/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/transform/aws/ddb/JsonToDdbModelConverter.java
 
b/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/transform/aws/ddb/JsonToDdbModelConverter.java
deleted file mode 100644
index 2a203ed0..00000000
--- 
a/library/camel-kamelets-utils/src/main/java/org/apache/camel/kamelets/utils/transform/aws/ddb/JsonToDdbModelConverter.java
+++ /dev/null
@@ -1,201 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements.  See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License.  You may obtain a copy of the License at
- *
- *      http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-package org.apache.camel.kamelets.utils.transform.aws.ddb;
-
-import java.util.LinkedHashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.stream.Collectors;
-import java.util.stream.Stream;
-
-import com.fasterxml.jackson.core.type.TypeReference;
-import com.fasterxml.jackson.databind.JsonNode;
-import com.fasterxml.jackson.databind.ObjectMapper;
-import org.apache.camel.Exchange;
-import org.apache.camel.ExchangeProperty;
-import org.apache.camel.InvalidPayloadException;
-import org.apache.camel.component.aws2.ddb.Ddb2Constants;
-import org.apache.camel.component.aws2.ddb.Ddb2Operations;
-import software.amazon.awssdk.services.dynamodb.model.AttributeAction;
-import software.amazon.awssdk.services.dynamodb.model.AttributeValue;
-import software.amazon.awssdk.services.dynamodb.model.AttributeValueUpdate;
-import software.amazon.awssdk.services.dynamodb.model.ReturnValue;
-
-/**
- * Maps Json body to DynamoDB attribute value map and sets the attribute map 
as Camel DynamoDB header entries.
- *
- * Json property names map to attribute keys and Json property values map to 
attribute values.
- *
- * During mapping the Json property types resolve to the respective attribute 
types ({@code String, StringSet, Boolean, Number, NumberSet, Map, Null}).
- * Primitive typed arrays in Json get mapped to {@code StringSet} or {@code 
NumberSet} attribute values.
- *
- * For PutItem operation the Json body defines all item attributes.
- *
- * For DeleteItem operation the Json body defines only the primary key 
attributes that identify the item to delete.
- *
- * For UpdateItem operation the Json body defines both key attributes to 
identify the item to be updated and all item attributes tht get updated on the 
item.
- *
- * The given Json body can use "key" and "item" as top level properties.
- * Both define a Json object that will be mapped to respective attribute value 
maps:
- * <pre>{@code
- * {
- *   "key": {},
- *   "item": {}
- * }
- * }
- * </pre>
- * The converter will extract the objects and set respective attribute value 
maps as header entries.
- * This is a comfortable way to define different key and item attribute value 
maps e.g. on UpdateItem operation.
- *
- * In case key and item attribute value maps are identical you can omit the 
special top level properties completely.
- * The converter will map the whole Json body as is then and use it as source 
for the attribute value map.
- */
-public class JsonToDdbModelConverter {
-
-    public String process(@ExchangeProperty("operation") String operation, 
Exchange exchange) throws InvalidPayloadException {
-        if (exchange.getMessage().getHeaders().containsKey(Ddb2Constants.ITEM) 
||
-                
exchange.getMessage().getHeaders().containsKey(Ddb2Constants.KEY)) {
-            return "";
-        }
-
-        ObjectMapper mapper = new ObjectMapper();
-
-        JsonNode jsonBody = 
exchange.getMessage().getMandatoryBody(JsonNode.class);
-
-        JsonNode key = jsonBody.get("key");
-        JsonNode item = jsonBody.get("item");
-
-        Map<String, Object> keyProps;
-        if (key != null) {
-            keyProps = mapper.convertValue(key, new TypeReference<Map<String, 
Object>>(){});
-        } else {
-            keyProps = mapper.convertValue(jsonBody, new 
TypeReference<Map<String, Object>>(){});
-        }
-
-        Map<String, Object> itemProps;
-        if (item != null) {
-            itemProps = mapper.convertValue(item, new 
TypeReference<Map<String, Object>>(){});
-        } else {
-            itemProps = keyProps;
-        }
-
-        final Map<String, AttributeValue> keyMap = 
getAttributeValueMap(keyProps);
-
-        switch (Ddb2Operations.valueOf(operation)) {
-            case PutItem:
-                exchange.getMessage().setHeader(Ddb2Constants.OPERATION, 
Ddb2Operations.PutItem);
-                exchange.getMessage().setHeader(Ddb2Constants.ITEM, 
getAttributeValueMap(itemProps));
-                setHeaderIfNotPresent(Ddb2Constants.RETURN_VALUES, 
ReturnValue.ALL_OLD.toString(), exchange);
-                break;
-            case UpdateItem:
-                exchange.getMessage().setHeader(Ddb2Constants.OPERATION, 
Ddb2Operations.UpdateItem);
-                exchange.getMessage().setHeader(Ddb2Constants.KEY, keyMap);
-                exchange.getMessage().setHeader(Ddb2Constants.UPDATE_VALUES, 
getAttributeValueUpdateMap(itemProps));
-                setHeaderIfNotPresent(Ddb2Constants.RETURN_VALUES, 
ReturnValue.ALL_NEW.toString(), exchange);
-                break;
-            case DeleteItem:
-                exchange.getMessage().setHeader(Ddb2Constants.OPERATION, 
Ddb2Operations.DeleteItem);
-                exchange.getMessage().setHeader(Ddb2Constants.KEY, keyMap);
-                setHeaderIfNotPresent(Ddb2Constants.RETURN_VALUES, 
ReturnValue.ALL_OLD.toString(), exchange);
-                break;
-            default:
-                throw new 
UnsupportedOperationException(String.format("Unsupported operation '%s'", 
operation));
-        }
-
-        return "";
-    }
-
-    private void setHeaderIfNotPresent(String headerName, Object value, 
Exchange exchange) {
-        exchange.getMessage().setHeader(headerName, value);
-    }
-
-    private Map<String, AttributeValue> getAttributeValueMap(Map<String, 
Object> body) {
-        final Map<String, AttributeValue> attributeValueMap = new 
LinkedHashMap<>();
-
-        for (Map.Entry<String, Object> attribute : body.entrySet()) {
-            attributeValueMap.put(attribute.getKey(), 
getAttributeValue(attribute.getValue()));
-        }
-
-        return attributeValueMap;
-    }
-
-    private Map<String, AttributeValueUpdate> 
getAttributeValueUpdateMap(Map<String, Object> body) {
-        final Map<String, AttributeValueUpdate> attributeValueMap = new 
LinkedHashMap<>();
-
-        for (Map.Entry<String, Object> attribute : body.entrySet()) {
-            attributeValueMap.put(attribute.getKey(), 
getAttributeValueUpdate(attribute.getValue()));
-        }
-
-        return attributeValueMap;
-    }
-
-    private static AttributeValue getAttributeValue(Object value) {
-        if (value == null) {
-            return AttributeValue.builder().nul(true).build();
-        }
-
-        if (value instanceof String) {
-            return AttributeValue.builder().s(value.toString()).build();
-        }
-
-        if (value instanceof Integer) {
-            return AttributeValue.builder().n(value.toString()).build();
-        }
-
-        if (value instanceof Boolean) {
-            return AttributeValue.builder().bool((Boolean) value).build();
-        }
-
-        if (value instanceof String[]) {
-            return AttributeValue.builder().ss((String[]) value).build();
-        }
-
-        if (value instanceof int[]) {
-            return AttributeValue.builder().ns(Stream.of((int[]) 
value).map(Object::toString).collect(Collectors.toList())).build();
-        }
-
-        if (value instanceof List) {
-            List<?> values = ((List<?>) value);
-
-            if (values.isEmpty()) {
-                return AttributeValue.builder().ss().build();
-            } else if (values.get(0) instanceof Integer) {
-                return 
AttributeValue.builder().ns(values.stream().map(Object::toString).collect(Collectors.toList())).build();
-            } else {
-                return 
AttributeValue.builder().ss(values.stream().map(Object::toString).collect(Collectors.toList())).build();
-            }
-        }
-
-        if (value instanceof Map) {
-            Map<String, AttributeValue> nestedAttributes = new 
LinkedHashMap<>();
-
-            for (Map.Entry<?, ?> nested : ((Map<?, ?>) value).entrySet()) {
-                nestedAttributes.put(nested.getKey().toString(), 
getAttributeValue(nested.getValue()));
-            }
-
-            return AttributeValue.builder().m(nestedAttributes).build();
-        }
-
-        return AttributeValue.builder().s(value.toString()).build();
-    }
-
-    private static AttributeValueUpdate getAttributeValueUpdate(Object value) {
-        return AttributeValueUpdate.builder()
-                .action(AttributeAction.PUT)
-                .value(getAttributeValue(value)).build();
-    }
-}
\ No newline at end of file
diff --git 
a/library/camel-kamelets-utils/src/test/java/org/apache/camel/kamelets/utils/transform/aws/ddb/JsonToDdbModelConverterTest.java
 
b/library/camel-kamelets-utils/src/test/java/org/apache/camel/kamelets/utils/transform/aws/ddb/JsonToDdbModelConverterTest.java
deleted file mode 100644
index e88dce4e..00000000
--- 
a/library/camel-kamelets-utils/src/test/java/org/apache/camel/kamelets/utils/transform/aws/ddb/JsonToDdbModelConverterTest.java
+++ /dev/null
@@ -1,184 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements.  See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License.  You may obtain a copy of the License at
- *
- *      http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-package org.apache.camel.kamelets.utils.transform.aws.ddb;
-
-import java.util.Map;
-
-import com.fasterxml.jackson.databind.ObjectMapper;
-import org.apache.camel.Exchange;
-import org.apache.camel.component.aws2.ddb.Ddb2Constants;
-import org.apache.camel.component.aws2.ddb.Ddb2Operations;
-import org.apache.camel.impl.DefaultCamelContext;
-import org.apache.camel.support.DefaultExchange;
-import org.junit.jupiter.api.Assertions;
-import org.junit.jupiter.api.BeforeEach;
-import org.junit.jupiter.api.Test;
-import software.amazon.awssdk.services.dynamodb.model.AttributeAction;
-import software.amazon.awssdk.services.dynamodb.model.AttributeValue;
-import software.amazon.awssdk.services.dynamodb.model.AttributeValueUpdate;
-import software.amazon.awssdk.services.dynamodb.model.ReturnValue;
-
-class JsonToDdbModelConverterTest {
-
-    private DefaultCamelContext camelContext;
-
-    private final ObjectMapper mapper = new ObjectMapper();
-
-    private final JsonToDdbModelConverter processor = new 
JsonToDdbModelConverter();
-
-    private final String keyJson = "{" +
-            "\"name\": \"Rajesh Koothrappali\"" +
-            "}";
-
-    private final String itemJson = "{" +
-            "\"name\": \"Rajesh Koothrappali\"," +
-            "\"age\": 29," +
-            "\"super-heroes\": [\"batman\", \"spiderman\", \"wonderwoman\"]," +
-            "\"issues\": [5, 3, 9, 1]," +
-            "\"girlfriend\": null," +
-            "\"doctorate\": true" +
-            "}";
-
-    @BeforeEach
-    void setup() {
-        this.camelContext = new DefaultCamelContext();
-    }
-
-    @Test
-    @SuppressWarnings("unchecked")
-    void shouldMapPutItemHeaders() throws Exception {
-        Exchange exchange = new DefaultExchange(camelContext);
-
-        exchange.getMessage().setBody(mapper.readTree(itemJson));
-
-        processor.process(Ddb2Operations.PutItem.name(), exchange);
-
-        Assertions.assertTrue(exchange.getMessage().hasHeaders());
-        Assertions.assertEquals(Ddb2Operations.PutItem, 
exchange.getMessage().getHeader(Ddb2Constants.OPERATION));
-        Assertions.assertEquals(ReturnValue.ALL_OLD.toString(), 
exchange.getMessage().getHeader(Ddb2Constants.RETURN_VALUES));
-
-        
assertAttributeValueMap(exchange.getMessage().getHeader(Ddb2Constants.ITEM, 
Map.class));
-    }
-
-    @Test
-    @SuppressWarnings("unchecked")
-    void shouldMapUpdateItemHeaders() throws Exception {
-        Exchange exchange = new DefaultExchange(camelContext);
-
-        exchange.getMessage().setBody(mapper.readTree("{\"key\": " + keyJson + 
", \"item\": " + itemJson + "}"));
-
-        processor.process(Ddb2Operations.UpdateItem.name(), exchange);
-
-        Assertions.assertTrue(exchange.getMessage().hasHeaders());
-        Assertions.assertEquals(Ddb2Operations.UpdateItem, 
exchange.getMessage().getHeader(Ddb2Constants.OPERATION));
-        Assertions.assertEquals(ReturnValue.ALL_NEW.toString(), 
exchange.getMessage().getHeader(Ddb2Constants.RETURN_VALUES));
-
-        Map<String, AttributeValue> attributeValueMap = 
exchange.getMessage().getHeader(Ddb2Constants.KEY, Map.class);
-        Assertions.assertEquals(1L, attributeValueMap.size());
-        Assertions.assertEquals(AttributeValue.builder().s("Rajesh 
Koothrappali").build(), attributeValueMap.get("name"));
-
-        
assertAttributeValueUpdateMap(exchange.getMessage().getHeader(Ddb2Constants.UPDATE_VALUES,
 Map.class));
-    }
-
-    @Test
-    @SuppressWarnings("unchecked")
-    void shouldMapDeleteItemHeaders() throws Exception {
-        Exchange exchange = new DefaultExchange(camelContext);
-
-        exchange.getMessage().setBody(mapper.readTree("{\"key\": " + keyJson + 
"}"));
-
-        processor.process(Ddb2Operations.DeleteItem.name(), exchange);
-
-        Assertions.assertTrue(exchange.getMessage().hasHeaders());
-        Assertions.assertEquals(Ddb2Operations.DeleteItem, 
exchange.getMessage().getHeader(Ddb2Constants.OPERATION));
-        Assertions.assertEquals(ReturnValue.ALL_OLD.toString(), 
exchange.getMessage().getHeader(Ddb2Constants.RETURN_VALUES));
-
-        Map<String, AttributeValue> attributeValueMap = 
exchange.getMessage().getHeader(Ddb2Constants.KEY, Map.class);
-        Assertions.assertEquals(1L, attributeValueMap.size());
-        Assertions.assertEquals(AttributeValue.builder().s("Rajesh 
Koothrappali").build(), attributeValueMap.get("name"));
-    }
-
-    @Test
-    @SuppressWarnings("unchecked")
-    void shouldMapNestedObjects() throws Exception {
-        Exchange exchange = new DefaultExchange(camelContext);
-
-        exchange.getMessage().setBody(mapper.readTree("{\"user\":" + itemJson 
+ "}"));
-
-        processor.process(Ddb2Operations.PutItem.name(), exchange);
-
-        Assertions.assertTrue(exchange.getMessage().hasHeaders());
-        Assertions.assertEquals(Ddb2Operations.PutItem, 
exchange.getMessage().getHeader(Ddb2Constants.OPERATION));
-        Assertions.assertEquals(ReturnValue.ALL_OLD.toString(), 
exchange.getMessage().getHeader(Ddb2Constants.RETURN_VALUES));
-
-        Map<String, AttributeValue> attributeValueMap = 
exchange.getMessage().getHeader(Ddb2Constants.ITEM, Map.class);
-        Assertions.assertEquals(1L, attributeValueMap.size());
-
-        
Assertions.assertEquals("AttributeValue(M={name=AttributeValue(S=Rajesh 
Koothrappali), " +
-                "age=AttributeValue(N=29), " +
-                "super-heroes=AttributeValue(SS=[batman, spiderman, 
wonderwoman]), " +
-                "issues=AttributeValue(NS=[5, 3, 9, 1]), " +
-                "girlfriend=AttributeValue(NUL=true), " +
-                "doctorate=AttributeValue(BOOL=true)})", 
attributeValueMap.get("user").toString());
-    }
-
-    @Test
-    @SuppressWarnings("unchecked")
-    void shouldMapEmptyJson() throws Exception {
-        Exchange exchange = new DefaultExchange(camelContext);
-
-        exchange.getMessage().setBody(mapper.readTree("{}"));
-
-        processor.process(Ddb2Operations.PutItem.name(), exchange);
-
-        Assertions.assertTrue(exchange.getMessage().hasHeaders());
-        Assertions.assertEquals(Ddb2Operations.PutItem, 
exchange.getMessage().getHeader(Ddb2Constants.OPERATION));
-        Assertions.assertEquals(ReturnValue.ALL_OLD.toString(), 
exchange.getMessage().getHeader(Ddb2Constants.RETURN_VALUES));
-
-        Map<String, AttributeValue> attributeValueMap = 
exchange.getMessage().getHeader(Ddb2Constants.ITEM, Map.class);
-        Assertions.assertEquals(0L, attributeValueMap.size());
-    }
-
-    @Test()
-    void shouldFailForUnsupportedOperation() throws Exception {
-        Exchange exchange = new DefaultExchange(camelContext);
-
-        exchange.getMessage().setBody(mapper.readTree("{}"));
-
-        Assertions.assertThrows(UnsupportedOperationException.class, () -> 
processor.process(Ddb2Operations.BatchGetItems.name(), exchange));
-    }
-
-    private void assertAttributeValueMap(Map<String, AttributeValue> 
attributeValueMap) {
-        Assertions.assertEquals(6L, attributeValueMap.size());
-        Assertions.assertEquals(AttributeValue.builder().s("Rajesh 
Koothrappali").build(), attributeValueMap.get("name"));
-        Assertions.assertEquals(AttributeValue.builder().n("29").build(), 
attributeValueMap.get("age"));
-        Assertions.assertEquals(AttributeValue.builder().ss("batman", 
"spiderman", "wonderwoman").build(), attributeValueMap.get("super-heroes"));
-        Assertions.assertEquals(AttributeValue.builder().ns("5", "3", "9", 
"1").build(), attributeValueMap.get("issues"));
-        Assertions.assertEquals(AttributeValue.builder().nul(true).build(), 
attributeValueMap.get("girlfriend"));
-        Assertions.assertEquals(AttributeValue.builder().bool(true).build(), 
attributeValueMap.get("doctorate"));
-    }
-
-    private void assertAttributeValueUpdateMap(Map<String, 
AttributeValueUpdate> attributeValueMap) {
-        Assertions.assertEquals(6L, attributeValueMap.size());
-        
Assertions.assertEquals(AttributeValueUpdate.builder().value(AttributeValue.builder().s("Rajesh
 Koothrappali").build()).action(AttributeAction.PUT).build(), 
attributeValueMap.get("name"));
-        
Assertions.assertEquals(AttributeValueUpdate.builder().value(AttributeValue.builder().n("29").build()).action(AttributeAction.PUT).build(),
 attributeValueMap.get("age"));
-        
Assertions.assertEquals(AttributeValueUpdate.builder().value(AttributeValue.builder().ss("batman",
 "spiderman", "wonderwoman").build()).action(AttributeAction.PUT).build(), 
attributeValueMap.get("super-heroes"));
-        
Assertions.assertEquals(AttributeValueUpdate.builder().value(AttributeValue.builder().ns("5",
 "3", "9", "1").build()).action(AttributeAction.PUT).build(), 
attributeValueMap.get("issues"));
-        
Assertions.assertEquals(AttributeValueUpdate.builder().value(AttributeValue.builder().nul(true).build()).action(AttributeAction.PUT).build(),
 attributeValueMap.get("girlfriend"));
-        
Assertions.assertEquals(AttributeValueUpdate.builder().value(AttributeValue.builder().bool(true).build()).action(AttributeAction.PUT).build(),
 attributeValueMap.get("doctorate"));
-    }
-}
\ No newline at end of file
diff --git 
a/library/camel-kamelets/src/main/resources/kamelets/aws-ddb-experimental-sink.kamelet.yaml
 
b/library/camel-kamelets/src/main/resources/kamelets/aws-ddb-experimental-sink.kamelet.yaml
deleted file mode 100644
index d2739afa..00000000
--- 
a/library/camel-kamelets/src/main/resources/kamelets/aws-ddb-experimental-sink.kamelet.yaml
+++ /dev/null
@@ -1,149 +0,0 @@
-# ---------------------------------------------------------------------------
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements.  See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License.  You may obtain a copy of the License at
-#
-#      http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-# ---------------------------------------------------------------------------
-
-apiVersion: camel.apache.org/v1alpha1
-kind: Kamelet
-metadata:
-  name: aws-ddb-experimental-sink
-  annotations:
-    camel.apache.org/kamelet.support.level: "Experimental"
-    camel.apache.org/catalog.version: "4.0.0-SNAPSHOT"
-    camel.apache.org/kamelet.icon: 
"
 [...]
-    camel.apache.org/provider: "Apache Software Foundation"
-    camel.apache.org/kamelet.group: "AWS DynamoDB Streams"
-    camel.apache.org/kamelet.namespace: "AWS"
-  labels:
-    camel.apache.org/kamelet.type: "sink"
-spec:
-  definition:
-    title: "AWS DynamoDB Experimental Sink"
-    description: |-
-      Send data to Amazon DynamoDB. The sent data inserts, updates, or deletes 
an item on the specified AWS DynamoDB table.
-
-      The basic authentication method for the AWS DynamoDB service is to 
specify an access key and a secret key. These parameters are optional because 
the Kamelet provides a default credentials provider.
-
-      If you use the default credentials provider, the DynamoDB client loads 
the credentials through this provider and doesn't use the basic authentication 
method.
-
-      This Kamelet expects a JSON-formatted body and it must include the 
primary key values that define the DynamoDB item. The mapping between the JSON 
fields and table attribute values is done by key. For example, for  
'{"username":"oscerd", "city":"Rome"}' input, the Kamelet inserts or update an 
item in the specified AWS DynamoDB table and sets the values for the 'username' 
and 'city' attributes.
-      
-      This Kamelet supports experimental input format to specify the data type 
that that is given to this sink. The Kamelet will do best effort to convert the 
provided input type to the required input for the sink.
-    required:
-      - table
-      - region
-    type: object
-    properties:
-      table:
-        title: Table
-        description: The name of the DynamoDB table.
-        type: string
-      accessKey:
-        title: Access Key
-        description: The access key obtained from AWS.
-        type: string
-        format: password
-        x-descriptors:
-        - urn:alm:descriptor:com.tectonic.ui:password
-        - urn:camel:group:credentials
-      secretKey:
-        title: Secret Key
-        description: The secret key obtained from AWS.
-        type: string
-        format: password
-        x-descriptors:
-        - urn:alm:descriptor:com.tectonic.ui:password
-        - urn:camel:group:credentials
-      region:
-        title: AWS Region
-        description: The AWS region to access.
-        type: string
-        enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", 
"ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", 
"af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", 
"ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", 
"sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", 
"ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", 
"cn-northwest-1", "us-isob-east-1", "aws-global", "a [...]
-      operation:
-        title: Operation
-        description: "The operation to perform. The options are PutItem, 
UpdateItem, or DeleteItem."
-        type: string
-        default: PutItem
-        example: PutItem
-      writeCapacity:
-        title: Write Capacity
-        description: The provisioned throughput to reserve for writing 
resources to your table.
-        type: integer
-        default: 1
-      useDefaultCredentialsProvider:
-        title: Default Credentials Provider
-        description: If true, the DynamoDB client loads credentials through a 
default credentials provider. If false, it uses the basic authentication method 
(access key and secret key).
-        type: boolean
-        x-descriptors:
-          - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      uriEndpointOverride:
-        title: Overwrite Endpoint URI
-        description: The overriding endpoint URI. To use this option, you must 
also select the `overrideEndpoint` option.
-        type: string
-      overrideEndpoint:
-        title: Endpoint Overwrite
-        description: Select this option to override the endpoint URI. To use 
this option, you must also provide a URI for the `uriEndpointOverride` option.
-        type: boolean
-        x-descriptors:
-          - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      inputFormat:
-        title: Input Type
-        description: Specify the input type for this Kamelet. The Kamelet will 
automatically apply conversion logic in order to transform message content to 
this data type.
-        type: string
-        default: json
-        example: json
-  types:
-    in:
-      mediaType: application/json
-  dependencies:
-  - mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.0.0-SNAPSHOT
-  - "camel:core"
-  - "camel:jackson"
-  - "camel:aws2-ddb"
-  - "camel:kamelet"
-  template:
-    beans:
-    - name: dataTypeRegistry
-      type: 
"#class:org.apache.camel.kamelets.utils.format.DefaultDataTypeRegistry"
-    - name: inputTypeProcessor
-      type: "#class:org.apache.camel.kamelets.utils.format.DataTypeProcessor"
-      property:
-        - key: scheme
-          value: 'aws2-ddb'
-        - key: format
-          value: '{{inputFormat}}'
-        - key: registry
-          value: '#bean:{{dataTypeRegistry}}'
-    from:
-      uri: "kamelet:source"
-      steps:
-      - set-property:
-          name: operation
-          constant: "{{operation}}"
-      - process:
-          ref: "{{inputTypeProcessor}}"
-      - to:
-          uri: "aws2-ddb:{{table}}"
-          parameters:
-            secretKey: "{{?secretKey}}"
-            accessKey: "{{?accessKey}}"
-            region: "{{region}}"
-            operation: "{{operation}}"
-            writeCapacity: "{{?writeCapacity}}"
-            useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}"
-            uriEndpointOverride: "{{?uriEndpointOverride}}"
-            overrideEndpoint: "{{overrideEndpoint}}"
diff --git 
a/library/camel-kamelets/src/main/resources/kamelets/aws-ddb-sink.kamelet.yaml 
b/library/camel-kamelets/src/main/resources/kamelets/aws-ddb-sink.kamelet.yaml
index bc7a2933..07a7c3cb 100644
--- 
a/library/camel-kamelets/src/main/resources/kamelets/aws-ddb-sink.kamelet.yaml
+++ 
b/library/camel-kamelets/src/main/resources/kamelets/aws-ddb-sink.kamelet.yaml
@@ -38,7 +38,7 @@ spec:
 
       If you use the default credentials provider, the DynamoDB client loads 
the credentials through this provider and doesn't use the basic authentication 
method.
 
-      This Kamelet expects a JSON-formatted body and it must include the 
primary key values that define the DynamoDB item. The mapping between the JSON 
fields and table attribute values is done by key. For example, for  
'{"username":"oscerd", "city":"Rome"}' input, the Kamelet inserts or update an 
item in the specified AWS DynamoDB table and sets the values for the 'username' 
and 'city' attributes. 
+      This Kamelet expects a JSON-formatted body and it must include the 
primary key values that define the DynamoDB item. The mapping between the JSON 
fields and table attribute values is done by key. For example, for  
'{"username":"oscerd", "city":"Rome"}' input, the Kamelet inserts or update an 
item in the specified AWS DynamoDB table and sets the values for the 'username' 
and 'city' attributes.
     required:
       - table
       - region
@@ -108,17 +108,26 @@ spec:
   - "camel:aws2-ddb"
   - "camel:kamelet"
   template:
+    beans:
+      - name: dataTypeRegistry
+        type: 
"#class:org.apache.camel.kamelets.utils.format.DefaultDataTypeRegistry"
+      - name: dataTypeProcessor
+        type: "#class:org.apache.camel.kamelets.utils.format.DataTypeProcessor"
+        property:
+          - key: scheme
+            value: 'aws2-ddb'
+          - key: format
+            value: 'json'
+          - key: registry
+            value: '#bean:{{dataTypeRegistry}}'
     from:
       uri: "kamelet:source"
       steps:
       - set-property:
           name: operation
           constant: "{{operation}}"
-      - unmarshal:
-          json:
-            library: Jackson
-            unmarshalType: com.fasterxml.jackson.databind.JsonNode
-      - bean: 
"org.apache.camel.kamelets.utils.transform.aws.ddb.JsonToDdbModelConverter"
+      - process:
+          ref: "{{dataTypeProcessor}}"
       - to:
           uri: "aws2-ddb:{{table}}"
           parameters:
diff --git 
a/library/camel-kamelets/src/main/resources/kamelets/aws-s3-experimental-source.kamelet.yaml
 
b/library/camel-kamelets/src/main/resources/kamelets/aws-s3-experimental-source.kamelet.yaml
deleted file mode 100644
index af435540..00000000
--- 
a/library/camel-kamelets/src/main/resources/kamelets/aws-s3-experimental-source.kamelet.yaml
+++ /dev/null
@@ -1,168 +0,0 @@
-apiVersion: camel.apache.org/v1alpha1
-kind: Kamelet
-metadata:
-  name: aws-s3-experimental-source
-  annotations:
-    camel.apache.org/kamelet.support.level: "Experimental"
-    camel.apache.org/catalog.version: "4.0.0-SNAPSHOT"
-    camel.apache.org/kamelet.icon: 
"
 [...]
-    camel.apache.org/provider: "Apache Software Foundation"
-    camel.apache.org/kamelet.group: "AWS S3"
-    camel.apache.org/kamelet.namespace: "AWS"
-  labels:
-    camel.apache.org/kamelet.type: "source"
-spec:
-  definition:
-    title: "AWS S3 Experimental Source"
-    description: |-
-      Receive data from an Amazon S3 Bucket.
-
-      The basic authentication method for the S3 service is to specify an 
access key and a secret key. These parameters are optional because the Kamelet 
provides a default credentials provider.
-      
-      If you use the default credentials provider, the S3 client loads the 
credentials through this provider and doesn't use the basic authentication 
method.
-
-      Two headers will be duplicated with different names for clarity at sink 
level, CamelAwsS3Key will be duplicated into aws.s3.key and 
CamelAwsS3BucketName will be duplicated in aws.s3.bucket.name.
-      
-      This Kamelet supports experimental output format to specify the data 
type produced by this source. Users of the Kamelet are able to choose from 
different output types.
-    required:
-      - bucketNameOrArn
-      - region
-    type: object
-    properties:
-      bucketNameOrArn:
-        title: Bucket Name
-        description: The S3 Bucket name or Amazon Resource Name (ARN).
-        type: string
-      deleteAfterRead:
-        title: Auto-delete Objects
-        description: Specifies to delete objects after consuming them.
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: true
-      accessKey:
-        title: Access Key
-        description: The access key obtained from AWS.
-        type: string
-        format: password
-        x-descriptors:
-        - urn:alm:descriptor:com.tectonic.ui:password
-        - urn:camel:group:credentials
-      secretKey:
-        title: Secret Key
-        description: The secret key obtained from AWS.
-        type: string
-        format: password
-        x-descriptors:
-        - urn:alm:descriptor:com.tectonic.ui:password
-        - urn:camel:group:credentials
-      region:
-        title: AWS Region
-        description: The AWS region to access.
-        type: string
-        enum: ["ap-south-1", "eu-south-1", "us-gov-east-1", "me-central-1", 
"ca-central-1", "eu-central-1", "us-iso-west-1", "us-west-1", "us-west-2", 
"af-south-1", "eu-north-1", "eu-west-3", "eu-west-2", "eu-west-1", 
"ap-northeast-3", "ap-northeast-2", "ap-northeast-1", "me-south-1", 
"sa-east-1", "ap-east-1", "cn-north-1", "us-gov-west-1", "ap-southeast-1", 
"ap-southeast-2", "us-iso-east-1", "ap-southeast-3", "us-east-1", "us-east-2", 
"cn-northwest-1", "us-isob-east-1", "aws-global", "a [...]
-      autoCreateBucket:
-        title: Autocreate Bucket
-        description: Specifies to automatically create the S3 bucket.
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      includeBody:
-        title: Include Body
-        description: If true, the exchange is consumed and put into the body 
and closed. If false, the S3Object stream is put raw into the body and the 
headers are set with the S3 object metadata.
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: true
-      prefix:
-        title: Prefix
-        description: The AWS S3 bucket prefix to consider while searching.
-        type: string
-        example: 'folder/'
-      ignoreBody:
-        title: Ignore Body
-        description: If true, the S3 Object body is ignored. Setting this to 
true overrides any behavior defined by the `includeBody` option. If false, the 
S3 object is put in the body.
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      useDefaultCredentialsProvider:
-        title: Default Credentials Provider
-        description: If true, the S3 client loads credentials through a 
default credentials provider. If false, it uses the basic authentication method 
(access key and secret key).
-        type: boolean
-        x-descriptors:
-        - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      uriEndpointOverride:
-        title: Overwrite Endpoint URI
-        description: The overriding endpoint URI. To use this option, you must 
also select the `overrideEndpoint` option.
-        type: string
-      overrideEndpoint:
-        title: Endpoint Overwrite
-        description: Select this option to override the endpoint URI. To use 
this option, you must also provide a URI for the `uriEndpointOverride` option.
-        type: boolean
-        x-descriptors:
-          - 'urn:alm:descriptor:com.tectonic.ui:checkbox'
-        default: false
-      delay:
-        title: Delay
-        description: The number of milliseconds before the next poll of the 
selected bucket.
-        type: integer
-        default: 500
-      outputFormat:
-        title: Output Type
-        description: Choose the output type for this Kamelet. The Kamelet 
supports different output types and performs automatic message conversion 
according to this data type.
-        type: string
-        default: binary
-        example: binary
-  dependencies:
-    - "camel:core"
-    - "camel:aws2-s3"
-    - "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.0.0-SNAPSHOT"
-    - "camel:kamelet"
-  template:
-    beans:
-      - name: dataTypeRegistry
-        type: 
"#class:org.apache.camel.kamelets.utils.format.DefaultDataTypeRegistry"
-      - name: outputTypeProcessor
-        type: "#class:org.apache.camel.kamelets.utils.format.DataTypeProcessor"
-        property:
-          - key: scheme
-            value: 'aws2-s3'
-          - key: format
-            value: '{{outputFormat}}'
-          - key: registry
-            value: '#bean:{{dataTypeRegistry}}'
-      - name: renameHeaders
-        type: 
"#class:org.apache.camel.kamelets.utils.headers.DuplicateNamingHeaders"
-        property:
-          - key: prefix
-            value: 'CamelAwsS3'
-          - key: renamingPrefix
-            value: 'aws.s3.'
-          - key: mode
-            value: 'filtering'
-          - key: selectedHeaders
-            value: 'CamelAwsS3Key,CamelAwsS3BucketName'
-    from:
-      uri: "aws2-s3:{{bucketNameOrArn}}"
-      parameters:
-        autoCreateBucket: "{{autoCreateBucket}}"
-        secretKey: "{{?secretKey}}"
-        accessKey: "{{?accessKey}}"
-        region: "{{region}}"
-        includeBody: "{{includeBody}}"
-        ignoreBody: "{{ignoreBody}}"
-        deleteAfterRead: "{{deleteAfterRead}}"
-        prefix: "{{?prefix}}"
-        useDefaultCredentialsProvider: "{{useDefaultCredentialsProvider}}"
-        uriEndpointOverride: "{{?uriEndpointOverride}}"
-        overrideEndpoint: "{{overrideEndpoint}}"
-        delay: "{{delay}}"
-      steps:
-      - process:
-          ref: "{{renameHeaders}}"
-      - process:
-          ref: "{{outputTypeProcessor}}"
-      - to: "kamelet:sink"
diff --git a/test/experimental/aws-ddb-sink-exp/amazonDDBClient.groovy 
b/test/experimental/aws-ddb-sink-exp/amazonDDBClient.groovy
deleted file mode 100644
index 2d332366..00000000
--- a/test/experimental/aws-ddb-sink-exp/amazonDDBClient.groovy
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License.  You may obtain a copy of the License at
- *
- *      http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import software.amazon.awssdk.auth.credentials.AwsBasicCredentials
-import software.amazon.awssdk.auth.credentials.StaticCredentialsProvider
-import software.amazon.awssdk.regions.Region
-import software.amazon.awssdk.services.dynamodb.DynamoDbClient
-import software.amazon.awssdk.services.dynamodb.model.AttributeDefinition
-import software.amazon.awssdk.services.dynamodb.model.KeySchemaElement
-import software.amazon.awssdk.services.dynamodb.model.KeyType
-import software.amazon.awssdk.services.dynamodb.model.ProvisionedThroughput
-import software.amazon.awssdk.services.dynamodb.model.ScalarAttributeType
-
-DynamoDbClient amazonDDBClient = DynamoDbClient
-        .builder()
-        
.endpointOverride(URI.create("${YAKS_TESTCONTAINERS_LOCALSTACK_DYNAMODB_LOCAL_URL}"))
-        .credentialsProvider(StaticCredentialsProvider.create(
-                AwsBasicCredentials.create(
-                        "${YAKS_TESTCONTAINERS_LOCALSTACK_ACCESS_KEY}",
-                        "${YAKS_TESTCONTAINERS_LOCALSTACK_SECRET_KEY}")
-        ))
-        .region(Region.of("${YAKS_TESTCONTAINERS_LOCALSTACK_REGION}"))
-        .build()
-
-amazonDDBClient.createTable(b -> {
-        b.tableName("${aws.ddb.tableName}")
-        b.keySchema(
-                
KeySchemaElement.builder().attributeName("id").keyType(KeyType.HASH).build(),
-        )
-        b.attributeDefinitions(
-                
AttributeDefinition.builder().attributeName("id").attributeType(ScalarAttributeType.N).build(),
-        )
-        b.provisionedThroughput(
-                ProvisionedThroughput.builder()
-                        .readCapacityUnits(1L)
-                        .writeCapacityUnits(1L).build())
-})
-
-return amazonDDBClient
diff --git a/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-binding.yaml 
b/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-binding.yaml
deleted file mode 100644
index e8588422..00000000
--- a/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-binding.yaml
+++ /dev/null
@@ -1,50 +0,0 @@
-# ---------------------------------------------------------------------------
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements.  See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License.  You may obtain a copy of the License at
-#
-#      http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-# ---------------------------------------------------------------------------
-
-apiVersion: camel.apache.org/v1alpha1
-kind: KameletBinding
-metadata:
-  name: aws-ddb-sink-binding
-spec:
-  source:
-    ref:
-      kind: Kamelet
-      apiVersion: camel.apache.org/v1alpha1
-      name: timer-source
-    properties:
-      period: ${timer.source.period}
-      message: '${aws.ddb.json.data}'
-  steps:
-    - ref:
-        kind: Kamelet
-        apiVersion: camel.apache.org/v1alpha1
-        name: log-action
-        properties:
-          showHeaders: true
-  sink:
-    ref:
-      kind: Kamelet
-      apiVersion: camel.apache.org/v1alpha1
-      name: aws-ddb-experimental-sink
-    properties:
-      table: ${aws.ddb.tableName}
-      operation: ${aws.ddb.operation}
-      overrideEndpoint: true
-      uriEndpointOverride: ${YAKS_TESTCONTAINERS_LOCALSTACK_DYNAMODB_LOCAL_URL}
-      accessKey: ${YAKS_TESTCONTAINERS_LOCALSTACK_ACCESS_KEY}
-      secretKey: ${YAKS_TESTCONTAINERS_LOCALSTACK_SECRET_KEY}
-      region: ${YAKS_TESTCONTAINERS_LOCALSTACK_REGION}
diff --git a/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-deleteItem.feature 
b/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-deleteItem.feature
deleted file mode 100644
index fc9f641a..00000000
--- a/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-deleteItem.feature
+++ /dev/null
@@ -1,61 +0,0 @@
-# ---------------------------------------------------------------------------
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements.  See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License.  You may obtain a copy of the License at
-#
-#      http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-# ---------------------------------------------------------------------------
-@experimental
-Feature: AWS DDB Sink - DeleteItem
-
-  Background:
-    Given variables
-      | timer.source.period  | 10000 |
-      | aws.ddb.operation    | DeleteItem |
-      | aws.ddb.tableName    | movies |
-      | aws.ddb.item.id      | 1 |
-      | aws.ddb.item.year    | 1985 |
-      | aws.ddb.item.title   | Back to the future |
-      | aws.ddb.json.data    | {"id": ${aws.ddb.item.id}} |
-
-  Scenario: Create infrastructure
-    # Start LocalStack container
-    Given Enable service DYNAMODB
-    Given start LocalStack container
-    # Create AWS-DDB client
-    Given New global Camel context
-    Given load to Camel registry amazonDDBClient.groovy
-
-  Scenario: Create item on AWS-DDB
-    Given run script putItem.groovy
-    Given variables
-      | maxRetryAttempts  | 20 |
-      | aws.ddb.items     | [[year:AttributeValue(N=${aws.ddb.item.year}), 
id:AttributeValue(N=${aws.ddb.item.id}), 
title:AttributeValue(S=${aws.ddb.item.title})]] |
-    Then apply actions verifyItems.groovy
-
-  Scenario: Verify AWS-DDB Kamelet sink binding
-    # Create binding
-    When load KameletBinding aws-ddb-sink-binding.yaml
-    And KameletBinding aws-ddb-sink-binding is available
-    And Camel K integration aws-ddb-sink-binding is running
-    And Camel K integration aws-ddb-sink-binding should print Started 
aws-ddb-sink-binding
-    # Verify Kamelet sink
-    Given variables
-      | maxRetryAttempts  | 20 |
-      | aws.ddb.items     | [] |
-    Then apply actions verifyItems.groovy
-
-  Scenario: Remove resources
-    # Remove Camel K resources
-    Given delete KameletBinding aws-ddb-sink-binding
-    # Stop LocalStack container
-    Given stop LocalStack container
diff --git a/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-putItem.feature 
b/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-putItem.feature
deleted file mode 100644
index 49460659..00000000
--- a/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-putItem.feature
+++ /dev/null
@@ -1,60 +0,0 @@
-# ---------------------------------------------------------------------------
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements.  See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License.  You may obtain a copy of the License at
-#
-#      http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-# ---------------------------------------------------------------------------
-@experimental
-Feature: AWS DDB Sink - PutItem
-
-  Background:
-    Given variables
-      | timer.source.period  | 10000 |
-      | aws.ddb.operation    | PutItem |
-      | aws.ddb.tableName    | movies |
-      | aws.ddb.item.id      | 1 |
-      | aws.ddb.item.year    | 1977 |
-      | aws.ddb.item.title   | Star Wars IV |
-      | aws.ddb.json.data    | { "id":${aws.ddb.item.id}, 
"year":${aws.ddb.item.year}, "title":"${aws.ddb.item.title}" } |
-
-  Scenario: Create infrastructure
-    # Start LocalStack container
-    Given Enable service DYNAMODB
-    Given start LocalStack container
-    # Create AWS-DDB client
-    Given New global Camel context
-    Given load to Camel registry amazonDDBClient.groovy
-
-  Scenario: Verify empty items on AWS-DDB
-    Given variables
-      | maxRetryAttempts  | 20 |
-      | aws.ddb.items | [] |
-    Then apply actions verifyItems.groovy
-
-  Scenario: Verify AWS-DDB Kamelet sink binding
-    # Create binding
-    When load KameletBinding aws-ddb-sink-binding.yaml
-    And KameletBinding aws-ddb-sink-binding is available
-    And Camel K integration aws-ddb-sink-binding is running
-    And Camel K integration aws-ddb-sink-binding should print Started 
aws-ddb-sink-binding
-    # Verify Kamelet sink
-    Given variables
-      | maxRetryAttempts  | 20 |
-      | aws.ddb.items     | [[year:AttributeValue(N=${aws.ddb.item.year}), 
id:AttributeValue(N=${aws.ddb.item.id}), 
title:AttributeValue(S=${aws.ddb.item.title})]] |
-    Then apply actions verifyItems.groovy
-
-  Scenario: Remove resources
-    # Remove Camel K binding
-    Given delete KameletBinding aws-ddb-sink-binding
-    # Stop LocalStack container
-    Given stop LocalStack container
diff --git a/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-updateItem.feature 
b/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-updateItem.feature
deleted file mode 100644
index be5a4c7e..00000000
--- a/test/experimental/aws-ddb-sink-exp/aws-ddb-sink-updateItem.feature
+++ /dev/null
@@ -1,64 +0,0 @@
-# ---------------------------------------------------------------------------
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements.  See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License.  You may obtain a copy of the License at
-#
-#      http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-# ---------------------------------------------------------------------------
-@experimental
-Feature: AWS DDB Sink - UpdateItem
-
-  Background:
-    Given variables
-      | timer.source.period    | 10000 |
-      | aws.ddb.operation      | UpdateItem |
-      | aws.ddb.tableName      | movies |
-      | aws.ddb.item.id        | 1 |
-      | aws.ddb.item.year      | 1933 |
-      | aws.ddb.item.title     | King Kong |
-      | aws.ddb.item.title.new | King Kong - Historical |
-      | aws.ddb.item.directors | ["Merian C. Cooper", "Ernest B. Schoedsack"] |
-      | aws.ddb.json.data      | { "key": {"id": ${aws.ddb.item.id}}, "item": 
{"title": "${aws.ddb.item.title.new}", "year": ${aws.ddb.item.year}, 
"directors": ${aws.ddb.item.directors}} } |
-
-  Scenario: Create infrastructure
-    # Start LocalStack container
-    Given Enable service DYNAMODB
-    Given start LocalStack container
-    # Create AWS-DDB client
-    Given New global Camel context
-    Given load to Camel registry amazonDDBClient.groovy
-
-  Scenario: Create item on AWS-DDB
-    Given run script putItem.groovy
-    Given variables
-      | maxRetryAttempts  | 20 |
-      | aws.ddb.items | [[year:AttributeValue(N=${aws.ddb.item.year}), 
id:AttributeValue(N=${aws.ddb.item.id}), 
title:AttributeValue(S=${aws.ddb.item.title})]] |
-    Then apply actions verifyItems.groovy
-
-  Scenario: Verify AWS-DDB Kamelet sink binding
-    # Create binding
-    When load KameletBinding aws-ddb-sink-binding.yaml
-    And KameletBinding aws-ddb-sink-binding is available
-    And Camel K integration aws-ddb-sink-binding is running
-    And Camel K integration aws-ddb-sink-binding should print Started 
aws-ddb-sink-binding
-    # Verify Kamelet sink
-    Given variables
-      | maxRetryAttempts  | 200 |
-      | aws.ddb.item.directors | [Ernest B. Schoedsack, Merian C. Cooper] |
-      | aws.ddb.items | [[year:AttributeValue(N=${aws.ddb.item.year}), 
directors:AttributeValue(SS=${aws.ddb.item.directors}), 
id:AttributeValue(N=${aws.ddb.item.id}), 
title:AttributeValue(S=${aws.ddb.item.title.new})]] |
-    Then apply actions verifyItems.groovy
-
-  Scenario: Remove resources
-    # Remove Camel K resources
-    Given delete KameletBinding aws-ddb-sink-binding
-    # Stop LocalStack container
-    Given stop LocalStack container
diff --git a/test/experimental/aws-ddb-sink-exp/putItem.groovy 
b/test/experimental/aws-ddb-sink-exp/putItem.groovy
deleted file mode 100644
index fd482f90..00000000
--- a/test/experimental/aws-ddb-sink-exp/putItem.groovy
+++ /dev/null
@@ -1,30 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License.  You may obtain a copy of the License at
- *
- *      http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import software.amazon.awssdk.services.dynamodb.model.AttributeValue
-import software.amazon.awssdk.services.dynamodb.model.ReturnValue
-
-Map<String, AttributeValue> item = new HashMap<>()
-item.put("id", AttributeValue.builder().n("${aws.ddb.item.id}").build())
-item.put("year", AttributeValue.builder().n("${aws.ddb.item.year}").build())
-item.put("title", AttributeValue.builder().s("${aws.ddb.item.title}").build())
-
-amazonDDBClient.putItem(b -> {
-    b.tableName("${aws.ddb.tableName}")
-    b.item(item)
-    b.returnValues(ReturnValue.ALL_OLD)
-})
diff --git a/test/experimental/aws-ddb-sink-exp/verifyItems.groovy 
b/test/experimental/aws-ddb-sink-exp/verifyItems.groovy
deleted file mode 100644
index b89dad5a..00000000
--- a/test/experimental/aws-ddb-sink-exp/verifyItems.groovy
+++ /dev/null
@@ -1,30 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License.  You may obtain a copy of the License at
- *
- *      http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-$(repeatOnError()
-    .until('i > ${maxRetryAttempts}')
-    .actions(new com.consol.citrus.TestAction() {
-        @Override
-        void execute(com.consol.citrus.context.TestContext context) {
-            try {
-                assert 
context.getVariable('aws.ddb.items').equals(amazonDDBClient.scan(b -> 
b.tableName(context.getVariable('aws.ddb.tableName')))?.items()?.toListString())
-            } catch (AssertionError e) {
-                throw new 
com.consol.citrus.exceptions.CitrusRuntimeException("AWS DDB item verification 
failed", e)
-            }
-        }
-    })
-)
diff --git a/test/experimental/aws-ddb-sink-exp/yaks-config.yaml 
b/test/experimental/aws-ddb-sink-exp/yaks-config.yaml
deleted file mode 100644
index c3fe0232..00000000
--- a/test/experimental/aws-ddb-sink-exp/yaks-config.yaml
+++ /dev/null
@@ -1,65 +0,0 @@
-# ---------------------------------------------------------------------------
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements.  See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License.  You may obtain a copy of the License at
-#
-#      http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-# ---------------------------------------------------------------------------
-
-config:
-  namespace:
-    temporary: false
-  runtime:
-    testcontainers:
-      enabled: true
-    env:
-      - name: YAKS_CAMEL_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: YAKS_CAMELK_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: YAKS_KAMELETS_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: YAKS_JBANG_CAMEL_DUMP_INTEGRATION_OUTPUT
-        value: true
-      - name: YAKS_TESTCONTAINERS_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: CITRUS_TYPE_CONVERTER
-        value: camel
-    resources:
-      - putItem.groovy
-      - verifyItems.groovy
-      - amazonDDBClient.groovy
-      - aws-ddb-sink-binding.yaml
-    cucumber:
-      tags:
-        - "not @ignored"
-    settings:
-      loggers:
-        - name: INTEGRATION_STATUS
-          level: INFO
-        - name: INTEGRATION_LOGS
-          level: INFO
-      dependencies:
-        - groupId: org.apache.camel
-          artifactId: camel-aws2-ddb
-          version: "@camel.version@"
-        - groupId: software.amazon.awssdk
-          artifactId: dynamodb
-          version: "@aws-java-sdk2.version@"
-        - groupId: org.apache.camel
-          artifactId: camel-jackson
-          version: "@camel.version@"
-  dump:
-    enabled: true
-    failedOnly: true
-    includes:
-      - app=camel-k
diff --git a/test/experimental/aws-s3-exp/amazonS3Client.groovy 
b/test/experimental/aws-s3-exp/amazonS3Client.groovy
deleted file mode 100644
index e0d21074..00000000
--- a/test/experimental/aws-s3-exp/amazonS3Client.groovy
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License.  You may obtain a copy of the License at
- *
- *      http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import software.amazon.awssdk.auth.credentials.AwsBasicCredentials
-import software.amazon.awssdk.auth.credentials.StaticCredentialsProvider
-import software.amazon.awssdk.regions.Region
-import software.amazon.awssdk.services.s3.S3Client
-
-S3Client s3 = S3Client
-        .builder()
-        
.endpointOverride(URI.create("${YAKS_TESTCONTAINERS_LOCALSTACK_S3_LOCAL_URL}"))
-        .credentialsProvider(StaticCredentialsProvider.create(
-                AwsBasicCredentials.create(
-                        "${YAKS_TESTCONTAINERS_LOCALSTACK_ACCESS_KEY}",
-                        "${YAKS_TESTCONTAINERS_LOCALSTACK_SECRET_KEY}")
-        ))
-        .region(Region.of("${YAKS_TESTCONTAINERS_LOCALSTACK_REGION}"))
-        .build()
-
-s3.createBucket(b -> b.bucket("${aws.s3.bucketNameOrArn}"))
-
-return s3
diff --git a/test/experimental/aws-s3-exp/aws-s3-cloudevents.feature 
b/test/experimental/aws-s3-exp/aws-s3-cloudevents.feature
deleted file mode 100644
index 6885c58d..00000000
--- a/test/experimental/aws-s3-exp/aws-s3-cloudevents.feature
+++ /dev/null
@@ -1,50 +0,0 @@
-@knative
-@experimental
-Feature: AWS S3 Kamelet - cloud events data type
-
-  Background:
-    Given Knative event consumer timeout is 20000 ms
-    Given variables
-      | aws.s3.output | cloudevents |
-      | aws.s3.bucketNameOrArn | mybucket |
-      | aws.s3.message | Hello from S3 Kamelet |
-      | aws.s3.key | hello.txt |
-
-  Scenario: Create infrastructure
-    # Start LocalStack container
-    Given Enable service S3
-    Given start LocalStack container
-    # Create AWS-S3 client
-    Given New global Camel context
-    Given load to Camel registry amazonS3Client.groovy
-    # Create Knative broker
-    Given create Knative broker default
-    And Knative broker default is running
-
-  Scenario: Verify AWS-S3 Kamelet to Knative binding
-    # Create binding
-    When load KameletBinding aws-s3-to-knative.yaml
-    And KameletBinding aws-s3-to-knative-binding is available
-    And Camel K integration aws-s3-to-knative-binding is running
-    Then Camel K integration aws-s3-to-knative-binding should print Started 
aws-s3-to-knative-binding
-    # Verify Kamelet source
-    Given create Knative event consumer service event-consumer-service
-    Given create Knative trigger event-service-trigger on service 
event-consumer-service with filter on attributes
-      | type   | org.apache.camel.event.aws.s3.getObject |
-    Given Camel exchange message header CamelAwsS3Key="${aws.s3.key}"
-    Given send Camel exchange 
to("aws2-s3://${aws.s3.bucketNameOrArn}?amazonS3Client=#amazonS3Client") with 
body: ${aws.s3.message}
-    Then expect Knative event data: ${aws.s3.message}
-    And verify Knative event
-      | type            | org.apache.camel.event.aws.s3.getObject |
-      | source          | aws.s3.bucket.${aws.s3.bucketNameOrArn} |
-      | subject         | ${aws.s3.key} |
-      | id              | @ignore@ |
-
-  Scenario: Remove resources
-    # Remove Camel K resources
-    Given delete KameletBinding aws-s3-to-knative-binding
-    Given delete Kubernetes service event-consumer-service
-    # Remove Knative resources
-    Given delete Knative broker default
-    # Stop LocalStack container
-    Given stop LocalStack container
diff --git a/test/experimental/aws-s3-exp/aws-s3-knative.feature 
b/test/experimental/aws-s3-exp/aws-s3-knative.feature
deleted file mode 100644
index 10ad5264..00000000
--- a/test/experimental/aws-s3-exp/aws-s3-knative.feature
+++ /dev/null
@@ -1,49 +0,0 @@
-@knative
-@experimental
-Feature: AWS S3 Kamelet - Knative binding
-
-  Background:
-    Given Knative event consumer timeout is 20000 ms
-    Given variables
-      | aws.s3.output | string |
-      | aws.s3.bucketNameOrArn | mybucket |
-      | aws.s3.message | Hello from S3 Kamelet |
-      | aws.s3.key | hello.txt |
-
-  Scenario: Create infrastructure
-    # Start LocalStack container
-    Given Enable service S3
-    Given start LocalStack container
-    # Create AWS-S3 client
-    Given New global Camel context
-    Given load to Camel registry amazonS3Client.groovy
-    # Create Knative broker
-    Given create Knative broker default
-    And Knative broker default is running
-
-  Scenario: Verify AWS-S3 Kamelet to Knative binding
-    # Create binding
-    When load KameletBinding aws-s3-to-knative.yaml
-    And KameletBinding aws-s3-to-knative-binding is available
-    And Camel K integration aws-s3-to-knative-binding is running
-    Then Camel K integration aws-s3-to-knative-binding should print Started 
aws-s3-to-knative-binding
-    # Verify Kamelet source
-    Given create Knative event consumer service event-consumer-service
-    Given create Knative trigger event-service-trigger on service 
event-consumer-service with filter on attributes
-      | type   | org.apache.camel.event |
-    Given Camel exchange message header CamelAwsS3Key="${aws.s3.key}"
-    Given send Camel exchange 
to("aws2-s3://${aws.s3.bucketNameOrArn}?amazonS3Client=#amazonS3Client") with 
body: ${aws.s3.message}
-    Then expect Knative event data: ${aws.s3.message}
-    And verify Knative event
-      | type            | org.apache.camel.event |
-      | source          | @ignore@ |
-      | id              | @ignore@ |
-
-  Scenario: Remove resources
-    # Remove Camel K resources
-    Given delete KameletBinding aws-s3-to-knative-binding
-    Given delete Kubernetes service event-consumer-service
-    # Remove Knative resources
-    Given delete Knative broker default
-    # Stop LocalStack container
-    Given stop LocalStack container
diff --git a/test/experimental/aws-s3-exp/aws-s3-to-knative.yaml 
b/test/experimental/aws-s3-exp/aws-s3-to-knative.yaml
deleted file mode 100644
index 117c3332..00000000
--- a/test/experimental/aws-s3-exp/aws-s3-to-knative.yaml
+++ /dev/null
@@ -1,47 +0,0 @@
-# ---------------------------------------------------------------------------
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements.  See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License.  You may obtain a copy of the License at
-#
-#      http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-# ---------------------------------------------------------------------------
-
-apiVersion: camel.apache.org/v1alpha1
-kind: KameletBinding
-metadata:
-  name: aws-s3-to-knative-binding
-spec:
-  source:
-    ref:
-      kind: Kamelet
-      apiVersion: camel.apache.org/v1alpha1
-      name: aws-s3-experimental-source
-    properties:
-      bucketNameOrArn: ${aws.s3.bucketNameOrArn}
-      overrideEndpoint: true
-      outputFormat: ${aws.s3.output}
-      uriEndpointOverride: ${YAKS_TESTCONTAINERS_LOCALSTACK_S3_URL}
-      accessKey: ${YAKS_TESTCONTAINERS_LOCALSTACK_ACCESS_KEY}
-      secretKey: ${YAKS_TESTCONTAINERS_LOCALSTACK_SECRET_KEY}
-      region: ${YAKS_TESTCONTAINERS_LOCALSTACK_REGION}
-  steps:
-    - ref:
-        kind: Kamelet
-        apiVersion: camel.apache.org/v1alpha1
-        name: log-sink
-      properties:
-        showHeaders: true
-  sink:
-    ref:
-      kind: Broker
-      apiVersion: eventing.knative.dev/v1
-      name: default
diff --git a/test/experimental/aws-s3-exp/yaks-config.yaml 
b/test/experimental/aws-s3-exp/yaks-config.yaml
deleted file mode 100644
index ce37838a..00000000
--- a/test/experimental/aws-s3-exp/yaks-config.yaml
+++ /dev/null
@@ -1,67 +0,0 @@
-# ---------------------------------------------------------------------------
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements.  See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License.  You may obtain a copy of the License at
-#
-#      http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-# ---------------------------------------------------------------------------
-
-config:
-  namespace:
-    temporary: false
-  runtime:
-    testcontainers:
-      enabled: true
-    env:
-      - name: YAKS_CAMEL_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: YAKS_CAMELK_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: YAKS_KAMELETS_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: YAKS_KUBERNETES_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: YAKS_KNATIVE_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: YAKS_JBANG_CAMEL_DUMP_INTEGRATION_OUTPUT
-        value: true
-      - name: YAKS_TESTCONTAINERS_AUTO_REMOVE_RESOURCES
-        value: false
-      - name: CITRUS_TYPE_CONVERTER
-        value: camel
-    resources:
-      - amazonS3Client.groovy
-      - aws-s3-to-knative.yaml
-    cucumber:
-      tags:
-        - "not @ignored and not @knative"
-    settings:
-      loggers:
-        - name: INTEGRATION_STATUS
-          level: INFO
-        - name: INTEGRATION_LOGS
-          level: INFO
-      dependencies:
-        - groupId: org.apache.camel
-          artifactId: camel-aws2-s3
-          version: "@camel.version@"
-        - groupId: software.amazon.awssdk
-          artifactId: s3
-          version: "@aws-java-sdk2.version@"
-        - groupId: org.apache.camel
-          artifactId: camel-jackson
-          version: "@camel.version@"
-  dump:
-    enabled: true
-    failedOnly: true
-    includes:
-      - app=camel-k


Reply via email to