mirror of
				https://github.com/kubernetes-sigs/external-dns.git
				synced 2025-10-26 08:11:26 +01: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 | 	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. | // Identify if old and new endpoints require DELETE/CREATE instead of UPDATE. | ||||||
| func (p *AWSProvider) requiresDeleteCreate(old *endpoint.Endpoint, new *endpoint.Endpoint) bool { | func (p *AWSProvider) requiresDeleteCreate(old *endpoint.Endpoint, new *endpoint.Endpoint) bool { | ||||||
| 	// a change of record type | 	// 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.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.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.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-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-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"), | 		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{ | 	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"), | 		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{ | 	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{ | ||||||
| 		endpoint.NewEndpointWithTTL("delete-test.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeA, endpoint.TTL(recordTTL), "1.2.3.4"), | 		Delete: []*endpoint.Endpoint{ | ||||||
| 		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.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeA, endpoint.TTL(recordTTL), "1.2.3.4"), | ||||||
| 		endpoint.NewEndpointWithTTL("delete-test-cname.zone-1.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeCNAME, endpoint.TTL(recordTTL), "baz.elb.amazonaws.com"), | 			endpoint.NewEndpointWithTTL("delete-test.zone-2.ext-dns-test-2.teapot.zalan.do", endpoint.RecordTypeA, endpoint.TTL(recordTTL), "8.8.8.8"), | ||||||
| 		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.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-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-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.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.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-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.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"), | 			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{}) | 	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}, | 		{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.") | 	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"}, | 				Targets:    endpoint.Targets{"foo.eu-central-1.elb.amazonaws.com"}, | ||||||
| 				RecordType: endpoint.RecordTypeCNAME, | 				RecordType: endpoint.RecordTypeCNAME, | ||||||
| 				ProviderSpecific: endpoint.ProviderSpecific{ | 				ProviderSpecific: endpoint.ProviderSpecific{ | ||||||
|  | 					endpoint.ProviderSpecificProperty{ | ||||||
|  | 						Name:  providerSpecificAlias, | ||||||
|  | 						Value: "true", | ||||||
|  | 					}, | ||||||
| 					endpoint.ProviderSpecificProperty{ | 					endpoint.ProviderSpecificProperty{ | ||||||
| 						Name:  providerSpecificEvaluateTargetHealth, | 						Name:  providerSpecificEvaluateTargetHealth, | ||||||
| 						Value: key, | 						Value: key, | ||||||
| @ -1682,6 +1695,10 @@ func TestAWSCreateRecordsWithALIAS(t *testing.T) { | |||||||
| 				Targets:    endpoint.Targets{"bar.eu-central-1.elb.amazonaws.com"}, | 				Targets:    endpoint.Targets{"bar.eu-central-1.elb.amazonaws.com"}, | ||||||
| 				RecordType: endpoint.RecordTypeCNAME, | 				RecordType: endpoint.RecordTypeCNAME, | ||||||
| 				ProviderSpecific: endpoint.ProviderSpecific{ | 				ProviderSpecific: endpoint.ProviderSpecific{ | ||||||
|  | 					endpoint.ProviderSpecificProperty{ | ||||||
|  | 						Name:  providerSpecificAlias, | ||||||
|  | 						Value: "true", | ||||||
|  | 					}, | ||||||
| 					endpoint.ProviderSpecificProperty{ | 					endpoint.ProviderSpecificProperty{ | ||||||
| 						Name:  providerSpecificEvaluateTargetHealth, | 						Name:  providerSpecificEvaluateTargetHealth, | ||||||
| 						Value: key, | 						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.") | 		recordSets := listAWSRecords(t, provider.client, "/hostedzone/zone-1.ext-dns-test-2.teapot.zalan.do.") | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user