Skip to content

Commit

Permalink
Add more coverage in octavia controller function tests
Browse files Browse the repository at this point in the history
  • Loading branch information
gthiemonge committed Oct 8, 2024
1 parent f9b6dc4 commit bfa6a7d
Show file tree
Hide file tree
Showing 5 changed files with 1,094 additions and 87 deletions.
25 changes: 19 additions & 6 deletions tests/functional/api_fixture.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ import (
. "github.com/onsi/ginkgo/v2" //revive:disable:dot-imports

"github.com/gophercloud/gophercloud/openstack/identity/v3/projects"
"github.com/gophercloud/gophercloud/openstack/identity/v3/users"
keystone_helpers "github.com/openstack-k8s-operators/keystone-operator/api/test/helpers"

api "github.com/openstack-k8s-operators/lib-common/modules/test/apis"
Expand Down Expand Up @@ -172,11 +173,13 @@ func keystoneGetProject(
f.APIFixture.Log.Info(fmt.Sprintf("GetProject returns %s", string(bytes)))
}

func SetupAPIFixtures(logger logr.Logger) (
*keystone_helpers.KeystoneAPIFixture,
*NovaAPIFixture,
*NeutronAPIFixture,
) {
type APIFixtures struct {
Keystone *keystone_helpers.KeystoneAPIFixture
Nova *NovaAPIFixture
Neutron *NeutronAPIFixture
}

func SetupAPIFixtures(logger logr.Logger) APIFixtures {
nova := NewNovaAPIFixtureWithServer(logger)
nova.Setup()
DeferCleanup(nova.Cleanup)
Expand All @@ -188,6 +191,12 @@ func SetupAPIFixtures(logger logr.Logger) (
neutronURL := neutron.Endpoint()

keystone := keystone_helpers.NewKeystoneAPIFixtureWithServer(logger)
keystone.Users = map[string]users.User{
"octavia": {
Name: "octavia",
ID: uuid.New().String(),
},
}
keystone.Setup(
api.Handler{Pattern: "/", Func: keystone.HandleVersion},
api.Handler{Pattern: "/v3/users", Func: keystone.HandleUsers},
Expand All @@ -205,5 +214,9 @@ func SetupAPIFixtures(logger logr.Logger) (
}
}})
DeferCleanup(keystone.Cleanup)
return keystone, nova, neutron
return APIFixtures{
Keystone: keystone,
Nova: nova,
Neutron: neutron,
}
}
91 changes: 89 additions & 2 deletions tests/functional/base_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,14 @@ limitations under the License.
package functional_test

import (
"encoding/json"
"fmt"
"time"

. "github.com/onsi/ginkgo/v2" //revive:disable:dot-imports
. "github.com/onsi/gomega" //revive:disable:dot-imports

networkv1 "github.com/k8snetworkplumbingwg/network-attachment-definition-client/pkg/apis/k8s.cni.cncf.io/v1"
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
Expand All @@ -32,6 +34,7 @@ import (
condition "github.com/openstack-k8s-operators/lib-common/modules/common/condition"
"github.com/openstack-k8s-operators/lib-common/modules/common/endpoint"
octaviav1 "github.com/openstack-k8s-operators/octavia-operator/api/v1beta1"
"github.com/openstack-k8s-operators/octavia-operator/pkg/octavia"
)

const (
Expand Down Expand Up @@ -106,8 +109,14 @@ func SimulateKeystoneReady(

func GetDefaultOctaviaSpec() map[string]interface{} {
return map[string]interface{}{
"databaseInstance": "test-octavia-db-instance",
"secret": SecretName,
"databaseInstance": "test-octavia-db-instance",
"secret": SecretName,
"octaviaNetworkAttachment": "octavia-attachement",
"databaseAccount": "octavia-db-account",
"persistenceDatabaseAccount": "octavia-persistence-db-account",
"lbMgmtNetwork": map[string]interface{}{
"availabilityZones": []string{"az0"},
},
}
}

Expand Down Expand Up @@ -215,3 +224,81 @@ func OctaviaAPIConditionGetter(name types.NamespacedName) condition.Conditions {
instance := GetOctaviaAPI(name)
return instance.Status.Conditions
}

func SimulateOctaviaAPIReady(name types.NamespacedName) {
Eventually(func(g Gomega) {
octaviaAPI := GetOctaviaAPI(name)
octaviaAPI.Status.ObservedGeneration = octaviaAPI.Generation
octaviaAPI.Status.ReadyCount = 1
g.Expect(k8sClient.Status().Update(ctx, octaviaAPI)).To(Succeed())
}, timeout, interval).Should(Succeed())
}

func CreateNAD(name types.NamespacedName) client.Object {
raw := map[string]interface{}{
"apiVersion": "k8s.cni.cncf.io/v1",
"kind": "NetworkAttachmentDefinition",
"metadata": map[string]interface{}{
"name": name.Name,
"namespace": name.Namespace,
},
"spec": map[string]interface{}{
"config": `{
"cniVersion": "0.3.1",
"name": "octavia",
"type": "bridge",
"bridge": "octbr",
"ipam": {
"type": "whereabouts",
"range": "172.23.0.0/24",
"range_start": "172.23.0.30",
"range_end": "172.23.0.70",
"routes": [{
"dst": "172.24.0.0/16",
"gw" : "172.23.0.150"
}]
}
}`,
},
}
return th.CreateUnstructured(raw)
}

func GetNADConfig(name types.NamespacedName) *octavia.NADConfig {
nad := &networkv1.NetworkAttachmentDefinition{}
Eventually(func(g Gomega) {
g.Expect(k8sClient.Get(ctx, name, nad)).Should(Succeed())
}, timeout, interval).Should(Succeed())

nadConfig := &octavia.NADConfig{}
jsonDoc := []byte(nad.Spec.Config)
err := json.Unmarshal(jsonDoc, nadConfig)
if err != nil {
return nil
}

return nadConfig
}

func CreateNode(name types.NamespacedName) client.Object {
raw := map[string]interface{}{
"apiVersion": "v1",
"kind": "Node",
"metadata": map[string]interface{}{
"name": name.Name,
"namespace": name.Namespace,
},
"spec": map[string]interface{}{},
}
return th.CreateUnstructured(raw)

}

func CreateSSHPubKey() client.Object {
return th.CreateConfigMap(types.NamespacedName{
Name: "octavia-ssh-pubkey",
Namespace: namespace,
}, map[string]interface{}{
"key": []byte("public key"),
})
}
Loading

0 comments on commit bfa6a7d

Please sign in to comment.