From ab8f79030852c0bf60a698b862a42c7241316413 Mon Sep 17 00:00:00 2001 From: Andrea Tarocchi Date: Thu, 12 Oct 2023 12:20:37 +0200 Subject: [PATCH] Added build-catalog-tool-timeout parameter to install command. Added CAMEL_K_BUILD_CATALOG_TOOL_TIMEOUT to e2e tests to leverage the new install parameter. Updated doc. --- .gitignore | 2 ++ docs/modules/ROOT/pages/contributing/e2e.adoc | 13 ++++++++++--- .../ROOT/pages/installation/advanced/advanced.adoc | 1 + e2e/support/test_support.go | 6 ++++++ pkg/cmd/install.go | 12 ++++++++++++ pkg/cmd/install_test.go | 7 +++++++ 6 files changed, 38 insertions(+), 3 deletions(-) diff --git a/.gitignore b/.gitignore index 767e219e61..90d1d69bbe 100644 --- a/.gitignore +++ b/.gitignore @@ -180,3 +180,5 @@ pkg/resources/resources.go # MAC OS files .DS_Store +# Audit logs file +logs.txt diff --git a/docs/modules/ROOT/pages/contributing/e2e.adoc b/docs/modules/ROOT/pages/contributing/e2e.adoc index 337f0ab86a..5fb7d72320 100644 --- a/docs/modules/ROOT/pages/contributing/e2e.adoc +++ b/docs/modules/ROOT/pages/contributing/e2e.adoc @@ -31,15 +31,22 @@ This is the list of the groups we are using (please, notice that they can slight * builder (`make test-builder`) * common (`make test-common`) * commonwithcustominstall (`make test-common-with-custom-install`) - * install (`make test-install` and `make test-install-olm`) + * install (`make test-install`, `make test-install-olm` and `make test-install-upgrade`) * knative (`make test-knative`) * native (`make test-quarkus-native` and `make test-quarkus-native-high-memory`) * telemetry (`make test-telemetry`) - * yaks (run only in CI) Each group tests a specific feature of Camel K. Typically any new test should be falling under the `common` group, unless it belongs to any other category or it requires some particular customization. As an example, `telemetry` requires the configuration of an OTLP Collector, reason why it requires its own group. If the test still is a common one but needs to perform customization on the Camel K Operator, then, it should be developed under `commonwithcustominstall`: as an example, we have there tests which requires the configuration of a Maven proxy. -It's important to know that `common` is used as smoke test in the nightly release process. We want to keep this group of test as fast as possible. +It's important to know that a subset of `common` named `test-smoke` is used as smoke test in the nightly release process. We want to keep this group of test as fast as possible. + +=== Configure End To End tests runs with env vars +Some e2e test runs parameters can be configured usually with env vars. +Most of them are located at https://github.com/apache/camel-k/tree/main/e2e/support/test_support.go[e2e/support/test_support.go] in `init` and `kamelInstallWithContext` functions. +A list of the most commonly used: + + * `CAMEL_K_TEST_SKIP_PROBLEMATIC`: set it to `true` to skip tests that might fail. + * `CAMEL_K_BUILD_CATALOG_TOOL_TIMEOUT`: set timeout time (in seconds) for building the catalog tool image is the default 2 minutes are not enough for your setup. [[testing-operator]] == Testing Operator under development diff --git a/docs/modules/ROOT/pages/installation/advanced/advanced.adoc b/docs/modules/ROOT/pages/installation/advanced/advanced.adoc index 595f9cceff..4052513373 100644 --- a/docs/modules/ROOT/pages/installation/advanced/advanced.adoc +++ b/docs/modules/ROOT/pages/installation/advanced/advanced.adoc @@ -28,6 +28,7 @@ We have several configuration used to influence the building of an integration: --build-strategy string Set the build strategy --build-order-strategy string Set the build order strategy --build-timeout string Set how long the build process can last +--build-catalog-tool-timeout string Set how long the catalogtool image build can last ``` A very important set of configuration you can provide is related to Maven: ``` diff --git a/e2e/support/test_support.go b/e2e/support/test_support.go index ce7389262e..d6908752ee 100644 --- a/e2e/support/test_support.go +++ b/e2e/support/test_support.go @@ -291,6 +291,12 @@ func kamelInstallWithContext(ctx context.Context, operatorID string, namespace s installArgs = append(installArgs, "--operator-image-pull-policy", opImagePullPolicy) } + opBuildCatalogToolTimeout := os.Getenv("CAMEL_K_BUILD_CATALOG_TOOL_TIMEOUT") + if opImagePullPolicy != "" { + fmt.Printf("Setting build catalog tool timeout to %s\n", opBuildCatalogToolTimeout) + installArgs = append(installArgs, "--build-catalog-tool-timeout", opBuildCatalogToolTimeout) + } + installArgs = append(installArgs, args...) return KamelWithContext(ctx, installArgs...) } diff --git a/pkg/cmd/install.go b/pkg/cmd/install.go index 6a4f3bd088..12b5ad4c31 100644 --- a/pkg/cmd/install.go +++ b/pkg/cmd/install.go @@ -111,6 +111,7 @@ func newCmdInstall(rootCmdOptions *RootCmdOptions) (*cobra.Command, *installCmdO cmd.Flags().String("build-publish-strategy", "", "Set the build publish strategy") cmd.Flags().StringArray("build-publish-strategy-option", nil, "Add a build publish strategy option, as ") cmd.Flags().String("build-timeout", "", "Set how long the build process can last") + cmd.Flags().String("build-catalog-tool-timeout", "", "Set how long the catalogtool image build can last") cmd.Flags().String("trait-profile", "", "The profile to use for traits") // OLM @@ -186,6 +187,7 @@ type installCmdOptions struct { BuildPublishStrategy string `mapstructure:"build-publish-strategy"` BuildPublishStrategyOptions []string `mapstructure:"build-publish-strategy-options"` BuildTimeout string `mapstructure:"build-timeout"` + BuildCatalogToolTimeout string `mapstructure:"build-catalog-tool-timeout"` MavenExtensions []string `mapstructure:"maven-extensions"` MavenLocalRepository string `mapstructure:"maven-local-repository"` MavenProperties []string `mapstructure:"maven-properties"` @@ -542,6 +544,16 @@ func (o *installCmdOptions) setupIntegrationPlatform(c client.Client, namespace Duration: d, } } + if o.BuildCatalogToolTimeout != "" { + d, err := time.ParseDuration(o.BuildCatalogToolTimeout) + if err != nil { + return nil, err + } + + platform.Spec.Build.BuildCatalogToolTimeout = &metav1.Duration{ + Duration: d, + } + } if o.MaxRunningBuilds > 0 { platform.Spec.Build.MaxRunningBuilds = o.MaxRunningBuilds } diff --git a/pkg/cmd/install_test.go b/pkg/cmd/install_test.go index aacc8824be..0014ceca13 100644 --- a/pkg/cmd/install_test.go +++ b/pkg/cmd/install_test.go @@ -121,6 +121,13 @@ func TestInstallBuildTimeoutFlag(t *testing.T) { assert.Equal(t, "10", installCmdOptions.BuildTimeout) } +func TestInstallBuildCatalogToolTimeoutFlag(t *testing.T) { + installCmdOptions, rootCmd, _ := initializeInstallCmdOptions(t) + _, err := test.ExecuteCommand(rootCmd, cmdInstall, "--build-catalog-tool-timeout", "600") + assert.Nil(t, err) + assert.Equal(t, "600", installCmdOptions.BuildCatalogToolTimeout) +} + func TestInstallClusterSetupFlag(t *testing.T) { installCmdOptions, rootCmd, _ := initializeInstallCmdOptions(t) _, err := test.ExecuteCommand(rootCmd, cmdInstall, "--cluster-setup")