From b0079662bd01089101b0d1a02ab2d67d4f55f5f8 Mon Sep 17 00:00:00 2001 From: Wesley Hershberger Date: Fri, 9 Aug 2024 15:59:24 -0500 Subject: [PATCH] internal/core/resources: Unittests for ValidateResources Signed-off-by: Wesley Hershberger --- internal/rest/resources/resources_test.go | 79 +++++++++++++++++++++++ 1 file changed, 79 insertions(+) create mode 100644 internal/rest/resources/resources_test.go diff --git a/internal/rest/resources/resources_test.go b/internal/rest/resources/resources_test.go new file mode 100644 index 00000000..b6728a07 --- /dev/null +++ b/internal/rest/resources/resources_test.go @@ -0,0 +1,79 @@ +package resources + +import ( + "testing" + + "github.com/canonical/microcluster/v3/rest" +) + +var validServers = map[string]rest.Server{ + "coreConsumer": { + CoreAPI: true, + Resources: []rest.Resources{ + { + PathPrefix: "core_consumer", + }, + }, + }, +} + +func TestValidateEndpointsValidServers(t *testing.T) { + err := ValidateEndpoints(validServers, "localhost:8000") + if err != nil { + t.Errorf("Valid server failed validation: %s", err) + } +} + +var invalidServers = map[string]rest.Server{ + "emptyResources": { + CoreAPI: true, + }, + "duplicate": { + Resources: []rest.Resources{ + { + PathPrefix: "dup", + Endpoints: []rest.Endpoint{ + { + Path: "duplicate", + }, + }, + }, + { + PathPrefix: "dup", + Endpoints: []rest.Endpoint{ + { + Path: "duplicate", + }, + }, + }, + }, + }, + "overlapCore": { + CoreAPI: true, + Resources: []rest.Resources{ + { + PathPrefix: "core", + }, + }, + }, + "overlapCoreMultipart": { + CoreAPI: true, + Resources: []rest.Resources{ + { + PathPrefix: "core/subpoint", + }, + }, + }, +} + +func TestValidateEndpointsInvalidServers(t *testing.T) { + for serverName, server := range invalidServers { + servers := map[string]rest.Server{ + serverName: server, + } + err := ValidateEndpoints(servers, "localhost:8000") + if err == nil { + t.Errorf("Invalid server %q passed validation", serverName) + } + } +}