package ec2 import ( "fmt" "reflect" "testing" "time" ) func TestParseMetadataSecurityCredentialsFailure(t *testing.T) { f := func(s string) { t.Helper() creds, err := parseMetadataSecurityCredentials([]byte(s)) if err == nil { t.Fatalf("expecting non-nil error") } if creds != nil { t.Fatalf("expecting nil apiCreds; got %v", creds) } } f("") f("foobar") } func TestParseMetadataSecurityCredentialsSuccess(t *testing.T) { // See https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/iam-roles-for-amazon-ec2.html s := `{ "Code" : "Success", "LastUpdated" : "2012-04-26T16:39:16Z", "Type" : "AWS-HMAC", "AccessKeyId" : "ASIAIOSFODNN7EXAMPLE", "SecretAccessKey" : "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY", "Token" : "token", "Expiration" : "2017-05-17T15:09:54Z" }` creds, err := parseMetadataSecurityCredentials([]byte(s)) if err != nil { t.Fatalf("unexpected error: %s", err) } credsExpected := &apiCredentials{ AccessKeyID: "ASIAIOSFODNN7EXAMPLE", SecretAccessKey: "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY", Token: "token", Expiration: mustParseRFC3339("2017-05-17T15:09:54Z"), } if !reflect.DeepEqual(creds, credsExpected) { t.Fatalf("unexpected creds;\ngot\n%+v\nwant\n%+v", creds, credsExpected) } } func TestParseARNCredentialsFailure(t *testing.T) { f := func(s string) { t.Helper() creds, err := parseARNCredentials([]byte(s), "") if err == nil { t.Fatalf("expecting non-nil error") } if creds != nil { t.Fatalf("expecting nil apiCreds; got %v", creds) } } f("") f("foobar") } func TestParseARNCredentialsSuccess(t *testing.T) { f := func(data, role string, credsExpected *apiCredentials) { t.Helper() creds, err := parseARNCredentials([]byte(data), role) if err != nil { t.Fatalf("unexpected error: %s", err) } if !reflect.DeepEqual(creds, credsExpected) { t.Fatalf("unexpected creds;\ngot\n%+v\nwant\n%+v", creds, credsExpected) } } // See https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html s := ` arn:aws:sts::123456789012:assumed-role/demo/TestAR ARO123EXAMPLE123:TestAR ASIAIOSFODNN7EXAMPLE wJalrXUtnFEMI/K7MDENG/bPxRfiCYzEXAMPLEKEY AQoDYXdzEPT//////////wEXAMPLEtc764bNrC9SAPBSM22wDOk4x4HIZ8j4FZTwdQW LWsKWHGBuFqwAeMicRXmxfpSPfIeoIYRqTflfKD8YUuwthAx7mSEI/qkPpKPi/kMcGd QrmGdeehM4IC1NtBmUpp2wUE8phUZampKsburEDy0KPkyQDYwT7WZ0wq5VSXDvp75YU 9HFvlRd8Tx6q6fE8YQcHNVXAkiY9q6d+xo0rKwT38xVqr7ZD0u0iPPkUL64lIZbqBAz +scqKmlzm8FDrypNC9Yjc8fPOLn9FX9KSYvKTr4rvx3iSIlTJabIQwj2ICCR/oLxBA== 2019-11-09T13:34:41Z 6 c6104cbe-af31-11e0-8154-cbc7ccf896c7 ` credsExpected := &apiCredentials{ AccessKeyID: "ASIAIOSFODNN7EXAMPLE", SecretAccessKey: "wJalrXUtnFEMI/K7MDENG/bPxRfiCYzEXAMPLEKEY", Token: ` AQoDYXdzEPT//////////wEXAMPLEtc764bNrC9SAPBSM22wDOk4x4HIZ8j4FZTwdQW LWsKWHGBuFqwAeMicRXmxfpSPfIeoIYRqTflfKD8YUuwthAx7mSEI/qkPpKPi/kMcGd QrmGdeehM4IC1NtBmUpp2wUE8phUZampKsburEDy0KPkyQDYwT7WZ0wq5VSXDvp75YU 9HFvlRd8Tx6q6fE8YQcHNVXAkiY9q6d+xo0rKwT38xVqr7ZD0u0iPPkUL64lIZbqBAz +scqKmlzm8FDrypNC9Yjc8fPOLn9FX9KSYvKTr4rvx3iSIlTJabIQwj2ICCR/oLxBA== `, Expiration: mustParseRFC3339("2019-11-09T13:34:41Z"), } s2 := ` sts.amazonaws.com AROA2X6NOXN27E3OGMK3T:vmagent-ec2-discovery arn:aws:sts::111111111:assumed-role/eks-role-9N0EFKEDJ1X/vmagent-ec2-discovery arn:aws:iam::111111111:oidc-provider/oidc.eks.eu-west-1.amazonaws.com/id/111111111 ASIABYASSDASF asffasfasf/RvxIQpCid4iRMGm56nnRs2oKgV asfafsassssssssss/MlyKUPOYAiEAq5HgS19Mf8SJ3kIKU3NCztDeZW5EUW4NrPrPyXQ8om0q/AQIjv////////// 2021-03-01T13:38:15Z system:serviceaccount:default:vmagent 1214124-7bb0-4673-ad6d-af9e67fc1141 ` credsExpected2 := &apiCredentials{ AccessKeyID: "ASIABYASSDASF", SecretAccessKey: "asffasfasf/RvxIQpCid4iRMGm56nnRs2oKgV", Token: "asfafsassssssssss/MlyKUPOYAiEAq5HgS19Mf8SJ3kIKU3NCztDeZW5EUW4NrPrPyXQ8om0q/AQIjv//////////", Expiration: mustParseRFC3339("2021-03-01T13:38:15Z"), } f(s, "AssumeRole", credsExpected) f(s2, "AssumeRoleWithWebIdentity", credsExpected2) } func mustParseRFC3339(s string) time.Time { expTime, err := time.Parse(time.RFC3339, s) if err != nil { panic(fmt.Errorf("unexpected error when parsing time from %q: %w", s, err)) } return expTime }