lock pirvatedns zone cache and remove cache for filtering recordset
parent
70ddf3c042
commit
53471fa02c
|
@ -99,11 +99,6 @@ func (s *privateDNSRepository) listAllRecords(zone *armprivatedns.PrivateZone) (
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *privateDNSRepository) ListAllARecords(zone *armprivatedns.PrivateZone) ([]*armprivatedns.RecordSet, error) {
|
func (s *privateDNSRepository) ListAllARecords(zone *armprivatedns.PrivateZone) ([]*armprivatedns.RecordSet, error) {
|
||||||
cacheKey := fmt.Sprintf("privateDNSListAllARecords-%s", *zone.ID)
|
|
||||||
if v := s.cache.Get(cacheKey); v != nil {
|
|
||||||
return v.([]*armprivatedns.RecordSet), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
records, err := s.listAllRecords(zone)
|
records, err := s.listAllRecords(zone)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -116,18 +111,10 @@ func (s *privateDNSRepository) ListAllARecords(zone *armprivatedns.PrivateZone)
|
||||||
results = append(results, record)
|
results = append(results, record)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
s.cache.Put(cacheKey, results)
|
|
||||||
|
|
||||||
return results, nil
|
return results, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *privateDNSRepository) ListAllAAAARecords(zone *armprivatedns.PrivateZone) ([]*armprivatedns.RecordSet, error) {
|
func (s *privateDNSRepository) ListAllAAAARecords(zone *armprivatedns.PrivateZone) ([]*armprivatedns.RecordSet, error) {
|
||||||
cacheKey := fmt.Sprintf("privateDNSListAllAAAARecords-%s", *zone.ID)
|
|
||||||
if v := s.cache.Get(cacheKey); v != nil {
|
|
||||||
return v.([]*armprivatedns.RecordSet), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
records, err := s.listAllRecords(zone)
|
records, err := s.listAllRecords(zone)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -140,18 +127,10 @@ func (s *privateDNSRepository) ListAllAAAARecords(zone *armprivatedns.PrivateZon
|
||||||
results = append(results, record)
|
results = append(results, record)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
s.cache.Put(cacheKey, results)
|
|
||||||
|
|
||||||
return results, nil
|
return results, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *privateDNSRepository) ListAllCNAMERecords(zone *armprivatedns.PrivateZone) ([]*armprivatedns.RecordSet, error) {
|
func (s *privateDNSRepository) ListAllCNAMERecords(zone *armprivatedns.PrivateZone) ([]*armprivatedns.RecordSet, error) {
|
||||||
cacheKey := fmt.Sprintf("privateDNSListAllCNAMERecords-%s", *zone.ID)
|
|
||||||
if v := s.cache.Get(cacheKey); v != nil {
|
|
||||||
return v.([]*armprivatedns.RecordSet), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
records, err := s.listAllRecords(zone)
|
records, err := s.listAllRecords(zone)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -164,15 +143,14 @@ func (s *privateDNSRepository) ListAllCNAMERecords(zone *armprivatedns.PrivateZo
|
||||||
results = append(results, record)
|
results = append(results, record)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
s.cache.Put(cacheKey, results)
|
|
||||||
|
|
||||||
return results, nil
|
return results, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *privateDNSRepository) ListAllPrivateZones() ([]*armprivatedns.PrivateZone, error) {
|
func (s *privateDNSRepository) ListAllPrivateZones() ([]*armprivatedns.PrivateZone, error) {
|
||||||
cacheKey := "privateDNSListAllPrivateZones"
|
cacheKey := "privateDNSListAllPrivateZones"
|
||||||
if v := s.cache.Get(cacheKey); v != nil {
|
v := s.cache.GetAndLock(cacheKey)
|
||||||
|
defer s.cache.Unlock(cacheKey)
|
||||||
|
if v != nil {
|
||||||
return v.([]*armprivatedns.PrivateZone), nil
|
return v.([]*armprivatedns.PrivateZone), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -100,7 +100,8 @@ func Test_ListAllPrivateZones_MultiplesResults(t *testing.T) {
|
||||||
fakeClient.On("List", mock.Anything).Return(mockPager)
|
fakeClient.On("List", mock.Anything).Return(mockPager)
|
||||||
|
|
||||||
c := &cache.MockCache{}
|
c := &cache.MockCache{}
|
||||||
c.On("Get", "privateDNSListAllPrivateZones").Return(nil).Times(1)
|
c.On("GetAndLock", "privateDNSListAllPrivateZones").Return(nil).Times(1)
|
||||||
|
c.On("Unlock", "privateDNSListAllPrivateZones").Times(1)
|
||||||
c.On("Put", "privateDNSListAllPrivateZones", expected).Return(true).Times(1)
|
c.On("Put", "privateDNSListAllPrivateZones", expected).Return(true).Times(1)
|
||||||
s := &privateDNSRepository{
|
s := &privateDNSRepository{
|
||||||
zoneClient: fakeClient,
|
zoneClient: fakeClient,
|
||||||
|
@ -136,7 +137,9 @@ func Test_ListAllPrivateZones_MultiplesResults_WithCache(t *testing.T) {
|
||||||
fakeClient := &mockPrivateZonesClient{}
|
fakeClient := &mockPrivateZonesClient{}
|
||||||
|
|
||||||
c := &cache.MockCache{}
|
c := &cache.MockCache{}
|
||||||
c.On("Get", "privateDNSListAllPrivateZones").Return(expected).Times(1)
|
c.On("GetAndLock", "privateDNSListAllPrivateZones").Return(expected).Times(1)
|
||||||
|
c.On("Unlock", "privateDNSListAllPrivateZones").Times(1)
|
||||||
|
|
||||||
s := &privateDNSRepository{
|
s := &privateDNSRepository{
|
||||||
zoneClient: fakeClient,
|
zoneClient: fakeClient,
|
||||||
cache: c,
|
cache: c,
|
||||||
|
@ -279,8 +282,6 @@ func Test_ListAllARecords_MultiplesResults(t *testing.T) {
|
||||||
fakeRecordSetClient.On("List", "rgid", "zone", (*armprivatedns.RecordSetsListOptions)(nil)).Return(mockPager)
|
fakeRecordSetClient.On("List", "rgid", "zone", (*armprivatedns.RecordSetsListOptions)(nil)).Return(mockPager)
|
||||||
|
|
||||||
c := &cache.MockCache{}
|
c := &cache.MockCache{}
|
||||||
c.On("Get", "privateDNSListAllARecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(nil).Times(1)
|
|
||||||
c.On("Put", "privateDNSListAllARecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com", expected).Return(true).Times(1)
|
|
||||||
c.On("GetAndLock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(nil).Times(1)
|
c.On("GetAndLock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(nil).Times(1)
|
||||||
c.On("Unlock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return().Times(1)
|
c.On("Unlock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return().Times(1)
|
||||||
c.On("Put", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com", mock.Anything).Return(true).Times(1)
|
c.On("Put", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com", mock.Anything).Return(true).Times(1)
|
||||||
|
@ -319,13 +320,19 @@ func Test_ListAllARecords_MultiplesResults_WithCache(t *testing.T) {
|
||||||
ID: to.StringPtr("record1"),
|
ID: to.StringPtr("record1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Properties: &armprivatedns.RecordSetProperties{
|
||||||
|
ARecords: []*armprivatedns.ARecord{
|
||||||
|
{IPv4Address: to.StringPtr("ip")},
|
||||||
|
},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
fakeRecordSetClient := &mockPrivateRecordSetClient{}
|
fakeRecordSetClient := &mockPrivateRecordSetClient{}
|
||||||
|
|
||||||
c := &cache.MockCache{}
|
c := &cache.MockCache{}
|
||||||
c.On("Get", "privateDNSListAllARecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(expected).Times(1)
|
c.On("GetAndLock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(expected).Times(1)
|
||||||
|
c.On("Unlock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Times(1)
|
||||||
s := &privateDNSRepository{
|
s := &privateDNSRepository{
|
||||||
recordClient: fakeRecordSetClient,
|
recordClient: fakeRecordSetClient,
|
||||||
cache: c,
|
cache: c,
|
||||||
|
@ -482,8 +489,6 @@ func Test_ListAllAAAARecords_MultiplesResults(t *testing.T) {
|
||||||
fakeRecordSetClient.On("List", "rgid", "zone", (*armprivatedns.RecordSetsListOptions)(nil)).Return(mockPager)
|
fakeRecordSetClient.On("List", "rgid", "zone", (*armprivatedns.RecordSetsListOptions)(nil)).Return(mockPager)
|
||||||
|
|
||||||
c := &cache.MockCache{}
|
c := &cache.MockCache{}
|
||||||
c.On("Get", "privateDNSListAllAAAARecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(nil).Times(1)
|
|
||||||
c.On("Put", "privateDNSListAllAAAARecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com", expected).Return(true).Times(1)
|
|
||||||
c.On("GetAndLock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(nil).Times(1)
|
c.On("GetAndLock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(nil).Times(1)
|
||||||
c.On("Unlock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return().Times(1)
|
c.On("Unlock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return().Times(1)
|
||||||
c.On("Put", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com", mock.Anything).Return(true).Times(1)
|
c.On("Put", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com", mock.Anything).Return(true).Times(1)
|
||||||
|
@ -522,13 +527,19 @@ func Test_ListAllAAAARecords_MultiplesResults_WithCache(t *testing.T) {
|
||||||
ID: to.StringPtr("record1"),
|
ID: to.StringPtr("record1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Properties: &armprivatedns.RecordSetProperties{
|
||||||
|
AaaaRecords: []*armprivatedns.AaaaRecord{
|
||||||
|
{IPv6Address: to.StringPtr("ip")},
|
||||||
|
},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
fakeRecordSetClient := &mockPrivateRecordSetClient{}
|
fakeRecordSetClient := &mockPrivateRecordSetClient{}
|
||||||
|
|
||||||
c := &cache.MockCache{}
|
c := &cache.MockCache{}
|
||||||
c.On("Get", "privateDNSListAllAAAARecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(expected).Times(1)
|
c.On("GetAndLock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(expected).Times(1)
|
||||||
|
c.On("Unlock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Times(1)
|
||||||
s := &privateDNSRepository{
|
s := &privateDNSRepository{
|
||||||
recordClient: fakeRecordSetClient,
|
recordClient: fakeRecordSetClient,
|
||||||
cache: c,
|
cache: c,
|
||||||
|
@ -685,8 +696,6 @@ func Test_ListAllCNAMERecords_MultiplesResults(t *testing.T) {
|
||||||
fakeRecordSetClient.On("List", "rgid", "zone", (*armprivatedns.RecordSetsListOptions)(nil)).Return(mockPager)
|
fakeRecordSetClient.On("List", "rgid", "zone", (*armprivatedns.RecordSetsListOptions)(nil)).Return(mockPager)
|
||||||
|
|
||||||
c := &cache.MockCache{}
|
c := &cache.MockCache{}
|
||||||
c.On("Get", "privateDNSListAllCNAMERecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(nil).Times(1)
|
|
||||||
c.On("Put", "privateDNSListAllCNAMERecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com", expected).Return(true).Times(1)
|
|
||||||
c.On("GetAndLock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(nil).Times(1)
|
c.On("GetAndLock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(nil).Times(1)
|
||||||
c.On("Unlock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return().Times(1)
|
c.On("Unlock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return().Times(1)
|
||||||
c.On("Put", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com", mock.Anything).Return(true).Times(1)
|
c.On("Put", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com", mock.Anything).Return(true).Times(1)
|
||||||
|
@ -725,13 +734,21 @@ func Test_ListAllCNAMERecords_MultiplesResults_WithCache(t *testing.T) {
|
||||||
ID: to.StringPtr("record1"),
|
ID: to.StringPtr("record1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Properties: &armprivatedns.RecordSetProperties{
|
||||||
|
CnameRecord: &armprivatedns.CnameRecord{
|
||||||
|
Cname: to.StringPtr("cname"),
|
||||||
|
},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
fakeRecordSetClient := &mockPrivateRecordSetClient{}
|
fakeRecordSetClient := &mockPrivateRecordSetClient{}
|
||||||
|
|
||||||
c := &cache.MockCache{}
|
c := &cache.MockCache{}
|
||||||
c.On("Get", "privateDNSListAllCNAMERecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(expected).Times(1)
|
|
||||||
|
c.On("GetAndLock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return(expected).Times(1)
|
||||||
|
c.On("Unlock", "privateDNSlistAllRecords-/subscriptions/subid/resourceGroups/rgid/providers/Microsoft.Network/privateDnsZones/zone.com").Return().Times(1)
|
||||||
|
|
||||||
s := &privateDNSRepository{
|
s := &privateDNSRepository{
|
||||||
recordClient: fakeRecordSetClient,
|
recordClient: fakeRecordSetClient,
|
||||||
cache: c,
|
cache: c,
|
||||||
|
|
Loading…
Reference in New Issue