Skip to content

Commit

Permalink
refactor(e2e): resource option integration test
Browse files Browse the repository at this point in the history
  • Loading branch information
squakez committed Jun 16, 2021
1 parent 3198af0 commit 4ed645b
Show file tree
Hide file tree
Showing 16 changed files with 101 additions and 102 deletions.
84 changes: 51 additions & 33 deletions e2e/common/config/config_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,35 +59,53 @@ func TestRunConfigExamples(t *testing.T) {

// Configmap

t.Run("Textplain configmap", func(t *testing.T) {
// Store a configmap on the cluster
var cmData = make(map[string]string)
cmData["my-configmap-key"] = "my-configmap-content"
NewPlainTextConfigmap(ns, "my-cm", cmData)

Expect(Kamel("run", "-n", ns, "./files/configmap-route.groovy", "--config", "configmap:my-cm").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "configmap-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "configmap-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "configmap-route"), TestTimeoutShort).Should(ContainSubstring(cmData["my-configmap-key"]))
// Store a configmap on the cluster
var cmData = make(map[string]string)
cmData["my-configmap-key"] = "my-configmap-content"
NewPlainTextConfigmap(ns, "my-cm", cmData)

t.Run("Config configmap", func(t *testing.T) {
Expect(Kamel("run", "-n", ns, "./files/config-configmap-route.groovy", "--config", "configmap:my-cm").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "config-configmap-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "config-configmap-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "config-configmap-route"), TestTimeoutShort).Should(ContainSubstring(cmData["my-configmap-key"]))
Expect(Kamel("delete", "--all", "-n", ns).Execute()).To(Succeed())
})

t.Run("Resource configmap", func(t *testing.T) {
// We can reuse the configmap created previously

Expect(Kamel("run", "-n", ns, "./files/resource-configmap-route.groovy", "--resource", "configmap:my-cm").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "resource-configmap-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "resource-configmap-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "resource-configmap-route"), TestTimeoutShort).Should(ContainSubstring(cmData["my-configmap-key"]))
Expect(Kamel("delete", "--all", "-n", ns).Execute()).To(Succeed())
})

// Secret

t.Run("Textplain secret", func(t *testing.T) {
// Store a secret on the cluster
var secData = make(map[string]string)
secData["my-secret-key"] = "very top secret"
NewPlainTextSecret(ns, "my-sec", secData)
// Store a secret on the cluster
var secData = make(map[string]string)
secData["my-secret-key"] = "very top secret"
NewPlainTextSecret(ns, "my-sec", secData)

t.Run("Config secret", func(t *testing.T) {
Expect(Kamel("run", "-n", ns, "./files/config-secret-route.groovy", "--config", "secret:my-sec").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "config-secret-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "config-secret-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "config-secret-route"), TestTimeoutShort).Should(ContainSubstring(secData["my-secret-key"]))
Expect(Kamel("delete", "--all", "-n", ns).Execute()).To(Succeed())
})

Expect(Kamel("run", "-n", ns, "./files/secret-route.groovy", "--config", "secret:my-sec").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "secret-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "secret-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "secret-route"), TestTimeoutShort).Should(ContainSubstring(secData["my-secret-key"]))
t.Run("Resource secret", func(t *testing.T) {
Expect(Kamel("run", "-n", ns, "./files/resource-secret-route.groovy", "--resource", "secret:my-sec").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "resource-secret-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "resource-secret-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "resource-secret-route"), TestTimeoutShort).Should(ContainSubstring(secData["my-secret-key"]))
Expect(Kamel("delete", "--all", "-n", ns).Execute()).To(Succeed())
})

// File Configuration
// Config File

t.Run("Plain text configuration file", func(t *testing.T) {
Expect(Kamel("run", "-n", ns, "./files/config-file-route.groovy", "--config", "file:./files/resources-data.txt").Execute()).To(Succeed())
Expand All @@ -97,21 +115,21 @@ func TestRunConfigExamples(t *testing.T) {
Expect(Kamel("delete", "--all", "-n", ns).Execute()).To(Succeed())
})

// Resources
// Resource File

t.Run("Plain text resource file", func(t *testing.T) {
Expect(Kamel("run", "-n", ns, "./files/resources-route.groovy", "--resource", "./files/resources-data.txt").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "resources-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "resources-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "resources-route"), TestTimeoutShort).Should(ContainSubstring("the file body"))
Expect(Kamel("run", "-n", ns, "./files/resource-file-route.groovy", "--resource", "file:./files/resources-data.txt").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "resource-file-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "resource-file-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "resource-file-route"), TestTimeoutShort).Should(ContainSubstring("the file body"))
Expect(Kamel("delete", "--all", "-n", ns).Execute()).To(Succeed())
})

t.Run("Binary (zip) resource file", func(t *testing.T) {
Expect(Kamel("run", "-n", ns, "./files/resources-binary-route.groovy", "--resource", "./files/resources-data.zip", "-d", "camel-zipfile").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "resources-binary-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "resources-binary-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "resources-binary-route"), TestTimeoutShort).Should(ContainSubstring("the file body"))
Expect(Kamel("run", "-n", ns, "./files/resource-file-binary-route.groovy", "--resource", "file:./files/resources-data.zip", "-d", "camel-zipfile").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "resource-file-binary-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "resource-file-binary-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "resource-file-binary-route"), TestTimeoutShort).Should(ContainSubstring("the file body"))
Expect(Kamel("delete", "--all", "-n", ns).Execute()).To(Succeed())
})

Expand All @@ -122,10 +140,10 @@ func TestRunConfigExamples(t *testing.T) {
expectedBytes, err := gzip.CompressBase64([]byte(source))
assert.Nil(t, err)

Expect(Kamel("run", "-n", ns, "./files/resources-base64-encoded-route.groovy", "--resource", "./files/resources-data.txt", "--compression=true").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "resources-base64-encoded-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "resources-base64-encoded-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "resources-base64-encoded-route"), TestTimeoutShort).Should(ContainSubstring(string(expectedBytes)))
Expect(Kamel("run", "-n", ns, "./files/resource-file-base64-encoded-route.groovy", "--resource", "file:./files/resources-data.txt", "--compression=true").Execute()).To(Succeed())
Eventually(IntegrationPodPhase(ns, "resource-file-base64-encoded-route"), TestTimeoutMedium).Should(Equal(v1.PodRunning))
Eventually(IntegrationCondition(ns, "resource-file-base64-encoded-route", camelv1.IntegrationConditionReady), TestTimeoutShort).Should(Equal(v1.ConditionTrue))
Eventually(IntegrationLogs(ns, "resource-file-base64-encoded-route"), TestTimeoutShort).Should(ContainSubstring(string(expectedBytes)))
Expect(Kamel("delete", "--all", "-n", ns).Execute()).To(Succeed())
})

Expand Down
8 changes: 0 additions & 8 deletions e2e/common/config/files/build-property-file-route.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,6 @@
* limitations under the License.
*/

//
// Provide a build time configuration property file
//
// To run this integrations use:
//
// kamel run --build-property=file:quarkus.properties build-property-file-route.groovy --dev
//

from('timer:build-property')
.routeId('build-property')
.log('The application name: {{quarkus.application.name}}')
8 changes: 0 additions & 8 deletions e2e/common/config/files/build-property-route.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,6 @@
* limitations under the License.
*/

//
// Provide a build time configuration property (the application name)
//
// To run this integrations use:
//
// kamel run --build-property=quarkus.application.name=my-super-application build-property-route.groovy --dev
//

from('timer:build-property')
.routeId('build-property')
.log('The application name: {{quarkus.application.name}}')
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,6 @@
* limitations under the License.
*/

//
// To run this integrations use:
//
// kubectl create configmap my-cm --from-literal=my-configmap-key="configmap content"
// kamel run --config configmap:my-cm configmap-route.groovy --dev
//

from('timer:configmap')
.routeId('configmap')
.setBody()
Expand Down
5 changes: 0 additions & 5 deletions e2e/common/config/files/config-file-route.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,6 @@
* limitations under the License.
*/

//
// To run this integrations use:
// kamel run --config file:resources-data.txt resources-route.groovy --dev
//

from('timer:resources')
.routeId('resources')
.setBody()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,6 @@
* limitations under the License.
*/

//
// To run this integrations use:
//
// kubectl create secret generic my-sec --from-literal=my-secret-key="very top secret"
// kamel run --config secret:my-sec secret-route.groovy --dev
//

from('timer:secret')
.routeId('secret')
.setBody()
Expand Down
6 changes: 0 additions & 6 deletions e2e/common/config/files/property-file-route.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,6 @@
* limitations under the License.
*/

//
// To run this integrations use:
//
// kamel run --property file:my.properties property-file-route.groovy --dev
//

from('timer:property-file')
.routeId('property-file')
.log('property file content is: {{my.key.1}} {{my.key.2}}')
6 changes: 0 additions & 6 deletions e2e/common/config/files/property-route.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,6 @@
* limitations under the License.
*/

//
// To run this integrations use:
//
// kamel run -p my.message=test-property property-route.groovy --dev
//

from('timer:property')
.routeId('property')
.log('property content is: {{my.message}}')
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,5 @@
* limitations under the License.
*/

//
// To run this integrations use:
// kamel run --resource resources-data.txt resources-route.groovy --dev
//

from('file:/etc/camel/resources/?fileName=resources-data.txt&noop=true&idempotent=false')
from('file:/etc/camel/data/configmaps/my-cm/?fileName=my-configmap-key&noop=true&idempotent=false')
.log('resource file content is: ${body}')
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,6 @@
* limitations under the License.
*/

//
// To run this integrations use:
// kamel run --resource resources-data.txt --compression=true resources-base64-encoded-route.groovy --dev
//

from('timer:resources-bas64')
.routeId('resources-base64')
.setBody()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,7 @@
* limitations under the License.
*/

//
// To run this integrations use:
// kamel run --resource resources-data.zip resources-binary-route.groovy -d camel-zipfile --dev
//

from('file:/etc/camel/resources/?fileName=resources-data.zip&noop=true&idempotent=false')
from('file:/etc/camel/data/resources/?fileName=resources-data.zip&noop=true&idempotent=false')
.routeId('resources-zip')
.unmarshal().zipFile()
.log('resource file unzipped content is: ${body}')
20 changes: 20 additions & 0 deletions e2e/common/config/files/resource-file-route.groovy
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
// camel-k: language=groovy
/*
* 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.
*/

from('file:/etc/camel/data/resources/?fileName=resources-data.txt&noop=true&idempotent=false')
.log('resource file content is: ${body}')
20 changes: 20 additions & 0 deletions e2e/common/config/files/resource-secret-route.groovy
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
// camel-k: language=groovy
/*
* 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.
*/

from('file:/etc/camel/data/secrets/my-sec/?fileName=my-secret-key&noop=true&idempotent=false')
.log('resource file content is: ${body}')
2 changes: 1 addition & 1 deletion examples/user-config/resource-file-binary-route.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@
// kamel run --resource resources-data.zip resource-file-binary-route.groovy -d camel-zipfile --dev
//

from('file:/etc/camel/resources/?fileName=resources-data.zip&noop=true&idempotent=false')
from('file:/etc/camel/data/resources/?fileName=resources-data.zip&noop=true&idempotent=false')
.routeId('resources-zip')
.unmarshal().zipFile()
.log('resource file unzipped content is: ${body}')
2 changes: 2 additions & 0 deletions pkg/trait/jvm.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,8 @@ func (t *jvmTrait) Apply(e *Environment) error {
classpath := strset.New()

classpath.Add("./resources")
classpath.Add(configResourcesMountPath)
classpath.Add(dataResourcesMountPath)

for _, artifact := range kit.Status.Artifacts {
classpath.Add(artifact.Target)
Expand Down
9 changes: 5 additions & 4 deletions pkg/trait/jvm_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ package trait

import (
"context"
"fmt"
"sort"
"strings"
"testing"
Expand Down Expand Up @@ -103,12 +104,12 @@ func TestApplyJvmTraitWithDeploymentResource(t *testing.T) {

assert.Nil(t, err)

cp := strset.New("./resources", "/mount/path").List()
cp := strset.New("./resources", configResourcesMountPath, dataResourcesMountPath, "/mount/path").List()
sort.Strings(cp)

assert.Equal(t, []string{
"-cp",
"./resources:/mount/path",
fmt.Sprintf("./resources:%s:%s:/mount/path", configResourcesMountPath, dataResourcesMountPath),
"io.quarkus.bootstrap.runner.QuarkusEntryPoint",
}, d.Spec.Template.Spec.Containers[0].Args)
}
Expand All @@ -135,12 +136,12 @@ func TestApplyJvmTraitWithKNativeResource(t *testing.T) {

assert.Nil(t, err)

cp := strset.New("./resources", "/mount/path").List()
cp := strset.New("./resources", configResourcesMountPath, dataResourcesMountPath, "/mount/path").List()
sort.Strings(cp)

assert.Equal(t, []string{
"-cp",
"./resources:/mount/path",
fmt.Sprintf("./resources:%s:%s:/mount/path", configResourcesMountPath, dataResourcesMountPath),
"io.quarkus.bootstrap.runner.QuarkusEntryPoint",
}, s.Spec.Template.Spec.Containers[0].Args)
}
Expand Down

0 comments on commit 4ed645b

Please sign in to comment.