mirror of
https://github.com/StackExchange/dnscontrol.git
synced 2025-01-13 19:07:57 +08:00
50db086278
* New provider * Add support for SRV records * Modify ACTIVEDIRECTORY_PS provider to warn that it is deprecated.
169 lines
5.2 KiB
Go
169 lines
5.2 KiB
Go
package msdns
|
|
|
|
import (
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/StackExchange/dnscontrol/v3/models"
|
|
)
|
|
|
|
func Test_generatePSZoneAll(t *testing.T) {
|
|
type args struct {
|
|
dnsserver string
|
|
domain string
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
args args
|
|
want string
|
|
}{
|
|
{
|
|
name: "local",
|
|
args: args{},
|
|
want: `Get-DnsServerZone | ConvertTo-Json`,
|
|
},
|
|
{
|
|
name: "remote",
|
|
args: args{dnsserver: "mydnsserver"},
|
|
want: `Get-DnsServerZone -ComputerName "mydnsserver" | ConvertTo-Json`,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := generatePSZoneAll(tt.args.dnsserver); got != tt.want {
|
|
t.Errorf("generatePSZoneAll() = got=(\n%s\n) want=(\n%s\n)", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_generatePSZoneDump(t *testing.T) {
|
|
type args struct {
|
|
domainname string
|
|
dnsserver string
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
args args
|
|
want string
|
|
}{
|
|
{
|
|
name: "local",
|
|
args: args{domainname: "example.com"},
|
|
want: `Get-DnsServerResourceRecord -ZoneName "example.com" | ConvertTo-Json -depth 4 > mytemp.json`,
|
|
},
|
|
{
|
|
name: "remote",
|
|
args: args{domainname: "example.com", dnsserver: "mydnsserver"},
|
|
want: `Get-DnsServerResourceRecord -ComputerName "mydnsserver" -ZoneName "example.com" | ConvertTo-Json -depth 4 > mytemp.json`,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := generatePSZoneDump(tt.args.dnsserver, tt.args.domainname, "mytemp.json"); got != tt.want {
|
|
t.Errorf("generatePSZoneDump() = got=(\n%s\n) want=(\n%s\n)", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
//func Test_generatePSDelete(t *testing.T) {
|
|
// type args struct {
|
|
// domain string
|
|
// rec *models.RecordConfig
|
|
// }
|
|
// tests := []struct {
|
|
// name string
|
|
// args args
|
|
// want string
|
|
// }{
|
|
// // TODO: Add test cases.
|
|
// }
|
|
// for _, tt := range tests {
|
|
// t.Run(tt.name, func(t *testing.T) {
|
|
// if got := generatePSDelete(tt.args.domain, tt.args.rec); got != tt.want {
|
|
// t.Errorf("generatePSDelete() = %v, want %v", got, tt.want)
|
|
// }
|
|
// })
|
|
// }
|
|
//}
|
|
|
|
// func Test_generatePSCreate(t *testing.T) {
|
|
// type args struct {
|
|
// domain string
|
|
// rec *models.RecordConfig
|
|
// }
|
|
// tests := []struct {
|
|
// name string
|
|
// args args
|
|
// want string
|
|
// }{
|
|
// // TODO: Add test cases.
|
|
// }
|
|
// for _, tt := range tests {
|
|
// t.Run(tt.name, func(t *testing.T) {
|
|
// if got := generatePSCreate(tt.args.domain, tt.args.rec); got != tt.want {
|
|
// t.Errorf("generatePSCreate() = %v, want %v", got, tt.want)
|
|
// }
|
|
// })
|
|
// }
|
|
// }
|
|
|
|
func Test_generatePSModify(t *testing.T) {
|
|
|
|
recA1 := &models.RecordConfig{
|
|
Type: "A",
|
|
Name: "@",
|
|
Target: "1.2.3.4",
|
|
}
|
|
recA2 := &models.RecordConfig{
|
|
Type: "A",
|
|
Name: "@",
|
|
Target: "10.20.30.40",
|
|
}
|
|
|
|
recMX1 := &models.RecordConfig{
|
|
Type: "MX",
|
|
Name: "@",
|
|
Target: "foo.com.",
|
|
MxPreference: 5,
|
|
}
|
|
recMX2 := &models.RecordConfig{
|
|
Type: "MX",
|
|
Name: "@",
|
|
Target: "foo2.com.",
|
|
MxPreference: 50,
|
|
}
|
|
|
|
type args struct {
|
|
domain string
|
|
dnsserver string
|
|
old *models.RecordConfig
|
|
rec *models.RecordConfig
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
args args
|
|
want string
|
|
}{
|
|
{name: "A", args: args{domain: "example.com", dnsserver: "", old: recA1, rec: recA2},
|
|
want: `echo DELETE "A" "@" "1.2.3.4" ; Remove-DnsServerResourceRecord -Force -ZoneName "example.com" -Name "@" -RRType "A" -RecordData "1.2.3.4" ; echo CREATE "A" "@" "10.20.30.40" ; Add-DnsServerResourceRecord -ZoneName "example.com" -Name "@" -TimeToLive $(New-TimeSpan -Seconds 0) -A -IPv4Address "10.20.30.40"`,
|
|
},
|
|
{name: "MX1", args: args{domain: "example.com", dnsserver: "", old: recMX1, rec: recMX2},
|
|
want: `echo DELETE "MX" "@" "5 foo.com." ; Remove-DnsServerResourceRecord -Force -ZoneName "example.com" -Name "@" -RRType "MX" -RecordData 5,"foo.com." ; echo CREATE "MX" "@" "50 foo2.com." ; Add-DnsServerResourceRecord -ZoneName "example.com" -Name "@" -TimeToLive $(New-TimeSpan -Seconds 0) -MX -MailExchange "foo2.com." -Preference 50`,
|
|
},
|
|
{name: "A-remote", args: args{domain: "example.com", dnsserver: "myremote", old: recA1, rec: recA2},
|
|
want: `echo DELETE "A" "@" "1.2.3.4" ; Remove-DnsServerResourceRecord -ComputerName "myremote" -Force -ZoneName "example.com" -Name "@" -RRType "A" -RecordData "1.2.3.4" ; echo CREATE "A" "@" "10.20.30.40" ; Add-DnsServerResourceRecord -ComputerName "myremote" -ZoneName "example.com" -Name "@" -TimeToLive $(New-TimeSpan -Seconds 0) -A -IPv4Address "10.20.30.40"`,
|
|
},
|
|
{name: "MX1-remote", args: args{domain: "example.com", dnsserver: "yourremote", old: recMX1, rec: recMX2},
|
|
want: `echo DELETE "MX" "@" "5 foo.com." ; Remove-DnsServerResourceRecord -ComputerName "yourremote" -Force -ZoneName "example.com" -Name "@" -RRType "MX" -RecordData 5,"foo.com." ; echo CREATE "MX" "@" "50 foo2.com." ; Add-DnsServerResourceRecord -ComputerName "yourremote" -ZoneName "example.com" -Name "@" -TimeToLive $(New-TimeSpan -Seconds 0) -MX -MailExchange "foo2.com." -Preference 50`,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := generatePSModify(tt.args.dnsserver, tt.args.domain, tt.args.old, tt.args.rec); strings.TrimSpace(got) != strings.TrimSpace(tt.want) {
|
|
t.Errorf("generatePSModify() = got=(\n%s\n) want=(\n%s\n)", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|