| // +build integration |
| |
| // To enable compilation of this file in Goland, go to "Settings -> Go -> Vendoring & Build Tags -> Custom Tags" and add "integration" |
| |
| /* |
| 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 e2e |
| |
| import ( |
| "fmt" |
| "path" |
| "testing" |
| "time" |
| |
| "github.com/apache/camel-k/e2e/util" |
| camelv1 "github.com/apache/camel-k/pkg/apis/camel/v1" |
| . "github.com/onsi/gomega" |
| v1 "k8s.io/api/core/v1" |
| ) |
| |
| func TestRunSimpleExamples(t *testing.T) { |
| withNewTestNamespace(t, func(ns string) { |
| Expect(kamel("install", "-n", ns).Execute()).Should(BeNil()) |
| |
| t.Run("run java", func(t *testing.T) { |
| RegisterTestingT(t) |
| Expect(kamel("run", "-n", ns, "files/Java.java").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "java"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "java"), 1*time.Minute).Should(ContainSubstring("Magicstring!")) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| |
| t.Run("run java with properties", func(t *testing.T) { |
| RegisterTestingT(t) |
| Expect(kamel("run", "-n", ns, "files/Prop.java", "--property-file", "files/prop.properties").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "prop"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "prop"), 1*time.Minute).Should(ContainSubstring("Magicstring!")) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| |
| t.Run("run java with master", func(t *testing.T) { |
| RegisterTestingT(t) |
| Expect(kamel("run", "-n", ns, "files/Master.java").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "master"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "master"), 1*time.Minute).Should(ContainSubstring("Magicstring!")) |
| Eventually(configMap(ns, "master-lock"), 10*time.Second).ShouldNot(BeNil()) |
| // Start a second integration with the same lock (it should not start the route) |
| Expect(kamel("run", "-n", ns, "files/Master.java", "--name", "second", |
| "-t", "master.configmap=master", "-t", "master.label-value=master").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "second"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "second"), 1*time.Minute).Should(ContainSubstring("started in")) |
| Eventually(integrationLogs(ns, "second"), 30*time.Second).ShouldNot(ContainSubstring("Magicstring!")) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| |
| t.Run("run xml", func(t *testing.T) { |
| RegisterTestingT(t) |
| Expect(kamel("run", "-n", ns, "files/xml.xml").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "xml"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "xml"), 1*time.Minute).Should(ContainSubstring("Magicstring!")) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| |
| t.Run("run groovy", func(t *testing.T) { |
| RegisterTestingT(t) |
| Expect(kamel("run", "-n", ns, "files/groovy.groovy").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "groovy"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "groovy"), 1*time.Minute).Should(ContainSubstring("Magicstring!")) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| |
| t.Run("run js", func(t *testing.T) { |
| RegisterTestingT(t) |
| Expect(kamel("run", "-n", ns, "files/js.js").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "js"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "js"), 1*time.Minute).Should(ContainSubstring("Magicstring!")) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| |
| t.Run("run kotlin", func(t *testing.T) { |
| RegisterTestingT(t) |
| Expect(kamel("run", "-n", ns, "files/kotlin.kts").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "kotlin"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "kotlin"), 1*time.Minute).Should(ContainSubstring("Magicstring!")) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| |
| t.Run("run yaml", func(t *testing.T) { |
| RegisterTestingT(t) |
| Expect(kamel("run", "-n", ns, "files/yaml.yaml").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "yaml"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "yaml"), 1*time.Minute).Should(ContainSubstring("Magicstring!")) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| |
| t.Run("run yaml Quarkus", func(t *testing.T) { |
| RegisterTestingT(t) |
| Expect(kamel("run", "-n", ns, "--name", "yaml-quarkus", "files/yaml.yaml", "-t", "quarkus.enabled=true").Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, "yaml-quarkus"), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, "yaml-quarkus"), 1*time.Minute).Should(ContainSubstring("running on Quarkus")) |
| Eventually(integrationLogs(ns, "yaml-quarkus"), 1*time.Minute).Should(ContainSubstring("Magicstring!")) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| |
| for _, lang := range camelv1.Languages { |
| t.Run("init run "+string(lang), func(t *testing.T) { |
| RegisterTestingT(t) |
| dir := util.MakeTempDir(t) |
| itName := fmt.Sprintf("init%s", string(lang)) // e.g. initjava |
| fileName := fmt.Sprintf("%s.%s", itName, string(lang)) // e.g. initjava.java |
| file := path.Join(dir, fileName) |
| Expect(kamel("init", file).Execute()).Should(BeNil()) |
| Expect(kamel("run", "-n", ns, file).Execute()).Should(BeNil()) |
| Eventually(integrationPodPhase(ns, itName), 5*time.Minute).Should(Equal(v1.PodRunning)) |
| Eventually(integrationLogs(ns, itName), 1*time.Minute).Should(ContainSubstring(languageInitExpectedString(lang))) |
| Expect(kamel("delete", "--all", "-n", ns).Execute()).Should(BeNil()) |
| }) |
| } |
| }) |
| } |
| |
| func languageInitExpectedString(lang camelv1.Language) string { |
| langDesc := string(lang) |
| if lang == camelv1.LanguageKotlin { |
| langDesc = "kotlin" |
| } |
| return fmt.Sprintf(" Hello Camel K from %s", langDesc) |
| } |