mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-07 00:22:16 +01:00
312fead9a2
* Add improvements to ec2 discovery https://github.com/VictoriaMetrics/VictoriaMetrics/issues/771 role_arn support with aws sts instance iam_role support refreshing temporary tokens * Apply suggestions from code review Co-authored-by: Roman Khavronenko <hagen1778@gmail.com> * changed implementation, removed tests, clean up code * moved endpoint builder into getEC2APIResponse Co-authored-by: Roman Khavronenko <hagen1778@gmail.com>
30 lines
923 B
Go
30 lines
923 B
Go
package ec2
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
func TestNewSignedRequest(t *testing.T) {
|
|
f := func(apiURL string, authHeaderExpected string) {
|
|
t.Helper()
|
|
service := "ec2"
|
|
region := "us-east-1"
|
|
ac := &apiCredentials{
|
|
AccessKeyID: "fake-access-key",
|
|
SecretAccessKey: "foobar",
|
|
}
|
|
ct := time.Unix(0, 0).UTC()
|
|
req, err := newSignedRequestWithTime(apiURL, service, region, ac, ct)
|
|
if err != nil {
|
|
t.Fatalf("error in newSignedRequest: %s", err)
|
|
}
|
|
authHeader := req.Header.Get("Authorization")
|
|
if authHeader != authHeaderExpected {
|
|
t.Fatalf("unexpected auth header;\ngot\n%s\nwant\n%s", authHeader, authHeaderExpected)
|
|
}
|
|
}
|
|
f("https://ec2.amazonaws.com/?Action=DescribeRegions&Version=2013-10-15",
|
|
"AWS4-HMAC-SHA256 Credential=fake-access-key/19700101/us-east-1/ec2/aws4_request, SignedHeaders=host;x-amz-date, Signature=79dc8f54719a4c11edcd5811824a071361b3514172a3f5c903b7e279dfa6a710")
|
|
}
|