Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added NS RRSet example in Docs #262

Merged
merged 40 commits into from
Mar 28, 2024
Merged
Changes from 1 commit
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
ff07002
Added entities for work with DNS v2 API.
dchudik Jan 23, 2024
75a282b
Resolve merge conflicts in go.mod and go.sum after added entities for…
dchudik Jan 23, 2024
60394c5
Fix test: import zone for dns v2.
dchudik Jan 23, 2024
4db5403
Fix linters
dchudik Jan 23, 2024
da20624
Update entities selectel_domains_v2 for work with domains-go 1.0.2. A…
dchudik Jan 26, 2024
6629170
Remove "computed: true" from project_id in datasource domains_zone_v2.
dchudik Jan 26, 2024
08378f2
Added docs. Added ForceNew for not editable fields.
dchudik Feb 1, 2024
59a8313
Remove deprecated marks. DNSv1 is legacy.
dchudik Feb 5, 2024
3a905d7
Fix linter. Resolve go.mod conflicts. Rename rrset into two styles: r…
dchudik Feb 6, 2024
eef3b83
Merge branch 'master' into master
dchudik Feb 6, 2024
42c5c5c
Fix acceptance tests for import domains_v2 resources
dchudik Feb 6, 2024
34e655d
Update examples in docs. project_id required
dchudik Feb 9, 2024
3c1e75e
Merge branch 'master' into master
dchudik Feb 13, 2024
5f3bd5e
Added comments in import functions for domains_v2 resources. Used d.I…
dchudik Feb 13, 2024
5fa55d5
Fix docs for domains
dchudik Feb 21, 2024
b113a5a
Fix docs in domains
dchudik Feb 22, 2024
dd21ccf
Fix docs for domains
dchudik Feb 22, 2024
6ccebf5
Remove domains_v2 datasources with docs
dchudik Feb 26, 2024
82bf5f5
Added entities for work with DNS v2 API.
dchudik Jan 23, 2024
e006c45
Resolve merge conflicts in go.mod and go.sum after added entities for…
dchudik Jan 23, 2024
b41a52b
Fix test: import zone for dns v2.
dchudik Jan 23, 2024
bde2c6a
Fix linters
dchudik Jan 23, 2024
5288b16
Update entities selectel_domains_v2 for work with domains-go 1.0.2. A…
dchudik Jan 26, 2024
3d59a71
Remove "computed: true" from project_id in datasource domains_zone_v2.
dchudik Jan 26, 2024
4cc4482
Added docs. Added ForceNew for not editable fields.
dchudik Feb 1, 2024
7d97ac0
Remove deprecated marks. DNSv1 is legacy.
dchudik Feb 5, 2024
69802da
Fix linter. Resolve go.mod conflicts. Rename rrset into two styles: r…
dchudik Feb 6, 2024
6f3d0cd
Fix acceptance tests for import domains_v2 resources
dchudik Feb 6, 2024
7192a92
Update examples in docs. project_id required
dchudik Feb 9, 2024
7385ec6
Added comments in import functions for domains_v2 resources. Used d.I…
dchudik Feb 13, 2024
e20f478
Fix docs for domains
dchudik Feb 21, 2024
9e26587
Fix docs in domains
dchudik Feb 22, 2024
13932bd
Fix docs for domains
dchudik Feb 22, 2024
3d48fa3
Remove domains_v2 datasources with docs
dchudik Feb 26, 2024
ed87272
Merge remote-tracking branch 'origin/master'
Mar 22, 2024
d219551
Added NS RRSet in docs
dchudik Mar 22, 2024
9e64685
Merge branch 'master' into master
dchudik Mar 24, 2024
828f22c
Merge branch 'master' into master
dchudik Mar 25, 2024
f9d619c
Fix misprint in project_id
dchudik Mar 25, 2024
ddfc3d6
Fix NS RRSet example in docs
dchudik Mar 28, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fix linters
dchudik authored Jan 23, 2024
commit 4db5403fd490b05984200bce8c9ef72563bff60a
4 changes: 2 additions & 2 deletions selectel/data_source_selectel_domains_rrset_v2_test.go
Original file line number Diff line number Diff line change
@@ -11,14 +11,14 @@ import (
domainsV2 "github.com/selectel/domains-go/pkg/v2"
)

const resourceRrsetName = "rrset_tf_acc_test_1"

func TestAccDomainsRrsetV2DataSourceBasic(t *testing.T) {
testZoneName := fmt.Sprintf("%s.ru.", acctest.RandomWithPrefix("tf-acc"))
testRrsetName := fmt.Sprintf("%[1]s.%[2]s", acctest.RandomWithPrefix("tf-acc"), testZoneName)
testRrsetType := domainsV2.TXT
testRrsetTTL := 60
testRrrsetContent := fmt.Sprintf("\"%[1]s\"", acctest.RandString(16))
resourceZoneName := "zone_tf_acc_test_1"
resourceRrsetName := "rrset_tf_acc_test_1"
dataSourceRrrsetName := fmt.Sprintf("data.selectel_domains_rrset_v2.%[1]s", resourceRrsetName)
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccSelectelPreCheckWithProjectID(t) },
3 changes: 2 additions & 1 deletion selectel/data_source_selectel_domains_zone_v2_test.go
Original file line number Diff line number Diff line change
@@ -11,9 +11,10 @@ import (
"github.com/hashicorp/terraform-plugin-sdk/v2/terraform"
)

const resourceZoneName = "zone_tf_acc_test_1"

func TestAccDomainsZoneV2DataSourceBasic(t *testing.T) {
testZoneName := fmt.Sprintf("%s.ru.", acctest.RandomWithPrefix("tf-acc"))
resourceZoneName := "zone_tf_acc_test_1"
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccSelectelPreCheckWithProjectID(t) },
ProviderFactories: testAccProviders,
4 changes: 2 additions & 2 deletions selectel/domains_v2.go
Original file line number Diff line number Diff line change
@@ -26,11 +26,11 @@ func getDomainsV2Client(meta interface{}) (domainsV2.DNSClient[domainsV2.Zone, d

httpClient := &http.Client{}
userAgent := "terraform-provider-selectel"
defaultApiURL := "https://api.selectel.ru/domains/v2"
defaultAPIURL := "https://api.selectel.ru/domains/v2"
hdrs := http.Header{}
hdrs.Add("X-Auth-Token", selvpcClient.GetXAuthToken())
hdrs.Add("User-Agent", userAgent)
domainsClient := domainsV2.NewClient(defaultApiURL, httpClient, hdrs)
domainsClient := domainsV2.NewClient(defaultAPIURL, httpClient, hdrs)

return domainsClient, nil
}
38 changes: 20 additions & 18 deletions selectel/domains_v2_test.go
Original file line number Diff line number Diff line change
@@ -19,21 +19,23 @@ func (client *mockedDNSv2Client) ListZones(ctx context.Context, opts *map[string
args := client.Called(ctx, opts)
zones := args.Get(0).(domainsV2.Listable[domainsV2.Zone])
err := args.Error(1)

return zones, err
}

func (client *mockedDNSv2Client) ListRRSets(ctx context.Context, zoneID string, opts *map[string]string) (domainsV2.Listable[domainsV2.RRSet], error) {
args := client.Called(ctx, zoneID, opts)
rrsets := args.Get(0).(domainsV2.Listable[domainsV2.RRSet])
err := args.Error(1)

return rrsets, err
}

func TestGetZoneByName_whenNeededZoneInResponseWithOffset(t *testing.T) {
nameForSearch := "test.xyz."
correctIdForSearch := "mocked-uuid-2"
correctIDForSearch := "mocked-uuid-2"

mDnsClient := new(mockedDNSv2Client)
mDNSClient := new(mockedDNSv2Client)
ctx := context.Background()
nextOffset := 3
opts1 := &map[string]string{
@@ -47,45 +49,45 @@ func TestGetZoneByName_whenNeededZoneInResponseWithOffset(t *testing.T) {
"offset": strconv.Itoa(nextOffset),
}
incorrectNameForSearch := "a." + nameForSearch
incorrectIdForSearch := "mocked-uuid-1"
incorrectIDForSearch := "mocked-uuid-1"
zonesWithNextOffset := domainsV2.Listable[domainsV2.Zone](domainsV2.List[domainsV2.Zone]{
Count: 1,
NextOffset: nextOffset,
Items: []*domainsV2.Zone{
{
UUID: incorrectIdForSearch,
UUID: incorrectIDForSearch,
Name: incorrectNameForSearch,
},
},
})
mDnsClient.On("ListZones", ctx, opts1).Return(zonesWithNextOffset, nil)
mDNSClient.On("ListZones", ctx, opts1).Return(zonesWithNextOffset, nil)
zonesWithoutNextOffset := domainsV2.Listable[domainsV2.Zone](domainsV2.List[domainsV2.Zone]{
Count: 1,
NextOffset: 0,
Items: []*domainsV2.Zone{
{
UUID: correctIdForSearch,
UUID: correctIDForSearch,
Name: nameForSearch,
},
},
})
mDnsClient.On("ListZones", ctx, opts2).Return(zonesWithoutNextOffset, nil)
mDNSClient.On("ListZones", ctx, opts2).Return(zonesWithoutNextOffset, nil)

zone, err := getZoneByName(ctx, mDnsClient, nameForSearch)
zone, err := getZoneByName(ctx, mDNSClient, nameForSearch)

assert.NoError(t, err)

assert.NotNil(t, zone)
assert.Equal(t, correctIdForSearch, zone.UUID)
assert.Equal(t, correctIDForSearch, zone.UUID)
assert.Equal(t, nameForSearch, zone.Name)
}

func TestGetRrsetByNameAndType_whenNeededRrrsetInResponseWithOffset(t *testing.T) {
rrsetNameForSearch := "test.xyz."
rrsetTypeForSearch := "A"
correctIdForSearch := "mocked-uuid-2"
correctIDForSearch := "mocked-uuid-2"
mockedZoneID := "mopcked-zone-id"
mDnsClient := new(mockedDNSv2Client)
mDNSClient := new(mockedDNSv2Client)
ctx := context.Background()
nextOffset := 3
opts1 := &map[string]string{
@@ -101,38 +103,38 @@ func TestGetRrsetByNameAndType_whenNeededRrrsetInResponseWithOffset(t *testing.T
"offset": strconv.Itoa(nextOffset),
}
incorrectNameForSearch := "a." + rrsetNameForSearch
incorrectIdForSearch := "mocked-uuid-1"
incorrectIDForSearch := "mocked-uuid-1"
rrsetWithNextOffset := domainsV2.Listable[domainsV2.RRSet](domainsV2.List[domainsV2.RRSet]{
Count: 1,
NextOffset: nextOffset,
Items: []*domainsV2.RRSet{
{
UUID: incorrectIdForSearch,
UUID: incorrectIDForSearch,
Name: incorrectNameForSearch,
Type: domainsV2.RecordType(rrsetTypeForSearch),
},
},
})
mDnsClient.On("ListRRSets", ctx, mockedZoneID, opts1).Return(rrsetWithNextOffset, nil)
mDNSClient.On("ListRRSets", ctx, mockedZoneID, opts1).Return(rrsetWithNextOffset, nil)
rrsetsWithoutNextOffset := domainsV2.Listable[domainsV2.RRSet](domainsV2.List[domainsV2.RRSet]{
Count: 1,
NextOffset: 0,
Items: []*domainsV2.RRSet{
{
UUID: correctIdForSearch,
UUID: correctIDForSearch,
Name: rrsetNameForSearch,
Type: domainsV2.RecordType(rrsetTypeForSearch),
},
},
})
mDnsClient.On("ListRRSets", ctx, mockedZoneID, opts2).Return(rrsetsWithoutNextOffset, nil)
mDNSClient.On("ListRRSets", ctx, mockedZoneID, opts2).Return(rrsetsWithoutNextOffset, nil)

rrset, err := getRrsetByNameAndType(ctx, mDnsClient, mockedZoneID, rrsetNameForSearch, rrsetTypeForSearch)
rrset, err := getRrsetByNameAndType(ctx, mDNSClient, mockedZoneID, rrsetNameForSearch, rrsetTypeForSearch)

assert.NoError(t, err)

assert.NotNil(t, rrset)
assert.Equal(t, correctIdForSearch, rrset.UUID)
assert.Equal(t, correctIDForSearch, rrset.UUID)
assert.Equal(t, rrsetNameForSearch, rrset.Name)
assert.Equal(t, rrsetTypeForSearch, string(rrset.Type))
}
2 changes: 0 additions & 2 deletions selectel/import_selectel_domains_rrset_v2_test.go
Original file line number Diff line number Diff line change
@@ -16,8 +16,6 @@ func TestAccDomainsRrsetV2ImportBasic(t *testing.T) {
testRrsetType := domainsV2.TXT
testRrsetTTL := 60
testRrrsetContent := fmt.Sprintf("\"%[1]s\"", acctest.RandString(16))
resourceZoneName := "zone_tf_acc_test_1"
resourceRrsetName := "rrset_tf_acc_test_1"
fullResourceName := fmt.Sprintf("selectel_domains_rrset_v2.%[1]s", resourceRrsetName)
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccSelectelPreCheckWithProjectID(t) },
7 changes: 3 additions & 4 deletions selectel/import_selectel_domains_zone_v2_test.go
Original file line number Diff line number Diff line change
@@ -10,17 +10,15 @@ import (
)

func TestAccDomainsZoneV2ImportBasic(t *testing.T) {
resourceName := "zone_tf_acc_test_1"
fullResourceName := fmt.Sprintf("selectel_domains_zone_v2.%[1]s", resourceName)
fullResourceName := fmt.Sprintf("selectel_domains_zone_v2.%[1]s", resourceZoneName)
testZoneName := fmt.Sprintf("%s.xyz.", acctest.RandomWithPrefix("tf-acc"))

resource.Test(t, resource.TestCase{
PreCheck: func() { testAccSelectelPreCheckWithProjectID(t) },
ProviderFactories: testAccProviders,
CheckDestroy: testAccCheckDomainsV2ZoneDestroy,
Steps: []resource.TestStep{
{
Config: testAccDomainsZoneV2Basic(resourceName, testZoneName),
Config: testAccDomainsZoneV2Basic(resourceZoneName, testZoneName),
},
{
ResourceName: fullResourceName,
@@ -38,5 +36,6 @@ func getTestZoneIDForImport(s *terraform.State) (string, error) {
if !ok {
return "", fmt.Errorf("Not found zone: %s", resourceZoneFullName)
}

return resourceZone.Primary.Attributes["name"], nil
}