lego/providers/dns/vegadns/vegadns_test.go

289 lines
6.8 KiB
Go
Raw Normal View History

2019-03-11 16:56:48 +00:00
package vegadns
2018-06-30 23:45:24 +00:00
import (
"fmt"
"net/http"
"net/http/httptest"
"testing"
"time"
2020-09-02 01:20:01 +00:00
"github.com/go-acme/lego/v4/platform/tester"
2018-06-30 23:45:24 +00:00
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
const testDomain = "example.com"
var envTest = tester.NewEnvTest(EnvKey, EnvSecret, EnvURL)
func TestNewDNSProvider_Fail(t *testing.T) {
defer envTest.RestoreEnv()
envTest.ClearEnv()
2018-06-30 23:45:24 +00:00
_, err := NewDNSProvider()
assert.Error(t, err, "VEGADNS_URL env missing")
}
func TestDNSProvider_TimeoutSuccess(t *testing.T) {
defer envTest.RestoreEnv()
envTest.ClearEnv()
2019-06-24 16:34:04 +00:00
tearDown := startTestServer(muxSuccess())
defer tearDown()
2018-06-30 23:45:24 +00:00
provider, err := NewDNSProvider()
require.NoError(t, err)
timeout, interval := provider.Timeout()
2019-06-24 16:34:04 +00:00
assert.Equal(t, timeout, 12*time.Minute)
assert.Equal(t, interval, 1*time.Minute)
2018-06-30 23:45:24 +00:00
}
func TestDNSProvider_Present(t *testing.T) {
testCases := []struct {
desc string
2019-06-24 16:34:04 +00:00
handler http.Handler
expectedError string
}{
{
2019-06-24 16:34:04 +00:00
desc: "Success",
handler: muxSuccess(),
},
{
desc: "FailToFindZone",
2019-06-24 16:34:04 +00:00
handler: muxFailToFindZone(),
expectedError: "vegadns: can't find Authoritative Zone for _acme-challenge.example.com. in Present: Unable to find auth zone for fqdn _acme-challenge.example.com",
},
{
desc: "FailToCreateTXT",
2019-06-24 16:34:04 +00:00
handler: muxFailToCreateTXT(),
expectedError: "vegadns: Got bad answer from VegaDNS on CreateTXT. Code: 400. Message: ",
},
}
2018-06-30 23:45:24 +00:00
for _, test := range testCases {
t.Run(test.desc, func(t *testing.T) {
defer envTest.RestoreEnv()
envTest.ClearEnv()
2019-06-24 16:34:04 +00:00
tearDown := startTestServer(test.handler)
defer tearDown()
2018-06-30 23:45:24 +00:00
provider, err := NewDNSProvider()
require.NoError(t, err)
2018-06-30 23:45:24 +00:00
err = provider.Present(testDomain, "token", "keyAuth")
if len(test.expectedError) == 0 {
assert.NoError(t, err)
} else {
assert.EqualError(t, err, test.expectedError)
}
})
}
2018-06-30 23:45:24 +00:00
}
func TestDNSProvider_CleanUp(t *testing.T) {
testCases := []struct {
desc string
2019-06-24 16:34:04 +00:00
handler http.Handler
expectedError string
}{
{
2019-06-24 16:34:04 +00:00
desc: "Success",
handler: muxSuccess(),
},
{
desc: "FailToFindZone",
2019-06-24 16:34:04 +00:00
handler: muxFailToFindZone(),
expectedError: "vegadns: can't find Authoritative Zone for _acme-challenge.example.com. in CleanUp: Unable to find auth zone for fqdn _acme-challenge.example.com",
},
{
desc: "FailToGetRecordID",
2019-06-24 16:34:04 +00:00
handler: muxFailToGetRecordID(),
expectedError: "vegadns: couldn't get Record ID in CleanUp: Got bad answer from VegaDNS on GetRecordID. Code: 404. Message: ",
},
}
2018-06-30 23:45:24 +00:00
for _, test := range testCases {
t.Run(test.desc, func(t *testing.T) {
defer envTest.RestoreEnv()
envTest.ClearEnv()
2019-06-24 16:34:04 +00:00
tearDown := startTestServer(test.handler)
defer tearDown()
2018-06-30 23:45:24 +00:00
provider, err := NewDNSProvider()
require.NoError(t, err)
2018-06-30 23:45:24 +00:00
err = provider.CleanUp(testDomain, "token", "keyAuth")
if len(test.expectedError) == 0 {
assert.NoError(t, err)
} else {
assert.EqualError(t, err, test.expectedError)
}
})
}
2018-06-30 23:45:24 +00:00
}
func muxSuccess() *http.ServeMux {
2018-06-30 23:45:24 +00:00
mux := http.NewServeMux()
mux.HandleFunc("/1.0/token", func(w http.ResponseWriter, r *http.Request) {
if r.Method == http.MethodPost {
2018-06-30 23:45:24 +00:00
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, tokenResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusBadRequest)
})
mux.HandleFunc("/1.0/domains", func(w http.ResponseWriter, r *http.Request) {
if r.URL.Query().Get("search") == "example.com" {
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, domainsResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusNotFound)
})
mux.HandleFunc("/1.0/records", func(w http.ResponseWriter, r *http.Request) {
switch r.Method {
case http.MethodGet:
if r.URL.Query().Get("domain_id") == "1" {
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, recordsResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusNotFound)
return
case http.MethodPost:
w.WriteHeader(http.StatusCreated)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, recordCreatedResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusBadRequest)
})
mux.HandleFunc("/1.0/records/3", func(w http.ResponseWriter, r *http.Request) {
if r.Method == http.MethodDelete {
2018-06-30 23:45:24 +00:00
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, recordDeletedResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusBadRequest)
})
mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(http.StatusNotFound)
fmt.Printf("Not Found for Request: (%+v)\n\n", r)
})
return mux
}
func muxFailToFindZone() *http.ServeMux {
2018-06-30 23:45:24 +00:00
mux := http.NewServeMux()
mux.HandleFunc("/1.0/token", func(w http.ResponseWriter, r *http.Request) {
if r.Method == http.MethodPost {
2018-06-30 23:45:24 +00:00
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, tokenResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusBadRequest)
})
2019-02-06 17:15:53 +00:00
mux.HandleFunc("/1.0/domains", func(w http.ResponseWriter, _ *http.Request) {
2018-06-30 23:45:24 +00:00
w.WriteHeader(http.StatusNotFound)
})
return mux
}
func muxFailToCreateTXT() *http.ServeMux {
2018-06-30 23:45:24 +00:00
mux := http.NewServeMux()
mux.HandleFunc("/1.0/token", func(w http.ResponseWriter, r *http.Request) {
if r.Method == http.MethodPost {
2018-06-30 23:45:24 +00:00
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, tokenResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusBadRequest)
})
mux.HandleFunc("/1.0/domains", func(w http.ResponseWriter, r *http.Request) {
if r.URL.Query().Get("search") == testDomain {
2018-06-30 23:45:24 +00:00
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, domainsResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusNotFound)
})
mux.HandleFunc("/1.0/records", func(w http.ResponseWriter, r *http.Request) {
switch r.Method {
case http.MethodGet:
if r.URL.Query().Get("domain_id") == "1" {
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, recordsResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusNotFound)
return
case http.MethodPost:
w.WriteHeader(http.StatusBadRequest)
return
}
w.WriteHeader(http.StatusBadRequest)
})
return mux
}
func muxFailToGetRecordID() *http.ServeMux {
2018-06-30 23:45:24 +00:00
mux := http.NewServeMux()
mux.HandleFunc("/1.0/token", func(w http.ResponseWriter, r *http.Request) {
if r.Method == http.MethodPost {
2018-06-30 23:45:24 +00:00
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, tokenResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusBadRequest)
})
mux.HandleFunc("/1.0/domains", func(w http.ResponseWriter, r *http.Request) {
if r.URL.Query().Get("search") == testDomain {
2018-06-30 23:45:24 +00:00
w.WriteHeader(http.StatusOK)
2019-02-06 17:15:53 +00:00
fmt.Fprint(w, domainsResponseMock)
2018-06-30 23:45:24 +00:00
return
}
w.WriteHeader(http.StatusNotFound)
})
mux.HandleFunc("/1.0/records", func(w http.ResponseWriter, r *http.Request) {
if r.Method == http.MethodGet {
2018-06-30 23:45:24 +00:00
w.WriteHeader(http.StatusNotFound)
return
}
w.WriteHeader(http.StatusBadRequest)
})
return mux
}
2019-06-24 16:34:04 +00:00
func startTestServer(handler http.Handler) func() {
ts := httptest.NewServer(handler)
2018-06-30 23:45:24 +00:00
2019-06-24 16:34:04 +00:00
envTest.Apply(map[string]string{
EnvKey: "key",
EnvSecret: "secret",
EnvURL: ts.URL,
2019-06-24 16:34:04 +00:00
})
2018-06-30 23:45:24 +00:00
2019-06-24 16:34:04 +00:00
return func() {
ts.Close()
2018-06-30 23:45:24 +00:00
}
}