mirror of
				https://github.com/kubernetes-sigs/external-dns.git
				synced 2025-10-25 16:51:01 +02:00 
			
		
		
		
	Remove unnecessary Route53 code
This commit is contained in:
		
							parent
							
								
									8589ac765a
								
							
						
					
					
						commit
						f4756f8498
					
				| @ -458,37 +458,6 @@ func (p *AWSProvider) records(ctx context.Context, zones map[string]*route53.Hos | ||||
| 	return endpoints, nil | ||||
| } | ||||
| 
 | ||||
| // CreateRecords creates a given set of DNS records in the given hosted zone. | ||||
| func (p *AWSProvider) CreateRecords(ctx context.Context, endpoints []*endpoint.Endpoint) error { | ||||
| 	return p.doRecords(ctx, route53.ChangeActionCreate, endpoints) | ||||
| } | ||||
| 
 | ||||
| // DeleteRecords deletes a given set of DNS records in a given zone. | ||||
| func (p *AWSProvider) DeleteRecords(ctx context.Context, endpoints []*endpoint.Endpoint) error { | ||||
| 	return p.doRecords(ctx, route53.ChangeActionDelete, endpoints) | ||||
| } | ||||
| 
 | ||||
| func (p *AWSProvider) doRecords(ctx context.Context, action string, endpoints []*endpoint.Endpoint) error { | ||||
| 	zones, err := p.Zones(ctx) | ||||
| 	if err != nil { | ||||
| 		return errors.Wrapf(err, "failed to list zones, aborting %s doRecords action", action) | ||||
| 	} | ||||
| 
 | ||||
| 	p.AdjustEndpoints(endpoints) | ||||
| 
 | ||||
| 	return p.submitChanges(ctx, p.newChanges(action, endpoints), zones) | ||||
| } | ||||
| 
 | ||||
| // UpdateRecords updates a given set of old records to a new set of records in a given hosted zone. | ||||
| func (p *AWSProvider) UpdateRecords(ctx context.Context, updates, current []*endpoint.Endpoint) error { | ||||
| 	zones, err := p.Zones(ctx) | ||||
| 	if err != nil { | ||||
| 		return errors.Wrapf(err, "failed to list zones, aborting UpdateRecords") | ||||
| 	} | ||||
| 
 | ||||
| 	return p.submitChanges(ctx, p.createUpdateChanges(updates, current), zones) | ||||
| } | ||||
| 
 | ||||
| // Identify if old and new endpoints require DELETE/CREATE instead of UPDATE. | ||||
| func (p *AWSProvider) requiresDeleteCreate(old *endpoint.Endpoint, new *endpoint.Endpoint) bool { | ||||
| 	// a change of record type | ||||
|  | ||||
| @ -550,13 +550,15 @@ func TestAWSCreateRecords(t *testing.T) { | ||||
| 		endpoint.NewEndpoint("create-test.zone-2.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeA, "8.8.8.8"), | ||||
| 		endpoint.NewEndpointWithTTL("create-test-custom-ttl.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeA, customTTL, "172.17.0.1"), | ||||
| 		endpoint.NewEndpoint("create-test-cname.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, "foo.example.com"), | ||||
| 		endpoint.NewEndpoint("create-test-cname-alias.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, "foo.eu-central-1.elb.amazonaws.com"), | ||||
| 		endpoint.NewEndpoint("create-test-cname-alias.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, "foo.eu-central-1.elb.amazonaws.com").WithProviderSpecific(providerSpecificAlias, "true"), | ||||
| 		endpoint.NewEndpoint("create-test-cname-alias.zone-2.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, "alias-target.zone-2.ext-dns-test-2.teapot.zalan.do").WithProviderSpecific(providerSpecificAlias, "true"), | ||||
| 		endpoint.NewEndpoint("create-test-multiple.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeA, "8.8.8.8", "8.8.4.4"), | ||||
| 		endpoint.NewEndpoint("create-test-mx.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeMX, "10 mailhost1.example.com", "20 mailhost2.example.com"), | ||||
| 	} | ||||
| 
 | ||||
| 	require.NoError(t, provider.CreateRecords(context.Background(), records)) | ||||
| 	require.NoError(t, provider.ApplyChanges(context.Background(), &plan.Changes{ | ||||
| 		Create: records, | ||||
| 	})) | ||||
| 
 | ||||
| 	validateRecords(t, listAWSRecords(t, provider.client, "/hostedzone/zone-1.ext-dns-test-2.teapot.zalan.do."), []*route53.ResourceRecordSet{ | ||||
| 		{ | ||||
| @ -675,7 +677,10 @@ func TestAWSUpdateRecords(t *testing.T) { | ||||
| 		endpoint.NewEndpoint("update-test-mx.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeMX, "10 mailhost1.foo.elb.amazonaws.com", "20 mailhost2.foo.elb.amazonaws.com"), | ||||
| 	} | ||||
| 
 | ||||
| 	require.NoError(t, provider.UpdateRecords(context.Background(), updatedRecords, currentRecords)) | ||||
| 	require.NoError(t, provider.ApplyChanges(context.Background(), &plan.Changes{ | ||||
| 		UpdateOld: currentRecords, | ||||
| 		UpdateNew: updatedRecords, | ||||
| 	})) | ||||
| 
 | ||||
| 	validateRecords(t, listAWSRecords(t, provider.client, "/hostedzone/zone-1.ext-dns-test-2.teapot.zalan.do."), []*route53.ResourceRecordSet{ | ||||
| 		{ | ||||
| @ -780,15 +785,17 @@ func TestAWSDeleteRecords(t *testing.T) { | ||||
| 		}, | ||||
| 	}) | ||||
| 
 | ||||
| 	require.NoError(t, provider.DeleteRecords(context.Background(), []*endpoint.Endpoint{ | ||||
| 	require.NoError(t, provider.ApplyChanges(context.Background(), &plan.Changes{ | ||||
| 		Delete: []*endpoint.Endpoint{ | ||||
| 			endpoint.NewEndpointWithTTL("delete-test.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeA, endpoint.TTL(recordTTL), "1.2.3.4"), | ||||
| 			endpoint.NewEndpointWithTTL("delete-test.zone-2.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeA, endpoint.TTL(recordTTL), "8.8.8.8"), | ||||
| 			endpoint.NewEndpointWithTTL("delete-test-cname.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, endpoint.TTL(recordTTL), "baz.elb.amazonaws.com"), | ||||
| 		endpoint.NewEndpoint("delete-test-cname.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, "foo.eu-central-1.elb.amazonaws.com").WithProviderSpecific(providerSpecificEvaluateTargetHealth, "false"), | ||||
| 		endpoint.NewEndpoint("delete-test-cname-alias.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, "foo.eu-central-1.elb.amazonaws.com").WithProviderSpecific(providerSpecificEvaluateTargetHealth, "true"), | ||||
| 			endpoint.NewEndpoint("delete-test-cname.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, "foo.eu-central-1.elb.amazonaws.com").WithProviderSpecific(providerSpecificEvaluateTargetHealth, "false").WithProviderSpecific(providerSpecificAlias, "true"), | ||||
| 			endpoint.NewEndpoint("delete-test-cname-alias.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, "foo.eu-central-1.elb.amazonaws.com").WithProviderSpecific(providerSpecificEvaluateTargetHealth, "true").WithProviderSpecific(providerSpecificAlias, "true"), | ||||
| 			endpoint.NewEndpoint("delete-test-cname-alias.zone-2.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, "delete-test.zone-2.ext-dns-test-2.teapot.zalan.do").WithProviderSpecific(providerSpecificEvaluateTargetHealth, "true").WithProviderSpecific(providerSpecificAlias, "true").WithProviderSpecific(providerSpecificTargetHostedZone, "/hostedzone/zone-2.ext-dns-test-2.teapot.zalan.do."), | ||||
| 			endpoint.NewEndpointWithTTL("delete-test-multiple.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeA, endpoint.TTL(recordTTL), "8.8.8.8", "8.8.4.4"), | ||||
| 			endpoint.NewEndpoint("delete-test-mx.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeMX, "10 mailhost1.foo.elb.amazonaws.com", "20 mailhost2.foo.elb.amazonaws.com"), | ||||
| 		}, | ||||
| 	})) | ||||
| 
 | ||||
| 	validateRecords(t, listAWSRecords(t, provider.client, "/hostedzone/zone-1.ext-dns-test-2.teapot.zalan.do."), []*route53.ResourceRecordSet{}) | ||||
| @ -1638,7 +1645,9 @@ func TestAWSCreateRecordsWithCNAME(t *testing.T) { | ||||
| 		{DNSName: "create-test.zone-1.ext-dns-test-2.teapot.zalan.do", Targets: endpoint.Targets{"foo.example.org"}, RecordType: endpoint.RecordTypeCNAME}, | ||||
| 	} | ||||
| 
 | ||||
| 	require.NoError(t, provider.CreateRecords(context.Background(), records)) | ||||
| 	require.NoError(t, provider.ApplyChanges(context.Background(), &plan.Changes{ | ||||
| 		Create: records, | ||||
| 	})) | ||||
| 
 | ||||
| 	recordSets := listAWSRecords(t, provider.client, "/hostedzone/zone-1.ext-dns-test-2.teapot.zalan.do.") | ||||
| 
 | ||||
| @ -1671,6 +1680,10 @@ func TestAWSCreateRecordsWithALIAS(t *testing.T) { | ||||
| 				Targets:    endpoint.Targets{"foo.eu-central-1.elb.amazonaws.com"}, | ||||
| 				RecordType: endpoint.RecordTypeCNAME, | ||||
| 				ProviderSpecific: endpoint.ProviderSpecific{ | ||||
| 					endpoint.ProviderSpecificProperty{ | ||||
| 						Name:  providerSpecificAlias, | ||||
| 						Value: "true", | ||||
| 					}, | ||||
| 					endpoint.ProviderSpecificProperty{ | ||||
| 						Name:  providerSpecificEvaluateTargetHealth, | ||||
| 						Value: key, | ||||
| @ -1682,6 +1695,10 @@ func TestAWSCreateRecordsWithALIAS(t *testing.T) { | ||||
| 				Targets:    endpoint.Targets{"bar.eu-central-1.elb.amazonaws.com"}, | ||||
| 				RecordType: endpoint.RecordTypeCNAME, | ||||
| 				ProviderSpecific: endpoint.ProviderSpecific{ | ||||
| 					endpoint.ProviderSpecificProperty{ | ||||
| 						Name:  providerSpecificAlias, | ||||
| 						Value: "true", | ||||
| 					}, | ||||
| 					endpoint.ProviderSpecificProperty{ | ||||
| 						Name:  providerSpecificEvaluateTargetHealth, | ||||
| 						Value: key, | ||||
| @ -1691,7 +1708,9 @@ func TestAWSCreateRecordsWithALIAS(t *testing.T) { | ||||
| 			}, | ||||
| 		} | ||||
| 
 | ||||
| 		require.NoError(t, provider.CreateRecords(context.Background(), records)) | ||||
| 		require.NoError(t, provider.ApplyChanges(context.Background(), &plan.Changes{ | ||||
| 			Create: records, | ||||
| 		})) | ||||
| 
 | ||||
| 		recordSets := listAWSRecords(t, provider.client, "/hostedzone/zone-1.ext-dns-test-2.teapot.zalan.do.") | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user