2020-12-09 15:31:34 +00:00
|
|
|
package middlewares
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
awssdk "github.com/aws/aws-sdk-go/aws"
|
|
|
|
"github.com/cloudskiff/driftctl/pkg/resource/aws"
|
|
|
|
|
|
|
|
"github.com/aws/aws-sdk-go/aws/awsutil"
|
|
|
|
"github.com/r3labs/diff/v2"
|
|
|
|
|
|
|
|
"github.com/cloudskiff/driftctl/pkg/resource"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestIamPolicyAttachmentSanitizer_Execute(t *testing.T) {
|
|
|
|
type resources struct {
|
|
|
|
RemoteResources *[]resource.Resource
|
|
|
|
ResourcesFromState *[]resource.Resource
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args resources
|
|
|
|
expected resources
|
|
|
|
wantErr bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "Split users and ReId", args: struct {
|
|
|
|
RemoteResources *[]resource.Resource
|
|
|
|
ResourcesFromState *[]resource.Resource
|
|
|
|
}{
|
|
|
|
RemoteResources: &[]resource.Resource{
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "wrongId",
|
|
|
|
PolicyArn: awssdk.String("arn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"jean", "paul", "pierre"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "wrongId2",
|
|
|
|
PolicyArn: awssdk.String("thisisarn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"jean", "paul", "jacques"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
ResourcesFromState: &[]resource.Resource{
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "wrongId",
|
|
|
|
PolicyArn: awssdk.String("fromstatearn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"jean"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: struct {
|
|
|
|
RemoteResources *[]resource.Resource
|
|
|
|
ResourcesFromState *[]resource.Resource
|
|
|
|
}{
|
|
|
|
RemoteResources: &[]resource.Resource{
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "jean-arn",
|
|
|
|
PolicyArn: awssdk.String("arn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"jean"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "paul-arn",
|
|
|
|
PolicyArn: awssdk.String("arn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"paul"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "pierre-arn",
|
|
|
|
PolicyArn: awssdk.String("arn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"pierre"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "jean-thisisarn",
|
|
|
|
PolicyArn: awssdk.String("thisisarn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"jean"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "paul-thisisarn",
|
|
|
|
PolicyArn: awssdk.String("thisisarn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"paul"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "jacques-thisisarn",
|
|
|
|
PolicyArn: awssdk.String("thisisarn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"jacques"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
ResourcesFromState: &[]resource.Resource{
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "jean-fromstatearn",
|
|
|
|
PolicyArn: awssdk.String("fromstatearn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Users: &[]string{"jean"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Split Roles and ReId", args: struct {
|
|
|
|
RemoteResources *[]resource.Resource
|
|
|
|
ResourcesFromState *[]resource.Resource
|
|
|
|
}{
|
|
|
|
RemoteResources: &[]resource.Resource{
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "wrongId",
|
|
|
|
PolicyArn: awssdk.String("arn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"role1", "role2", "pierre"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "wrongId2",
|
|
|
|
PolicyArn: awssdk.String("thisisarn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"role1", "role2", "role3"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
ResourcesFromState: &[]resource.Resource{
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "wrongId",
|
|
|
|
PolicyArn: awssdk.String("fromstatearn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"role1"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expected: struct {
|
|
|
|
RemoteResources *[]resource.Resource
|
|
|
|
ResourcesFromState *[]resource.Resource
|
|
|
|
}{
|
|
|
|
RemoteResources: &[]resource.Resource{
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "role1-arn",
|
|
|
|
PolicyArn: awssdk.String("arn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"role1"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "role2-arn",
|
|
|
|
PolicyArn: awssdk.String("arn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"role2"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "pierre-arn",
|
|
|
|
PolicyArn: awssdk.String("arn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"pierre"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "role1-thisisarn",
|
|
|
|
PolicyArn: awssdk.String("thisisarn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"role1"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "role2-thisisarn",
|
|
|
|
PolicyArn: awssdk.String("thisisarn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"role2"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "role3-thisisarn",
|
|
|
|
PolicyArn: awssdk.String("thisisarn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"role3"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
ResourcesFromState: &[]resource.Resource{
|
|
|
|
&aws.AwsIamPolicyAttachment{
|
|
|
|
Id: "role1-fromstatearn",
|
|
|
|
PolicyArn: awssdk.String("fromstatearn"),
|
2021-03-04 16:44:46 +00:00
|
|
|
Roles: &[]string{"role1"},
|
2020-12-09 15:31:34 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
m := IamPolicyAttachmentSanitizer{}
|
|
|
|
if err := m.Execute(tt.args.RemoteResources, tt.args.ResourcesFromState); (err != nil) != tt.wantErr {
|
|
|
|
t.Errorf("Execute() error = %v, wantErr %v", err, tt.wantErr)
|
|
|
|
}
|
|
|
|
changelog, err := diff.Diff(tt.args, tt.expected)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
if len(changelog) > 0 {
|
|
|
|
for _, change := range changelog {
|
|
|
|
t.Errorf("%s got = %v, want %v", strings.Join(change.Path, "."), awsutil.Prettify(change.From), awsutil.Prettify(change.To))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|