From 21b94765ce1b25cea4d8be44831ef5df96996342 Mon Sep 17 00:00:00 2001 From: Earl Warren Date: Sun, 9 Jun 2024 08:04:11 +0200 Subject: [PATCH] test(services/mailer): Add option for mailer to override mail headers Use MockVariableValue to avoid undesirable side effects between tests modifying global variables. TestToMessage relies on *setting.MailService being set, which will not be the case if run individually with test-sqlite#TestToMessage and fail. --- services/mailer/mailer_test.go | 20 +++++++++----------- 1 file changed, 9 insertions(+), 11 deletions(-) diff --git a/services/mailer/mailer_test.go b/services/mailer/mailer_test.go index 2f7da0869..b7b4c28a3 100644 --- a/services/mailer/mailer_test.go +++ b/services/mailer/mailer_test.go @@ -10,17 +10,16 @@ import ( repo_model "code.gitea.io/gitea/models/repo" "code.gitea.io/gitea/modules/setting" + "code.gitea.io/gitea/modules/test" "github.com/stretchr/testify/assert" ) func TestGenerateMessageID(t *testing.T) { - mailService := setting.Mailer{ + defer test.MockVariableValue(&setting.MailService, &setting.Mailer{ From: "test@gitea.com", - } - - setting.MailService = &mailService - setting.Domain = "localhost" + })() + defer test.MockVariableValue(&setting.Domain, "localhost")() date := time.Date(2000, 1, 2, 3, 4, 5, 6, time.UTC) m := NewMessageFrom("", "display-name", "from-address", "subject", "body") @@ -40,7 +39,7 @@ func TestGenerateMessageID(t *testing.T) { } func TestGenerateMessageIDForRelease(t *testing.T) { - setting.Domain = "localhost" + defer test.MockVariableValue(&setting.Domain, "localhost")() rel := repo_model.Release{ ID: 42, @@ -54,11 +53,10 @@ func TestGenerateMessageIDForRelease(t *testing.T) { } func TestToMessage(t *testing.T) { - oldConf := *setting.MailService - defer func() { - setting.MailService = &oldConf - }() - setting.MailService.From = "test@gitea.com" + defer test.MockVariableValue(&setting.MailService, &setting.Mailer{ + From: "test@gitea.com", + })() + defer test.MockVariableValue(&setting.Domain, "localhost")() m1 := Message{ Info: "info",