180 lines
5.0 KiB
Go
180 lines
5.0 KiB
Go
package controller
|
|
|
|
import (
|
|
"fmt"
|
|
"reflect"
|
|
"testing"
|
|
"time"
|
|
|
|
acidv1 "github.com/zalando/postgres-operator/pkg/apis/acid.zalan.do/v1"
|
|
"github.com/zalando/postgres-operator/pkg/spec"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
)
|
|
|
|
var (
|
|
True = true
|
|
False = false
|
|
)
|
|
|
|
func newPostgresqlTestController() *Controller {
|
|
controller := NewController(&spec.ControllerConfig{}, "postgresql-test")
|
|
return controller
|
|
}
|
|
|
|
var postgresqlTestController = newPostgresqlTestController()
|
|
|
|
func TestControllerOwnershipOnPostgresql(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
pg *acidv1.Postgresql
|
|
owned bool
|
|
error string
|
|
}{
|
|
{
|
|
"Postgres cluster with defined ownership of mocked controller",
|
|
&acidv1.Postgresql{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Annotations: map[string]string{"acid.zalan.do/controller": "postgresql-test"},
|
|
},
|
|
},
|
|
True,
|
|
"Postgres cluster should be owned by operator, but controller says no",
|
|
},
|
|
{
|
|
"Postgres cluster with defined ownership of another controller",
|
|
&acidv1.Postgresql{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Annotations: map[string]string{"acid.zalan.do/controller": "stups-test"},
|
|
},
|
|
},
|
|
False,
|
|
"Postgres cluster should be owned by another operator, but controller say yes",
|
|
},
|
|
{
|
|
"Test Postgres cluster without defined ownership",
|
|
&acidv1.Postgresql{},
|
|
False,
|
|
"Postgres cluster should be owned by operator with empty controller ID, but controller says yes",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
if postgresqlTestController.hasOwnership(tt.pg) != tt.owned {
|
|
t.Errorf("%s: %v", tt.name, tt.error)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestMergeDeprecatedPostgreSQLSpecParameters(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
in *acidv1.PostgresSpec
|
|
out *acidv1.PostgresSpec
|
|
error string
|
|
}{
|
|
{
|
|
"Check that old parameters propagate values to the new ones",
|
|
&acidv1.PostgresSpec{UseLoadBalancer: &True, ReplicaLoadBalancer: &True},
|
|
&acidv1.PostgresSpec{UseLoadBalancer: nil, ReplicaLoadBalancer: nil,
|
|
EnableMasterLoadBalancer: &True, EnableReplicaLoadBalancer: &True},
|
|
"New parameters should be set from the values of old ones",
|
|
},
|
|
{
|
|
"Check that new parameters are not set when both old and new ones are present",
|
|
&acidv1.PostgresSpec{UseLoadBalancer: &True, EnableMasterLoadBalancer: &False},
|
|
&acidv1.PostgresSpec{UseLoadBalancer: nil, EnableMasterLoadBalancer: &False},
|
|
"New parameters should remain unchanged when both old and new are present",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
result := postgresqlTestController.mergeDeprecatedPostgreSQLSpecParameters(tt.in)
|
|
if !reflect.DeepEqual(result, tt.out) {
|
|
t.Errorf("%s: %v", tt.name, tt.error)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestMeetsClusterDeleteAnnotations(t *testing.T) {
|
|
// set delete annotations in configuration
|
|
postgresqlTestController.opConfig.DeleteAnnotationDateKey = "delete-date"
|
|
postgresqlTestController.opConfig.DeleteAnnotationNameKey = "delete-clustername"
|
|
|
|
currentTime := time.Now()
|
|
today := currentTime.Format("2006-01-02") // go's reference date
|
|
clusterName := "acid-test-cluster"
|
|
|
|
tests := []struct {
|
|
name string
|
|
pg *acidv1.Postgresql
|
|
error string
|
|
}{
|
|
{
|
|
"Postgres cluster with matching delete annotations",
|
|
&acidv1.Postgresql{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: clusterName,
|
|
Annotations: map[string]string{
|
|
"delete-date": today,
|
|
"delete-clustername": clusterName,
|
|
},
|
|
},
|
|
},
|
|
"",
|
|
},
|
|
{
|
|
"Postgres cluster with violated delete date annotation",
|
|
&acidv1.Postgresql{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: clusterName,
|
|
Annotations: map[string]string{
|
|
"delete-date": "2020-02-02",
|
|
"delete-clustername": clusterName,
|
|
},
|
|
},
|
|
},
|
|
fmt.Sprintf("annotation delete-date not matching the current date: got 2020-02-02, expected %s", today),
|
|
},
|
|
{
|
|
"Postgres cluster with violated delete cluster name annotation",
|
|
&acidv1.Postgresql{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: clusterName,
|
|
Annotations: map[string]string{
|
|
"delete-date": today,
|
|
"delete-clustername": "acid-minimal-cluster",
|
|
},
|
|
},
|
|
},
|
|
fmt.Sprintf("annotation delete-clustername not matching the cluster name: got acid-minimal-cluster, expected %s", clusterName),
|
|
},
|
|
{
|
|
"Postgres cluster with missing delete annotations",
|
|
&acidv1.Postgresql{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: clusterName,
|
|
Annotations: map[string]string{},
|
|
},
|
|
},
|
|
"annotation delete-date not set in manifest to allow cluster deletion",
|
|
},
|
|
{
|
|
"Postgres cluster with missing delete cluster name annotation",
|
|
&acidv1.Postgresql{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: clusterName,
|
|
Annotations: map[string]string{
|
|
"delete-date": today,
|
|
},
|
|
},
|
|
},
|
|
"annotation delete-clustername not set in manifest to allow cluster deletion",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
if err := postgresqlTestController.meetsClusterDeleteAnnotations(tt.pg); err != nil {
|
|
if !reflect.DeepEqual(err.Error(), tt.error) {
|
|
t.Errorf("Expected error %q, got: %v", tt.error, err)
|
|
}
|
|
}
|
|
}
|
|
}
|