diff --git a/pkg/config-api-provider/provider/resources/group.go b/pkg/config-api-provider/provider/resources/group.go index 11ece3c2..674626fc 100644 --- a/pkg/config-api-provider/provider/resources/group.go +++ b/pkg/config-api-provider/provider/resources/group.go @@ -173,7 +173,7 @@ func (r *groupResource) Update(ctx context.Context, req resource.UpdateRequest, return } - patchRequest := config_api_client.NewGroupsPatchRequest("new_name") + patchRequest := config_api_client.NewGroupsPatchRequest(plan.Name.ValueString()) request := r.client.ConfigurationAPI. GroupsPatchNetworkingUxiV1alpha1GroupsGroupUidPatch(ctx, plan.ID.ValueString()). GroupsPatchRequest(*patchRequest) diff --git a/pkg/config-api-provider/provider/resources/service_group_assignment.go b/pkg/config-api-provider/provider/resources/service_group_assignment.go index ff6235bb..f779aa3e 100644 --- a/pkg/config-api-provider/provider/resources/service_group_assignment.go +++ b/pkg/config-api-provider/provider/resources/service_group_assignment.go @@ -161,7 +161,15 @@ func (r *serviceTestGroupAssignmentResource) Delete(ctx context.Context, req res return } - // Delete existing serviceTestGroupAssignment using the plan_id + request := r.client.ConfigurationAPI.DeleteServiceTestGroupAssignmentUxiV1alpha1ServiceTestGroupAssignmentsIdDelete(ctx, state.ID.ValueString()) + + _, response, err := util.RetryFor429(request.Execute) + errorPresent, errorDetail := util.RaiseForStatus(response, err) + + if errorPresent { + resp.Diagnostics.AddError(util.GenerateErrorSummary("delete", "uxi_service_test_group_assignment"), errorDetail) + return + } } func (r *serviceTestGroupAssignmentResource) ImportState(ctx context.Context, req resource.ImportStateRequest, resp *resource.ImportStateResponse) { diff --git a/pkg/config-api-provider/test/resources/agent_group_assignment_test.go b/pkg/config-api-provider/test/resources/agent_group_assignment_test.go index b4ac6f80..02e471d7 100644 --- a/pkg/config-api-provider/test/resources/agent_group_assignment_test.go +++ b/pkg/config-api-provider/test/resources/agent_group_assignment_test.go @@ -26,7 +26,11 @@ func TestAgentGroupAssignmentResource(t *testing.T) { } // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -98,7 +102,11 @@ func TestAgentGroupAssignmentResource(t *testing.T) { ) // required for creating another group - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid_2", "_2", "_2"), + util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), + 1, + ) // required for agent group assignment create resources.GetAgentGroupAssignment = func(uid string) resources.AgentGroupAssignmentResponseModel { diff --git a/pkg/config-api-provider/test/resources/group_test.go b/pkg/config-api-provider/test/resources/group_test.go index 9f4d156c..f65c89ed 100644 --- a/pkg/config-api-provider/test/resources/group_test.go +++ b/pkg/config-api-provider/test/resources/group_test.go @@ -27,7 +27,11 @@ func TestGroupResource(t *testing.T) { // Create and Read testing { PreConfig: func() { - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("uid", "", "")), + 1, + ) util.MockGetGroup("uid", util.GeneratePaginatedResponse( []map[string]interface{}{util.GenerateGroupResponseModel("uid", "", "")}), 1, @@ -65,7 +69,10 @@ func TestGroupResource(t *testing.T) { 1, ) // updated group - util.MockUpdateGroup("uid", util.GenerateGroupResponseModel("uid", "_2", ""), + util.MockUpdateGroup( + "uid", + map[string]interface{}{"name": "name_2"}, + util.GenerateGroupResponseModel("uid", "_2", ""), 1, ) util.MockGetGroup("uid", util.GeneratePaginatedResponse( @@ -93,7 +100,11 @@ func TestGroupResource(t *testing.T) { 1, ) // new group (replacement) - util.MockPostGroup(util.GenerateGroupResponseModel("new_uid", "", "_2"), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("new_uid", "", "_2"), + util.GenerateGroupResponseModel("new_uid", "", "_2"), + 1, + ) util.MockGetGroup("new_uid", util.GeneratePaginatedResponse( []map[string]interface{}{util.GenerateGroupResponseModel("new_uid", "", "_2")}), 1, @@ -186,7 +197,11 @@ func TestGroupResource429Handling(t *testing.T) { Post("/networking-uxi/v1alpha1/groups"). Reply(429). SetHeaders(util.RateLimitingHeaders) - util.MockPostGroup(util.GenerateGroupResponseModel("uid", "", ""), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("uid", "", ""), + util.GenerateGroupResponseModel("uid", "", ""), + 1, + ) util.MockGetGroup( "uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("uid", "", "")}), @@ -219,7 +234,10 @@ func TestGroupResource429Handling(t *testing.T) { Patch("/networking-uxi/v1alpha1/groups/uid"). Reply(429). SetHeaders(util.RateLimitingHeaders) - util.MockUpdateGroup("uid", util.GenerateGroupResponseModel("uid", "_2", ""), + util.MockUpdateGroup( + "uid", + map[string]interface{}{"name": "name_2"}, + util.GenerateGroupResponseModel("uid", "_2", ""), 1, ) util.MockGetGroup("uid", util.GeneratePaginatedResponse( @@ -336,7 +354,11 @@ func TestGroupResourceHttpErrorHandling(t *testing.T) { // Create group in prep for next step { PreConfig: func() { - util.MockPostGroup(util.GenerateGroupResponseModel("uid", "", ""), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("uid", "", ""), + util.GenerateGroupResponseModel("uid", "", ""), + 1, + ) util.MockGetGroup( "uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("uid", "", "")}), diff --git a/pkg/config-api-provider/test/resources/network_group_assignment_test.go b/pkg/config-api-provider/test/resources/network_group_assignment_test.go index 3d7701de..63b294aa 100644 --- a/pkg/config-api-provider/test/resources/network_group_assignment_test.go +++ b/pkg/config-api-provider/test/resources/network_group_assignment_test.go @@ -30,7 +30,11 @@ func TestNetworkGroupAssignmentResourceForWiredNetwork(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup("group_uid", util.GeneratePaginatedResponse( []map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), 2, @@ -38,7 +42,7 @@ func TestNetworkGroupAssignmentResourceForWiredNetwork(t *testing.T) { // required for network group assignment create util.MockPostNetworkGroupAssignment( - "network_group_assignment_uid", + util.GenerateNetworkGroupAssignmentRequest("network_group_assignment_uid", ""), util.GenerateNetworkGroupAssignmentResponse("network_group_assignment_uid", ""), 1, ) @@ -112,12 +116,16 @@ func TestNetworkGroupAssignmentResourceForWiredNetwork(t *testing.T) { ) // required for creating another group - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid_2", "_2", "_2"), + util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), + 1, + ) // required for network group assignment create util.MockDeleteNetworkGroupAssignment("network_group_assignment_uid", 1) util.MockPostNetworkGroupAssignment( - "network_group_assignment_uid_2", + util.GenerateNetworkGroupAssignmentRequest("network_group_assignment_uid_2", "_2"), util.GenerateNetworkGroupAssignmentResponse("network_group_assignment_uid_2", "_2"), 1, ) @@ -252,7 +260,11 @@ func TestNetworkGroupAssignmentResourceForWirelessNetwork(t *testing.T) { 2, ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -261,7 +273,7 @@ func TestNetworkGroupAssignmentResourceForWirelessNetwork(t *testing.T) { // required for network group assignment create util.MockPostNetworkGroupAssignment( - "network_group_assignment_uid", + util.GenerateNetworkGroupAssignmentRequest("network_group_assignment_uid", ""), util.GenerateNetworkGroupAssignmentResponse("network_group_assignment_uid", ""), 1, ) @@ -326,7 +338,11 @@ func TestNetworkGroupAssignmentResourceForWirelessNetwork(t *testing.T) { // required for creating another group util.MockDeleteNetworkGroupAssignment("network_group_assignment_uid", 1) - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid_2", "_2", "_2"), + util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), + 1, + ) util.MockGetGroup( "group_uid_2", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")}), @@ -351,7 +367,7 @@ func TestNetworkGroupAssignmentResourceForWirelessNetwork(t *testing.T) { 2, ) util.MockPostNetworkGroupAssignment( - "network_group_assignment_uid_2", + util.GenerateNetworkGroupAssignmentRequest("network_group_assignment_uid_2", "_2"), util.GenerateNetworkGroupAssignmentResponse("network_group_assignment_uid_2", "_2"), 1, ) @@ -478,7 +494,11 @@ func TestNetworkGroupAssignmentResource429Handling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup("group_uid", util.GeneratePaginatedResponse( []map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), 2, @@ -490,7 +510,7 @@ func TestNetworkGroupAssignmentResource429Handling(t *testing.T) { Reply(429). SetHeaders(util.RateLimitingHeaders) util.MockPostNetworkGroupAssignment( - "network_group_assignment_uid", + util.GenerateNetworkGroupAssignmentRequest("network_group_assignment_uid", ""), util.GenerateNetworkGroupAssignmentResponse("network_group_assignment_uid", ""), 1, ) @@ -591,7 +611,11 @@ func TestNetworkGroupAssignmentResourceHttpErrorHandling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup("group_uid", util.GeneratePaginatedResponse( []map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), 2, @@ -640,7 +664,11 @@ func TestNetworkGroupAssignmentResourceHttpErrorHandling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup("group_uid", util.GeneratePaginatedResponse( []map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), 2, @@ -690,7 +718,11 @@ func TestNetworkGroupAssignmentResourceHttpErrorHandling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup("group_uid", util.GeneratePaginatedResponse( []map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), 2, @@ -745,7 +777,11 @@ func TestNetworkGroupAssignmentResourceHttpErrorHandling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup("group_uid", util.GeneratePaginatedResponse( []map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), 2, @@ -753,7 +789,7 @@ func TestNetworkGroupAssignmentResourceHttpErrorHandling(t *testing.T) { // required for network group assignment create util.MockPostNetworkGroupAssignment( - "network_group_assignment_uid", + util.GenerateNetworkGroupAssignmentRequest("network_group_assignment_uid", ""), util.GenerateNetworkGroupAssignmentResponse("network_group_assignment_uid", ""), 1, ) diff --git a/pkg/config-api-provider/test/resources/sensor_group_assignment_test.go b/pkg/config-api-provider/test/resources/sensor_group_assignment_test.go index 3f58b985..f42f8514 100644 --- a/pkg/config-api-provider/test/resources/sensor_group_assignment_test.go +++ b/pkg/config-api-provider/test/resources/sensor_group_assignment_test.go @@ -29,7 +29,11 @@ func TestSensorGroupAssignmentResource(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -38,7 +42,7 @@ func TestSensorGroupAssignmentResource(t *testing.T) { // required for sensor group assignment create util.MockPostSensorGroupAssignment( - "sensor_group_assignment_uid", + util.GenerateSensorGroupAssignmentRequest("sensor_group_assignment_uid", ""), util.GenerateSensorGroupAssignmentResponse("sensor_group_assignment_uid", ""), 1, ) @@ -115,7 +119,11 @@ func TestSensorGroupAssignmentResource(t *testing.T) { // required for creating another group util.MockDeleteSensorGroupAssignment("sensor_group_assignment_uid", 1) - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid_2", "_2", "_2"), + util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), + 1, + ) // required for sensor group assignment create util.MockGetSensorGroupAssignment( @@ -130,7 +138,7 @@ func TestSensorGroupAssignmentResource(t *testing.T) { ) util.MockPostSensorGroupAssignment( - "sensor_group_assignment_uid_2", + util.GenerateSensorGroupAssignmentRequest("sensor_group_assignment_uid_2", "_2"), util.GenerateSensorGroupAssignmentResponse("sensor_group_assignment_uid_2", "_2"), 1, ) @@ -247,7 +255,11 @@ func TestSensorGroupAssignmentResource429Handling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -260,7 +272,7 @@ func TestSensorGroupAssignmentResource429Handling(t *testing.T) { Reply(429). SetHeaders(util.RateLimitingHeaders) util.MockPostSensorGroupAssignment( - "sensor_group_assignment_uid", + util.GenerateSensorGroupAssignmentRequest("sensor_group_assignment_uid", ""), util.GenerateSensorGroupAssignmentResponse("sensor_group_assignment_uid", ""), 1, ) @@ -368,7 +380,11 @@ func TestSensorGroupAssignmentResourceHttpErrorHandling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -421,7 +437,11 @@ func TestSensorGroupAssignmentResourceHttpErrorHandling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -475,7 +495,11 @@ func TestSensorGroupAssignmentResourceHttpErrorHandling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -534,7 +558,11 @@ func TestSensorGroupAssignmentResourceHttpErrorHandling(t *testing.T) { ) // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -543,7 +571,7 @@ func TestSensorGroupAssignmentResourceHttpErrorHandling(t *testing.T) { // required for sensor group assignment create util.MockPostSensorGroupAssignment( - "sensor_group_assignment_uid", + util.GenerateSensorGroupAssignmentRequest("sensor_group_assignment_uid", ""), util.GenerateSensorGroupAssignmentResponse("sensor_group_assignment_uid", ""), 1, ) diff --git a/pkg/config-api-provider/test/resources/service_test_group_assignment_test.go b/pkg/config-api-provider/test/resources/service_test_group_assignment_test.go index 29790402..6842770b 100644 --- a/pkg/config-api-provider/test/resources/service_test_group_assignment_test.go +++ b/pkg/config-api-provider/test/resources/service_test_group_assignment_test.go @@ -31,7 +31,11 @@ func TestServiceTestGroupAssignmentResource(t *testing.T) { } // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -40,7 +44,7 @@ func TestServiceTestGroupAssignmentResource(t *testing.T) { // required for serviceTest group assignment create util.MockPostServiceTestGroupAssignment( - "service_test_group_assignment_uid", + util.GenerateServiceTestGroupAssignmentRequest("service_test_group_assignment_uid", ""), util.StructToMap(util.GenerateServiceTestGroupAssignmentResponse("service_test_group_assignment_uid", "")), 1, ) @@ -101,8 +105,15 @@ func TestServiceTestGroupAssignmentResource(t *testing.T) { 3, ) + // required for deleting existing group + util.MockDeleteServiceTestGroupAssignment("service_test_group_assignment", 1) + // required for creating another group - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid_2", "_2", "_2"), + util.StructToMap(util.GenerateGroupResponseModel("group_uid_2", "_2", "_2")), + 1, + ) // required for serviceTest group assignment create resources.GetServiceTestGroupAssignment = func(uid string) config_api_client.ServiceTestGroupAssignmentsPostResponse { @@ -113,7 +124,7 @@ func TestServiceTestGroupAssignmentResource(t *testing.T) { } } util.MockPostServiceTestGroupAssignment( - "service_test_group_assignment_uid_2", + util.GenerateServiceTestGroupAssignmentRequest("service_test_group_assignment_uid_2", "_2"), util.StructToMap(util.GenerateServiceTestGroupAssignmentResponse("service_test_group_assignment_uid_2", "_2")), 1, ) @@ -176,6 +187,7 @@ func TestServiceTestGroupAssignmentResource(t *testing.T) { util.MockDeleteGroup("group_uid", 1) util.MockDeleteGroup("group_uid_2", 1) + util.MockDeleteServiceTestGroupAssignment("service_test_group_assignment_uid_2", 1) }, Config: provider.ProviderConfig + ` removed { @@ -194,7 +206,6 @@ func TestServiceTestGroupAssignmentResource(t *testing.T) { } }`, }, - // Delete testing automatically occurs in TestCase }, }) @@ -218,7 +229,11 @@ func TestServiceTestGroupAssignmentResource429Handling(t *testing.T) { } // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), @@ -232,7 +247,7 @@ func TestServiceTestGroupAssignmentResource429Handling(t *testing.T) { SetHeaders(util.RateLimitingHeaders) util.MockPostServiceTestGroupAssignment( - "service_test_group_assignment_uid", + util.GenerateServiceTestGroupAssignmentRequest("service_test_group_assignment_uid", ""), util.StructToMap(util.GenerateServiceTestGroupAssignmentResponse("service_test_group_assignment_uid", "")), 1, ) @@ -278,6 +293,7 @@ func TestServiceTestGroupAssignmentResource429Handling(t *testing.T) { ) util.MockDeleteGroup("group_uid", 1) + util.MockDeleteServiceTestGroupAssignment("service_test_group_assignment", 1) }, Config: provider.ProviderConfig + ` removed { @@ -310,7 +326,11 @@ func TestServiceTestGroupAssignmentResourceHttpErrorHandling(t *testing.T) { } // required for group create - util.MockPostGroup(util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), 1) + util.MockPostGroup( + util.GenerateGroupRequestModel("group_uid", "", ""), + util.StructToMap(util.GenerateGroupResponseModel("group_uid", "", "")), + 1, + ) util.MockGetGroup( "group_uid", util.GeneratePaginatedResponse([]map[string]interface{}{util.GenerateGroupResponseModel("group_uid", "", "")}), diff --git a/pkg/config-api-provider/test/util/utils.go b/pkg/config-api-provider/test/util/utils.go index 9fe21ebe..1291ce83 100644 --- a/pkg/config-api-provider/test/util/utils.go +++ b/pkg/config-api-provider/test/util/utils.go @@ -50,6 +50,13 @@ func GenerateGroupResponseModel(uid string, nonReplacementFieldPostfix string, r } } +func GenerateGroupRequestModel(uid string, nonReplacementFieldPostfix string, replacementFieldPostfix string) map[string]interface{} { + return map[string]interface{}{ + "name": "name" + nonReplacementFieldPostfix, + "parentId": "parent_uid" + replacementFieldPostfix, + } +} + func GeneratePaginatedResponse(items []map[string]interface{}) map[string]interface{} { return map[string]interface{}{ "items": items, @@ -114,6 +121,13 @@ func GenerateSensorGroupAssignmentResponse(uid string, postfix string) map[strin } } +func GenerateSensorGroupAssignmentRequest(uid string, postfix string) map[string]interface{} { + return map[string]interface{}{ + "groupId": "group_uid" + postfix, + "sensorId": "sensor_uid" + postfix, + } +} + func GenerateAgentGroupAssignmentResponse(uid string, postfix string) resources.AgentGroupAssignmentResponseModel { return resources.AgentGroupAssignmentResponseModel{ UID: uid, @@ -131,6 +145,13 @@ func GenerateNetworkGroupAssignmentResponse(uid string, postfix string) map[stri } } +func GenerateNetworkGroupAssignmentRequest(uid string, postfix string) map[string]interface{} { + return map[string]interface{}{ + "groupId": "group_uid" + postfix, + "networkId": "network_uid" + postfix, + } +} + func GenerateServiceTestGroupAssignmentResponse(uid string, postfix string) config_api_client.ServiceTestGroupAssignmentsPostResponse { return config_api_client.ServiceTestGroupAssignmentsPostResponse{ Id: uid, @@ -140,6 +161,13 @@ func GenerateServiceTestGroupAssignmentResponse(uid string, postfix string) conf } } +func GenerateServiceTestGroupAssignmentRequest(uid string, postfix string) map[string]interface{} { + return map[string]interface{}{ + "groupId": "group_uid" + postfix, + "serviceTestId": "service_test_uid" + postfix, + } +} + // Converts a struct to a map while maintaining the json name as keys func StructToMap(obj interface{}) map[string]interface{} { data, _ := json.Marshal(obj) // Convert to a json string @@ -164,12 +192,13 @@ func MockOAuth() *gock.Response { } -func MockPostGroup(response map[string]interface{}, times int) { +func MockPostGroup(request map[string]interface{}, response map[string]interface{}, times int) { gock.New("https://test.api.capenetworks.com"). Post("/networking-uxi/v1alpha1/groups"). MatchHeader("Content-Type", "application/json"). MatchHeader("Authorization", "mock_token"). Times(times). + JSON(request). Reply(200). JSON(response) } @@ -184,11 +213,12 @@ func MockGetGroup(uid string, response map[string]interface{}, times int) { JSON(response) } -func MockUpdateGroup(uid string, response map[string]interface{}, times int) { +func MockUpdateGroup(uid string, request map[string]interface{}, response map[string]interface{}, times int) { gock.New("https://test.api.capenetworks.com"). Patch("/networking-uxi/v1alpha1/groups/"+uid). MatchHeader("Authorization", "mock_token"). Times(times). + JSON(request). Reply(200). JSON(response) } @@ -241,12 +271,13 @@ func MockGetSensorGroupAssignment(uid string, response map[string]interface{}, t JSON(response) } -func MockPostSensorGroupAssignment(uid string, response map[string]interface{}, times int) { +func MockPostSensorGroupAssignment(request map[string]interface{}, response map[string]interface{}, times int) { gock.New("https://test.api.capenetworks.com"). Post("/networking-uxi/v1alpha1/sensor-group-assignments"). MatchHeader("Content-Type", "application/json"). MatchHeader("Authorization", "mock_token"). Times(times). + JSON(request). Reply(200). JSON(response) } @@ -269,12 +300,13 @@ func MockGetNetworkGroupAssignment(uid string, response map[string]interface{}, JSON(response) } -func MockPostNetworkGroupAssignment(uid string, response map[string]interface{}, times int) { +func MockPostNetworkGroupAssignment(request map[string]interface{}, response map[string]interface{}, times int) { gock.New("https://test.api.capenetworks.com"). Post("/networking-uxi/v1alpha1/network-group-assignments"). MatchHeader("Content-Type", "application/json"). MatchHeader("Authorization", "mock_token"). Times(times). + JSON(request). Reply(200). JSON(response) } @@ -287,16 +319,25 @@ func MockDeleteNetworkGroupAssignment(uid string, times int) { Reply(204) } -func MockPostServiceTestGroupAssignment(uid string, response map[string]interface{}, times int) { +func MockPostServiceTestGroupAssignment(request map[string]interface{}, response map[string]interface{}, times int) { gock.New("https://test.api.capenetworks.com"). Post("/networking-uxi/v1alpha1/service-test-group-assignments"). MatchHeader("Content-Type", "application/json"). MatchHeader("Authorization", "mock_token"). Times(times). + JSON(request). Reply(200). JSON(response) } +func MockDeleteServiceTestGroupAssignment(uid string, times int) { + gock.New("https://test.api.capenetworks.com"). + Delete("/uxi/v1alpha1/service-test-group-assignments/"+uid). + MatchHeader("Authorization", "mock_token"). + Times(times). + Reply(204) +} + var RateLimitingHeaders = map[string]string{ "X-RateLimit-Limit": "100", "X-RateLimit-Remaining": "0",