blob: 1b528bcbf7ca249c67a3c143fbb111cb69e60a51 [file] [log] [blame]
/*
* 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 installers
import (
"errors"
"fmt"
"regexp"
"sigs.k8s.io/controller-runtime/pkg/client"
"github.com/apache/incubator-kie-kogito-serverless-operator/bddframework/pkg/config"
"github.com/apache/incubator-kie-kogito-serverless-operator/bddframework/pkg/framework"
"github.com/apache/incubator-kie-kogito-serverless-operator/bddframework/pkg/installers"
"github.com/apache/incubator-kie-kogito-serverless-operator/controllers/workflowdef"
srvframework "github.com/apache/incubator-kie-kogito-serverless-operator/testbdd/framework"
)
const defaultOperatorImage = "quay.io/kiegroup/kogito-serverless-operator"
var (
// sonataFlowYamlClusterInstaller installs SonataFlow operator cluster wide using YAMLs
sonataFlowYamlClusterInstaller = installers.YamlClusterWideServiceInstaller{
InstallClusterYaml: installSonataFlowUsingYaml,
InstallationNamespace: SonataFlowNamespace,
WaitForClusterYamlServiceRunning: waitForSonataFlowOperatorUsingYamlRunning,
GetAllClusterYamlCrsInNamespace: getSonataFlowCrsInNamespace,
UninstallClusterYaml: uninstallSonataFlowUsingYaml,
ClusterYamlServiceName: sonataFlowServiceName,
CleanupClusterYamlCrsInNamespace: cleanupSonataFlowCrsInNamespace,
}
// sonataFlowCustomOlmClusterWideInstaller installs SonataFlow cluster wide using OLM with custom catalog
sonataFlowCustomOlmClusterWideInstaller = installers.OlmClusterWideServiceInstaller{
SubscriptionName: sonataFlowOperatorSubscriptionName,
Channel: sonataFlowOperatorSubscriptionChannel,
Catalog: framework.GetCustomKogitoOperatorCatalog,
InstallationTimeoutInMinutes: 5,
GetAllClusterWideOlmCrsInNamespace: getSonataFlowCrsInNamespace,
CleanupClusterWideOlmCrsInNamespace: cleanupSonataFlowCrsInNamespace,
}
// sonataFlowOlmClusterWideInstaller installs SonataFlow cluster wide using OLM with community catalog
sonataFlowOlmClusterWideInstaller = installers.OlmClusterWideServiceInstaller{
SubscriptionName: sonataFlowOperatorSubscriptionName,
Channel: sonataFlowOperatorSubscriptionChannel,
Catalog: framework.GetCommunityCatalog,
InstallationTimeoutInMinutes: 5,
GetAllClusterWideOlmCrsInNamespace: getSonataFlowCrsInNamespace,
CleanupClusterWideOlmCrsInNamespace: cleanupSonataFlowCrsInNamespace,
}
// SonataFlowNamespace is the SonataFlow namespace for yaml cluster-wide deployment
SonataFlowNamespace = "sonataflow-operator-system"
sonataFlowServiceName = "SonataFlow operator"
sonataFlowOperatorSubscriptionName = "sonataflow-operator"
sonataFlowOperatorSubscriptionChannel = "alpha"
)
// GetSonataFlowInstaller returns SonataFlow installer
func GetSonataFlowInstaller() (installers.ServiceInstaller, error) {
// If user doesn't pass SonataFlow operator image then use community OLM catalog to install operator
if len(config.GetOperatorImageTag()) == 0 {
framework.GetMainLogger().Info("Installing SonataFlow operator using community catalog.")
return &sonataFlowOlmClusterWideInstaller, nil
}
if config.IsOperatorInstalledByYaml() || config.IsOperatorProfiling() {
return &sonataFlowYamlClusterInstaller, nil
}
if config.IsOperatorInstalledByOlm() {
return &sonataFlowCustomOlmClusterWideInstaller, nil
}
return nil, errors.New("no SonataFlow operator installer available for provided configuration")
}
func installSonataFlowUsingYaml() error {
framework.GetMainLogger().Info("Installing SonataFlow operator")
yamlContent, err := framework.ReadFromURI(config.GetOperatorYamlURI())
if err != nil {
framework.GetMainLogger().Error(err, "Error while reading the operator YAML file")
return err
}
regexp, err := regexp.Compile(getDefaultOperatorImageTag())
if err != nil {
return err
}
yamlContent = regexp.ReplaceAllString(yamlContent, config.GetOperatorImageTag())
tempFilePath, err := framework.CreateTemporaryFile("kogito-serverless-operator*.yaml", yamlContent)
if err != nil {
framework.GetMainLogger().Error(err, "Error while storing adjusted YAML content to temporary file")
return err
}
_, err = framework.CreateCommand("oc", "create", "-f", tempFilePath).Execute()
if err != nil {
framework.GetMainLogger().Error(err, "Error while installing SonataFlow operator from YAML file")
return err
}
return nil
}
func waitForSonataFlowOperatorUsingYamlRunning() error {
return srvframework.WaitForSonataFlowOperatorRunning(SonataFlowNamespace)
}
func uninstallSonataFlowUsingYaml() error {
framework.GetMainLogger().Info("Uninstalling SonataFlow operator")
output, err := framework.CreateCommand("oc", "delete", "-f", config.GetOperatorYamlURI(), "--timeout=30s", "--ignore-not-found=true").Execute()
if err != nil {
framework.GetMainLogger().Error(err, fmt.Sprintf("Deleting SonataFlow operator failed, output: %s", output))
return err
}
return nil
}
func getSonataFlowCrsInNamespace(namespace string) ([]client.Object, error) {
var crs []client.Object
//kogitoRuntimes := &v1beta1.KogitoRuntimeList{}
//if err := framework.GetObjectsInNamespace(namespace, kogitoRuntimes); err != nil {
// return nil, err
//}
//for i := range kogitoRuntimes.Items {
// crs = append(crs, &kogitoRuntimes.Items[i])
//}
//
//kogitoBuilds := &v1beta1.KogitoBuildList{}
//if err := framework.GetObjectsInNamespace(namespace, kogitoBuilds); err != nil {
// return nil, err
//}
//for i := range kogitoBuilds.Items {
// crs = append(crs, &kogitoBuilds.Items[i])
//}
//
//kogitoSupportingServices := &v1beta1.KogitoSupportingServiceList{}
//if err := framework.GetObjectsInNamespace(namespace, kogitoSupportingServices); err != nil {
// return nil, err
//}
//for i := range kogitoSupportingServices.Items {
// crs = append(crs, &kogitoSupportingServices.Items[i])
//}
//
//kogitoInfras := &v1beta1.KogitoInfraList{}
//if err := framework.GetObjectsInNamespace(namespace, kogitoInfras); err != nil {
// return nil, err
//}
//for i := range kogitoInfras.Items {
// crs = append(crs, &kogitoInfras.Items[i])
//}
return crs, nil
}
func cleanupSonataFlowCrsInNamespace(namespace string) bool {
crs, err := getSonataFlowCrsInNamespace(namespace)
if err != nil {
framework.GetLogger(namespace).Error(err, "Error getting SonataFlow CRs.")
return false
}
for _, cr := range crs {
if err := framework.DeleteObject(cr); err != nil {
framework.GetLogger(namespace).Error(err, "Error deleting SonataFlow CR.", "CR name", cr.GetName())
return false
}
}
return true
}
func getDefaultOperatorImageTag() string {
return workflowdef.GetDefaultImageTag(defaultOperatorImage)
}