2018-02-18 17:27:58 +02:00
|
|
|
package lightsail
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/aws/aws-sdk-go/aws"
|
|
|
|
"github.com/aws/aws-sdk-go/aws/session"
|
|
|
|
"github.com/aws/aws-sdk-go/service/lightsail"
|
2018-06-11 17:32:50 +02:00
|
|
|
"github.com/stretchr/testify/require"
|
2018-02-18 17:27:58 +02:00
|
|
|
)
|
|
|
|
|
2018-10-12 19:29:18 +02:00
|
|
|
func TestLiveTTL(t *testing.T) {
|
2018-02-18 17:27:58 +02:00
|
|
|
m, err := testGetAndPreCheck()
|
|
|
|
if err != nil {
|
|
|
|
t.Skip(err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
provider, err := NewDNSProvider()
|
2018-06-11 17:32:50 +02:00
|
|
|
require.NoError(t, err)
|
2018-02-18 17:27:58 +02:00
|
|
|
|
2018-10-12 19:29:18 +02:00
|
|
|
domain := m["lightsailDomain"]
|
2018-09-24 21:07:20 +02:00
|
|
|
|
2018-10-12 19:29:18 +02:00
|
|
|
err = provider.Present(domain, "foo", "bar")
|
2018-06-11 17:32:50 +02:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2018-10-12 19:29:18 +02:00
|
|
|
// we need a separate Lightsail client here as the one in the DNS provider is
|
2018-02-18 17:27:58 +02:00
|
|
|
// unexported.
|
2018-10-12 19:29:18 +02:00
|
|
|
fqdn := "_acme-challenge." + domain
|
2018-07-01 02:24:20 +02:00
|
|
|
sess, err := session.NewSession()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
svc := lightsail.New(sess)
|
2018-09-24 21:07:20 +02:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
defer func() {
|
2018-10-12 19:29:18 +02:00
|
|
|
errC := provider.CleanUp(domain, "foo", "bar")
|
2018-09-24 21:07:20 +02:00
|
|
|
if errC != nil {
|
|
|
|
t.Log(errC)
|
|
|
|
}
|
|
|
|
}()
|
2018-06-11 17:32:50 +02:00
|
|
|
|
2018-02-18 17:27:58 +02:00
|
|
|
params := &lightsail.GetDomainInput{
|
2018-10-12 19:29:18 +02:00
|
|
|
DomainName: aws.String(domain),
|
2018-02-18 17:27:58 +02:00
|
|
|
}
|
2018-06-11 17:32:50 +02:00
|
|
|
|
2018-02-18 17:27:58 +02:00
|
|
|
resp, err := svc.GetDomain(params)
|
2018-09-24 21:07:20 +02:00
|
|
|
require.NoError(t, err)
|
2018-06-11 17:32:50 +02:00
|
|
|
|
2018-02-18 17:27:58 +02:00
|
|
|
entries := resp.Domain.DomainEntries
|
|
|
|
for _, entry := range entries {
|
|
|
|
if *entry.Type == "TXT" && *entry.Name == fqdn {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
2018-06-11 17:32:50 +02:00
|
|
|
|
2018-10-12 19:29:18 +02:00
|
|
|
t.Fatalf("Could not find a TXT record for _acme-challenge.%s", domain)
|
2018-02-18 17:27:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func testGetAndPreCheck() (map[string]string, error) {
|
|
|
|
m := map[string]string{
|
|
|
|
"lightsailKey": os.Getenv("AWS_ACCESS_KEY_ID"),
|
|
|
|
"lightsailSecret": os.Getenv("AWS_SECRET_ACCESS_KEY"),
|
|
|
|
"lightsailDomain": os.Getenv("DNS_ZONE"),
|
|
|
|
}
|
|
|
|
for _, v := range m {
|
|
|
|
if v == "" {
|
|
|
|
return nil, fmt.Errorf("AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY, and R53_DOMAIN are needed to run this test")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return m, nil
|
|
|
|
}
|