1
0
mirror of https://github.com/go-acme/lego.git synced 2025-01-10 18:53:06 +02:00
lego/providers/dns/domeneshop/internal/client_test.go

196 lines
4.5 KiB
Go
Raw Normal View History

2021-02-08 21:13:21 +02:00
package internal
import (
2023-05-05 09:49:38 +02:00
"context"
2021-02-08 21:13:21 +02:00
"net/http"
"net/http/httptest"
2023-05-05 09:49:38 +02:00
"net/url"
2021-02-08 21:13:21 +02:00
"testing"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
2023-05-05 09:49:38 +02:00
const authorizationHeader = "Authorization"
func setupTest(t *testing.T) (*Client, *http.ServeMux) {
2021-02-08 21:13:21 +02:00
t.Helper()
mux := http.NewServeMux()
server := httptest.NewServer(mux)
t.Cleanup(server.Close)
client := NewClient("token", "secret")
2023-05-05 09:49:38 +02:00
client.HTTPClient = server.Client()
client.baseURL, _ = url.Parse(server.URL)
2021-02-08 21:13:21 +02:00
return client, mux
}
func TestClient_CreateTXTRecord(t *testing.T) {
2023-05-05 09:49:38 +02:00
client, mux := setupTest(t)
2021-02-08 21:13:21 +02:00
mux.HandleFunc("/domains/1/dns", func(rw http.ResponseWriter, req *http.Request) {
if req.Method != http.MethodPost {
http.Error(rw, "invalid method: "+req.Method, http.StatusBadRequest)
return
}
2023-05-05 09:49:38 +02:00
auth := req.Header.Get(authorizationHeader)
2021-02-08 21:13:21 +02:00
if auth != "Basic dG9rZW46c2VjcmV0" {
2023-05-05 09:49:38 +02:00
http.Error(rw, "invalid credentials: "+auth, http.StatusUnauthorized)
2021-11-03 21:39:12 +02:00
return
2021-02-08 21:13:21 +02:00
}
_, _ = rw.Write([]byte(`{"id": 1}`))
})
2023-05-05 09:49:38 +02:00
err := client.CreateTXTRecord(context.Background(), &Domain{ID: 1}, "example", "txtTXTtxt")
2021-02-08 21:13:21 +02:00
require.NoError(t, err)
}
func TestClient_DeleteTXTRecord(t *testing.T) {
2023-05-05 09:49:38 +02:00
client, mux := setupTest(t)
2021-02-08 21:13:21 +02:00
mux.HandleFunc("/domains/1/dns", func(rw http.ResponseWriter, req *http.Request) {
if req.Method != http.MethodGet {
http.Error(rw, "invalid method: "+req.Method, http.StatusBadRequest)
return
}
2023-05-05 09:49:38 +02:00
auth := req.Header.Get(authorizationHeader)
2021-02-08 21:13:21 +02:00
if auth != "Basic dG9rZW46c2VjcmV0" {
2023-05-05 09:49:38 +02:00
http.Error(rw, "invalid credentials: "+auth, http.StatusUnauthorized)
2021-11-03 21:39:12 +02:00
return
2021-02-08 21:13:21 +02:00
}
_, _ = rw.Write([]byte(`[
{
"id": 1,
"host": "example.com",
"ttl": 3600,
"type": "TXT",
"data": "txtTXTtxt"
}
]`))
})
mux.HandleFunc("/domains/1/dns/1", func(rw http.ResponseWriter, req *http.Request) {
if req.Method != http.MethodDelete {
http.Error(rw, "invalid method: "+req.Method, http.StatusBadRequest)
return
}
2023-05-05 09:49:38 +02:00
auth := req.Header.Get(authorizationHeader)
2021-02-08 21:13:21 +02:00
if auth != "Basic dG9rZW46c2VjcmV0" {
2023-05-05 09:49:38 +02:00
http.Error(rw, "invalid credentials: "+auth, http.StatusUnauthorized)
2021-11-03 21:39:12 +02:00
return
2021-02-08 21:13:21 +02:00
}
})
2023-05-05 09:49:38 +02:00
err := client.DeleteTXTRecord(context.Background(), &Domain{ID: 1}, "example.com", "txtTXTtxt")
2021-02-08 21:13:21 +02:00
require.NoError(t, err)
}
func TestClient_getDNSRecordByHostData(t *testing.T) {
2023-05-05 09:49:38 +02:00
client, mux := setupTest(t)
2021-02-08 21:13:21 +02:00
mux.HandleFunc("/domains/1/dns", func(rw http.ResponseWriter, req *http.Request) {
if req.Method != http.MethodGet {
http.Error(rw, "invalid method: "+req.Method, http.StatusBadRequest)
return
}
2023-05-05 09:49:38 +02:00
auth := req.Header.Get(authorizationHeader)
2021-02-08 21:13:21 +02:00
if auth != "Basic dG9rZW46c2VjcmV0" {
2023-05-05 09:49:38 +02:00
http.Error(rw, "invalid credentials: "+auth, http.StatusUnauthorized)
2021-11-03 21:39:12 +02:00
return
2021-02-08 21:13:21 +02:00
}
_, _ = rw.Write([]byte(`[
{
"id": 1,
"host": "example.com",
"ttl": 3600,
"type": "TXT",
"data": "txtTXTtxt"
}
]`))
})
2023-05-05 09:49:38 +02:00
record, err := client.getDNSRecordByHostData(context.Background(), Domain{ID: 1}, "example.com", "txtTXTtxt")
2021-02-08 21:13:21 +02:00
require.NoError(t, err)
expected := &DNSRecord{
ID: 1,
Type: "TXT",
Host: "example.com",
Data: "txtTXTtxt",
TTL: 3600,
}
assert.Equal(t, expected, record)
}
func TestClient_GetDomainByName(t *testing.T) {
2023-05-05 09:49:38 +02:00
client, mux := setupTest(t)
2021-02-08 21:13:21 +02:00
mux.HandleFunc("/domains", func(rw http.ResponseWriter, req *http.Request) {
if req.Method != http.MethodGet {
http.Error(rw, "invalid method: "+req.Method, http.StatusBadRequest)
return
}
2023-05-05 09:49:38 +02:00
auth := req.Header.Get(authorizationHeader)
2021-02-08 21:13:21 +02:00
if auth != "Basic dG9rZW46c2VjcmV0" {
2023-05-05 09:49:38 +02:00
http.Error(rw, "invalid credentials: "+auth, http.StatusUnauthorized)
2021-11-03 21:39:12 +02:00
return
2021-02-08 21:13:21 +02:00
}
_, _ = rw.Write([]byte(`[
{
"id": 1,
"domain": "example.com",
"expiry_date": "2019-08-24",
"registered_date": "2019-08-24",
"renew": true,
"registrant": "Ola Nordmann",
"status": "active",
"nameservers": [
"ns1.hyp.net",
"ns2.hyp.net",
"ns3.hyp.net"
],
"services": {
"registrar": true,
"dns": true,
"email": true,
"webhotel": "none"
}
}
]`))
})
2023-05-05 09:49:38 +02:00
domain, err := client.GetDomainByName(context.Background(), "example.com")
2021-02-08 21:13:21 +02:00
require.NoError(t, err)
expected := &Domain{
Name: "example.com",
ID: 1,
ExpiryDate: "2019-08-24",
Nameservers: []string{"ns1.hyp.net", "ns2.hyp.net", "ns3.hyp.net"},
RegisteredDate: "2019-08-24",
Registrant: "Ola Nordmann",
Renew: true,
Services: Service{
DNS: true,
Email: true,
Registrar: true,
Webhotel: "none",
},
Status: "active",
}
assert.Equal(t, expected, domain)
}