//go:build go1.9 // +build go1.9 package endpoints import "testing" // *************************************************************************** // All endpoint metadata is sourced from the testdata/endpoints.json file at // test startup. Not the live endpoints model file. Update the testdata file // for the tests to use the latest live model. // *************************************************************************** func TestEnumDefaultPartitions(t *testing.T) { resolver := DefaultResolver() enum, ok := resolver.(EnumPartitions) if ok != true { t.Fatalf("resolver must satisfy EnumPartition interface") } ps := enum.Partitions() if a, e := len(ps), len(defaultPartitions); a != e { t.Errorf("expected %d partitions, got %d", e, a) } } func TestEnumDefaultRegions(t *testing.T) { expectPart := defaultPartitions[0] partEnum := defaultPartitions[0].Partition() regEnum := partEnum.Regions() if a, e := len(regEnum), len(expectPart.Regions); a != e { t.Errorf("expected %d regions, got %d", e, a) } } func TestEnumPartitionServices(t *testing.T) { expectPart := testPartitions[0] partEnum := testPartitions[0].Partition() if a, e := partEnum.ID(), "part-id"; a != e { t.Errorf("expect %q partition ID, got %q", e, a) } svcEnum := partEnum.Services() // Expect the number of services in the partition + ec2metadata if a, e := len(svcEnum), len(expectPart.Services)+1; a != e { t.Errorf("expected %d regions, got %d", e, a) } } func TestEnumRegionServices(t *testing.T) { p := testPartitions[0].Partition() rs := p.Regions() if a, e := len(rs), 2; a != e { t.Errorf("expect %d regions got %d", e, a) } if _, ok := rs["us-east-1"]; !ok { t.Errorf("expect us-east-1 region to be found, was not") } if _, ok := rs["us-west-2"]; !ok { t.Errorf("expect us-west-2 region to be found, was not") } r := rs["us-east-1"] if a, e := r.ID(), "us-east-1"; a != e { t.Errorf("expect %q region ID, got %q", e, a) } if a, e := r.Description(), "region description"; a != e { t.Errorf("expect %q region Description, got %q", e, a) } ss := r.Services() if a, e := len(ss), 1; a != e { t.Errorf("expect %d services for us-east-1, got %d", e, a) } if _, ok := ss["service1"]; !ok { t.Errorf("expect service1 service to be found, was not") } resolved, err := r.ResolveEndpoint("service1") if err != nil { t.Fatalf("expect no error, got %v", err) } if a, e := resolved.URL, "https://service1.us-east-1.amazonaws.com"; a != e { t.Errorf("expect %q resolved URL, got %q", e, a) } } func TestEnumServiceRegions(t *testing.T) { p := testPartitions[0].Partition() rs := p.Services()["service1"].Regions() if e, a := 2, len(rs); e != a { t.Errorf("expect %d regions, got %d", e, a) } if _, ok := rs["us-east-1"]; !ok { t.Errorf("expect region to be found") } if _, ok := rs["us-west-2"]; !ok { t.Errorf("expect region to be found") } } func TestEnumServicesEndpoints(t *testing.T) { p := testPartitions[0].Partition() ss := p.Services() // Expect the number of services in the partition + ec2metadata if a, e := len(ss), 6; a != e { t.Errorf("expect %d regions got %d", e, a) } if _, ok := ss["service1"]; !ok { t.Errorf("expect service1 region to be found, was not") } if _, ok := ss["service2"]; !ok { t.Errorf("expect service2 region to be found, was not") } s := ss["service1"] if a, e := s.ID(), "service1"; a != e { t.Errorf("expect %q service ID, got %q", e, a) } resolved, err := s.ResolveEndpoint("us-west-2") if err != nil { t.Fatalf("expect no error, got %v", err) } if a, e := resolved.URL, "https://service1.us-west-2.amazonaws.com"; a != e { t.Errorf("expect %q resolved URL, got %q", e, a) } } func TestEnumEndpoints(t *testing.T) { p := testPartitions[0].Partition() s := p.Services()["service1"] es := s.Endpoints() if a, e := len(es), 2; a != e { t.Errorf("expect %d endpoints for service2, got %d", e, a) } if _, ok := es["us-east-1"]; !ok { t.Errorf("expect us-east-1 to be found, was not") } e := es["us-east-1"] if a, e := e.ID(), "us-east-1"; a != e { t.Errorf("expect %q endpoint ID, got %q", e, a) } if a, e := e.ServiceID(), "service1"; a != e { t.Errorf("expect %q service ID, got %q", e, a) } resolved, err := e.ResolveEndpoint() if err != nil { t.Fatalf("expect no error, got %v", err) } if a, e := resolved.URL, "https://service1.us-east-1.amazonaws.com"; a != e { t.Errorf("expect %q resolved URL, got %q", e, a) } } func TestResolveEndpointForPartition(t *testing.T) { enum := testPartitions.Partitions()[0] expected, err := testPartitions.EndpointFor("service1", "us-east-1") if err != nil { t.Fatalf("unexpected error, %v", err) } actual, err := enum.EndpointFor("service1", "us-east-1") if err != nil { t.Fatalf("unexpected error, %v", err) } if expected != actual { t.Errorf("expect resolved endpoint to be %v, but got %v", expected, actual) } } func TestAddScheme(t *testing.T) { cases := []struct { In string Expect string DisableSSL bool }{ { In: "https://example.com", Expect: "https://example.com", }, { In: "example.com", Expect: "https://example.com", }, { In: "http://example.com", Expect: "http://example.com", }, { In: "example.com", Expect: "http://example.com", DisableSSL: true, }, { In: "https://example.com", Expect: "https://example.com", DisableSSL: true, }, } for i, c := range cases { actual := AddScheme(c.In, c.DisableSSL) if actual != c.Expect { t.Errorf("%d, expect URL to be %q, got %q", i, c.Expect, actual) } } } func TestResolverFunc(t *testing.T) { var resolver Resolver resolver = ResolverFunc(func(s, r string, opts ...func(*Options)) (ResolvedEndpoint, error) { return ResolvedEndpoint{ URL: "https://service.region.dnssuffix.com", SigningRegion: "region", SigningName: "service", }, nil }) resolved, err := resolver.EndpointFor("service", "region", func(o *Options) { o.DisableSSL = true }) if err != nil { t.Fatalf("expect no error, got %v", err) } if a, e := resolved.URL, "https://service.region.dnssuffix.com"; a != e { t.Errorf("expect %q endpoint URL, got %q", e, a) } if a, e := resolved.SigningRegion, "region"; a != e { t.Errorf("expect %q region, got %q", e, a) } if a, e := resolved.SigningName, "service"; a != e { t.Errorf("expect %q signing name, got %q", e, a) } } func TestOptionsSet(t *testing.T) { var actual Options actual.Set(DisableSSLOption, UseDualStackOption, StrictMatchingOption, UseDualStackEndpointOption) expect := Options{ DisableSSL: true, UseDualStack: true, UseDualStackEndpoint: DualStackEndpointStateEnabled, StrictMatching: true, } if actual != expect { t.Errorf("expect %v options got %v", expect, actual) } } func TestRegionsForService(t *testing.T) { ps := DefaultPartitions() var expect map[string]Region var serviceID string for _, s := range ps[0].Services() { expect = s.Regions() serviceID = s.ID() if len(expect) > 0 { break } } actual, ok := RegionsForService(ps, ps[0].ID(), serviceID) if !ok { t.Fatalf("expect regions to be found, was not") } if len(actual) == 0 { t.Fatalf("expect service %s to have regions", serviceID) } if e, a := len(expect), len(actual); e != a { t.Fatalf("expect %d regions, got %d", e, a) } for id, r := range actual { if e, a := id, r.ID(); e != a { t.Errorf("expect %s region id, got %s", e, a) } if _, ok := expect[id]; !ok { t.Errorf("expect %s region to be found", id) } if a, e := r.Description(), expect[id].desc; a != e { t.Errorf("expect %q region Description, got %q", e, a) } } } func TestRegionsForService_NotFound(t *testing.T) { ps := testPartitions.Partitions() actual, ok := RegionsForService(ps, ps[0].ID(), "service-not-exists") if ok { t.Fatalf("expect no regions to be found, but were") } if len(actual) != 0 { t.Errorf("expect no regions, got %v", actual) } } func TestPartitionForRegion(t *testing.T) { ps := DefaultPartitions() expect := ps[len(ps)%2] var regionID string for id := range expect.Regions() { regionID = id break } actual, ok := PartitionForRegion(ps, regionID) if !ok { t.Fatalf("expect partition to be found") } if e, a := expect.DNSSuffix(), actual.DNSSuffix(); e != a { t.Errorf("expect %s partition DNSSuffix, got %s", e, a) } if e, a := expect.ID(), actual.ID(); e != a { t.Errorf("expect %s partition ID, got %s", e, a) } } func TestPartitionForRegion_NotFound(t *testing.T) { ps := DefaultPartitions() actual, ok := PartitionForRegion(ps, "regionNotExists") if ok { t.Errorf("expect no partition to be found, got %v", actual) } } func TestEC2MetadataEndpoint(t *testing.T) { cases := []struct { Options Options Expected string }{ { Expected: ec2MetadataEndpointIPv4, }, { Options: Options{ EC2MetadataEndpointMode: EC2IMDSEndpointModeStateIPv4, }, Expected: ec2MetadataEndpointIPv4, }, { Options: Options{ EC2MetadataEndpointMode: EC2IMDSEndpointModeStateIPv6, }, Expected: ec2MetadataEndpointIPv6, }, } for _, p := range DefaultPartitions() { var region string for r := range p.Regions() { region = r break } for _, c := range cases { endpoint, err := p.EndpointFor("ec2metadata", region, func(options *Options) { *options = c.Options }) if err != nil { t.Fatalf("expect no error, got %v", err) } if e, a := c.Expected, endpoint.URL; e != a { t.Errorf("exect %v, got %v", e, a) } } } }