зеркало из https://github.com/Azure/ARO-RP.git
179 строки
5.6 KiB
Go
179 строки
5.6 KiB
Go
package frontend
|
|
|
|
// Copyright (c) Microsoft Corporation.
|
|
// Licensed under the Apache License 2.0.
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net/http"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/golang/mock/gomock"
|
|
"github.com/sirupsen/logrus"
|
|
|
|
"github.com/Azure/ARO-RP/pkg/api"
|
|
"github.com/Azure/ARO-RP/pkg/env"
|
|
"github.com/Azure/ARO-RP/pkg/frontend/adminactions"
|
|
"github.com/Azure/ARO-RP/pkg/metrics/noop"
|
|
mock_adminactions "github.com/Azure/ARO-RP/pkg/util/mocks/adminactions"
|
|
testdatabase "github.com/Azure/ARO-RP/test/database"
|
|
)
|
|
|
|
func TestAdminCordonUncordonNode(t *testing.T) {
|
|
mockSubID := "00000000-0000-0000-0000-000000000000"
|
|
mockTenantID := "00000000-0000-0000-0000-000000000000"
|
|
|
|
ctx := context.Background()
|
|
|
|
type test struct {
|
|
name string
|
|
resourceID string
|
|
fixture func(*testdatabase.Fixture)
|
|
vmName string
|
|
shouldCordon string
|
|
mocks func(*test, *mock_adminactions.MockKubeActions)
|
|
wantStatusCode int
|
|
wantResponse []byte
|
|
wantError string
|
|
}
|
|
|
|
for _, tt := range []*test{
|
|
{
|
|
name: "basic coverage - cordon",
|
|
vmName: "aro-worker-australiasoutheast-7tcq7",
|
|
shouldCordon: "false",
|
|
resourceID: testdatabase.GetResourcePath(mockSubID, "resourceName"),
|
|
fixture: func(f *testdatabase.Fixture) {
|
|
f.AddOpenShiftClusterDocuments(&api.OpenShiftClusterDocument{
|
|
Key: strings.ToLower(testdatabase.GetResourcePath(mockSubID, "resourceName")),
|
|
OpenShiftCluster: &api.OpenShiftCluster{
|
|
ID: testdatabase.GetResourcePath(mockSubID, "resourceName"),
|
|
Properties: api.OpenShiftClusterProperties{
|
|
ClusterProfile: api.ClusterProfile{
|
|
ResourceGroupID: fmt.Sprintf("/subscriptions/%s/resourceGroups/test-cluster", mockSubID),
|
|
},
|
|
},
|
|
},
|
|
})
|
|
|
|
f.AddSubscriptionDocuments(&api.SubscriptionDocument{
|
|
ID: mockSubID,
|
|
Subscription: &api.Subscription{
|
|
State: api.SubscriptionStateRegistered,
|
|
Properties: &api.SubscriptionProperties{
|
|
TenantID: mockTenantID,
|
|
},
|
|
},
|
|
})
|
|
},
|
|
mocks: func(tt *test, k *mock_adminactions.MockKubeActions) {
|
|
k.EXPECT().CordonNode(gomock.Any(), tt.vmName, false).Return(nil)
|
|
},
|
|
wantStatusCode: http.StatusOK,
|
|
},
|
|
{
|
|
name: "basic coverage - uncordon",
|
|
vmName: "aro-worker-australiasoutheast-7tcq7",
|
|
shouldCordon: "true",
|
|
resourceID: testdatabase.GetResourcePath(mockSubID, "resourceName"),
|
|
fixture: func(f *testdatabase.Fixture) {
|
|
f.AddOpenShiftClusterDocuments(&api.OpenShiftClusterDocument{
|
|
Key: strings.ToLower(testdatabase.GetResourcePath(mockSubID, "resourceName")),
|
|
OpenShiftCluster: &api.OpenShiftCluster{
|
|
ID: testdatabase.GetResourcePath(mockSubID, "resourceName"),
|
|
Properties: api.OpenShiftClusterProperties{
|
|
ClusterProfile: api.ClusterProfile{
|
|
ResourceGroupID: fmt.Sprintf("/subscriptions/%s/resourceGroups/test-cluster", mockSubID),
|
|
},
|
|
},
|
|
},
|
|
})
|
|
|
|
f.AddSubscriptionDocuments(&api.SubscriptionDocument{
|
|
ID: mockSubID,
|
|
Subscription: &api.Subscription{
|
|
State: api.SubscriptionStateRegistered,
|
|
Properties: &api.SubscriptionProperties{
|
|
TenantID: mockTenantID,
|
|
},
|
|
},
|
|
})
|
|
},
|
|
mocks: func(tt *test, k *mock_adminactions.MockKubeActions) {
|
|
k.EXPECT().CordonNode(gomock.Any(), tt.vmName, true).Return(nil)
|
|
},
|
|
wantStatusCode: http.StatusOK,
|
|
},
|
|
{
|
|
name: "unable to parse schedulable parameter - default to false",
|
|
vmName: "aro-worker-australiasoutheast-7tcq7",
|
|
shouldCordon: "unable_to_parse",
|
|
resourceID: testdatabase.GetResourcePath(mockSubID, "resourceName"),
|
|
fixture: func(f *testdatabase.Fixture) {
|
|
f.AddOpenShiftClusterDocuments(&api.OpenShiftClusterDocument{
|
|
Key: strings.ToLower(testdatabase.GetResourcePath(mockSubID, "resourceName")),
|
|
OpenShiftCluster: &api.OpenShiftCluster{
|
|
ID: testdatabase.GetResourcePath(mockSubID, "resourceName"),
|
|
Properties: api.OpenShiftClusterProperties{
|
|
ClusterProfile: api.ClusterProfile{
|
|
ResourceGroupID: fmt.Sprintf("/subscriptions/%s/resourceGroups/test-cluster", mockSubID),
|
|
},
|
|
},
|
|
},
|
|
})
|
|
|
|
f.AddSubscriptionDocuments(&api.SubscriptionDocument{
|
|
ID: mockSubID,
|
|
Subscription: &api.Subscription{
|
|
State: api.SubscriptionStateRegistered,
|
|
Properties: &api.SubscriptionProperties{
|
|
TenantID: mockTenantID,
|
|
},
|
|
},
|
|
})
|
|
},
|
|
mocks: func(tt *test, k *mock_adminactions.MockKubeActions) {
|
|
k.EXPECT().CordonNode(gomock.Any(), tt.vmName, false).Return(nil)
|
|
},
|
|
wantStatusCode: http.StatusOK,
|
|
},
|
|
} {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
ti := newTestInfra(t).WithOpenShiftClusters().WithSubscriptions()
|
|
defer ti.done()
|
|
|
|
k := mock_adminactions.NewMockKubeActions(ti.controller)
|
|
tt.mocks(tt, k)
|
|
|
|
err := ti.buildFixtures(tt.fixture)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
f, err := NewFrontend(ctx, ti.audit, ti.log, ti.env, ti.asyncOperationsDatabase, ti.clusterManagerDatabase, ti.openShiftClustersDatabase, ti.subscriptionsDatabase, nil, api.APIs, &noop.Noop{}, nil, func(*logrus.Entry, env.Interface, *api.OpenShiftCluster) (adminactions.KubeActions, error) {
|
|
return k, nil
|
|
}, nil, nil)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
go f.Run(ctx, nil, nil)
|
|
|
|
resp, b, err := ti.request(http.MethodPost,
|
|
fmt.Sprintf("https://server/admin%s/cordonnode?vmName=%s&shouldCordon=%s", tt.resourceID, tt.vmName, tt.shouldCordon),
|
|
nil, nil)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
err = validateResponse(resp, b, tt.wantStatusCode, tt.wantError, tt.wantResponse)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
})
|
|
}
|
|
}
|