From 6370bb773938bc2b8340d8659f96227eb95dd371 Mon Sep 17 00:00:00 2001 From: mark wu Date: Thu, 14 Dec 2023 16:30:20 +0800 Subject: [PATCH] Add test for verify dns server failure --- internal/cron/verify_domain_ownership_test.go | 34 +++++++++++++++++++ 1 file changed, 34 insertions(+) diff --git a/internal/cron/verify_domain_ownership_test.go b/internal/cron/verify_domain_ownership_test.go index 2dc419d..b986cd0 100644 --- a/internal/cron/verify_domain_ownership_test.go +++ b/internal/cron/verify_domain_ownership_test.go @@ -185,6 +185,40 @@ func TestVerifyDomainOwnership(t *testing.T) { } }) }) + t.Run("Should ignore domain verification when DNS Server connection error", func(t *testing.T) { + testutil.WithTestDB(func(database db.DB) { + + setupDB(now, ctx, database) + domainVerification, err := database.GetDomainVerificationByName(ctx, "test.com", "test") + if assert.NoError(t, err) { + assert.Nil(t, domainVerification.VerifiedAt) + } + db.WithTx(ctx, database, func(tx db.Tx) error { + return tx.CreateDomain(ctx, models.NewDomain( + now, + "test.com", + "test", + "main", + )) + }) + r := RaiseErrorDNSResolver{ + err: net.DNSError{}, + } + job := cron.VerifyDomainOwnership{ + DB: database, + Resolver: &r, + MaxConsumeActiveDomainCount: 1, + MaxConsumePendingDomainCount: 1, + RevalidatePeriod: time.Hour, + } + job.Run(ctx, logger) + domain, err := database.GetDomainByName(ctx, "test.com") + if assert.NoError(t, err) { + assert.Equal(t, "test.com", domain.Domain) + assert.Equal(t, "test", domain.AppID) + } + }) + }) t.Run("Should replace the conflict domain", func(t *testing.T) { testutil.WithTestDB(func(database db.DB) { data := setupDB(now, ctx, database)