Skip to content

Commit

Permalink
Create istio-system namespace as part of create operator bindings step
Browse files Browse the repository at this point in the history
  • Loading branch information
koala7659 committed Mar 20, 2024
1 parent f686f8b commit 9d04432
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,9 @@ import (
"github.com/kyma-project/control-plane/components/provisioner/internal/operations"
"github.com/kyma-project/control-plane/components/provisioner/internal/util"
"github.com/kyma-project/control-plane/components/provisioner/internal/util/k8s"

core "k8s.io/api/core/v1"
v1core "k8s.io/client-go/kubernetes/typed/core/v1"
)

const (
Expand Down Expand Up @@ -96,6 +99,10 @@ func (s *CreateBindingsForOperatorsStep) Run(cluster model.Cluster, _ model.Oper
return operations.StageResult{}, err.Append("failed to create k8s client").SetComponent(apperrors.ErrClusterK8SClient)
}

if err := s.createNamespace(k8sClient.CoreV1().Namespaces(), "istio-system"); err != nil {
return operations.StageResult{}, err
}

clusterRoles := make([]v12.ClusterRole, 0)
clusterRoles = append(clusterRoles,
buildClusterRole(
Expand Down Expand Up @@ -240,3 +247,15 @@ func createClusterRoleBindings(crbClient v1.ClusterRoleBindingInterface, cluster
}
return nil
}

func (c *CreateBindingsForOperatorsStep) createNamespace(namespaceInterface v1core.NamespaceInterface, namespace string) apperrors.AppError {
ns := &core.Namespace{
ObjectMeta: metav1.ObjectMeta{Name: namespace},
}
_, err := namespaceInterface.Create(context.Background(), ns, metav1.CreateOptions{})

if err != nil && !k8serrors.IsAlreadyExists(err) {
return util.K8SErrorToAppError(errors.Wrap(err, "Failed to create namespace"))
}
return nil
}
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import (
"github.com/sirupsen/logrus"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
core "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/kubernetes/fake"
)
Expand Down Expand Up @@ -104,6 +105,32 @@ func TestCreateBindingsForOperatorsStep_Run(t *testing.T) {
assert.Equal(t, time.Duration(0), result.Delay)
})

t.Run("should not fail if namespace istio-system already exists", func(t *testing.T) {
// given
k8sClient := fake.NewSimpleClientset()

ns := &core.Namespace{
ObjectMeta: metav1.ObjectMeta{Name: "istio-system"},
}

_, err := k8sClient.CoreV1().Namespaces().Create(context.Background(), ns, metav1.CreateOptions{})

require.NoError(t, err)

k8sClientProvider := &mocks.K8sClientProvider{}
k8sClientProvider.On("CreateK8SClient", dynamicKubeconfig).Return(k8sClient, nil)

step := NewCreateBindingsForOperatorsStep(k8sClientProvider, operatorBindingConfig, dynamicKubeconfigProvider, nextStageName, time.Minute)

// when
result, err := step.Run(cluster, model.Operation{}, &logrus.Entry{})

// then
require.NoError(t, err)
assert.Equal(t, nextStageName, result.Stage)
assert.Equal(t, time.Duration(0), result.Delay)
})

t.Run("should attempt retry when failed to get dynamic kubeconfig", func(t *testing.T) {
// given
dynamicKubeconfigProvider := &provisioning_mocks.DynamicKubeconfigProvider{}
Expand Down

0 comments on commit 9d04432

Please sign in to comment.