mirror of
https://github.com/dnote/dnote
synced 2026-03-15 23:15:50 +01:00
199 lines
5.5 KiB
Go
199 lines
5.5 KiB
Go
/* Copyright (C) 2019, 2020, 2021, 2022, 2023 Monomax Software Pty Ltd
|
|
*
|
|
* This file is part of Dnote.
|
|
*
|
|
* Dnote is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Dnote is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with Dnote. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
package app
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/dnote/dnote/pkg/assert"
|
|
"github.com/dnote/dnote/pkg/server/config"
|
|
"github.com/dnote/dnote/pkg/server/testutils"
|
|
)
|
|
|
|
func TestSendVerificationEmail(t *testing.T) {
|
|
testCases := []struct {
|
|
onPremise bool
|
|
expectedSender string
|
|
}{
|
|
{
|
|
onPremise: false,
|
|
expectedSender: "admin@getdnote.com",
|
|
},
|
|
{
|
|
onPremise: true,
|
|
expectedSender: "noreply@example.com",
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(fmt.Sprintf("self hosted %t", tc.onPremise), func(t *testing.T) {
|
|
c := config.Load()
|
|
c.SetOnPremises(tc.onPremise)
|
|
c.WebURL = "http://example.com"
|
|
|
|
emailBackend := testutils.MockEmailbackendImplementation{}
|
|
a := NewTest(&App{
|
|
EmailBackend: &emailBackend,
|
|
Config: c,
|
|
})
|
|
|
|
if err := a.SendVerificationEmail("alice@example.com", "mockTokenValue"); err != nil {
|
|
t.Fatal(err, "failed to perform")
|
|
}
|
|
|
|
assert.Equalf(t, len(emailBackend.Emails), 1, "email queue count mismatch")
|
|
assert.Equal(t, emailBackend.Emails[0].From, tc.expectedSender, "email sender mismatch")
|
|
assert.DeepEqual(t, emailBackend.Emails[0].To, []string{"alice@example.com"}, "email sender mismatch")
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestSendWelcomeEmail(t *testing.T) {
|
|
testCases := []struct {
|
|
onPremise bool
|
|
expectedSender string
|
|
}{
|
|
{
|
|
onPremise: false,
|
|
expectedSender: "admin@getdnote.com",
|
|
},
|
|
{
|
|
onPremise: true,
|
|
expectedSender: "noreply@example.com",
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(fmt.Sprintf("self hosted %t", tc.onPremise), func(t *testing.T) {
|
|
c := config.Load()
|
|
c.SetOnPremises(tc.onPremise)
|
|
c.WebURL = "http://example.com"
|
|
|
|
emailBackend := testutils.MockEmailbackendImplementation{}
|
|
a := NewTest(&App{
|
|
EmailBackend: &emailBackend,
|
|
Config: c,
|
|
})
|
|
|
|
if err := a.SendWelcomeEmail("alice@example.com"); err != nil {
|
|
t.Fatal(err, "failed to perform")
|
|
}
|
|
|
|
assert.Equalf(t, len(emailBackend.Emails), 1, "email queue count mismatch")
|
|
assert.Equal(t, emailBackend.Emails[0].From, tc.expectedSender, "email sender mismatch")
|
|
assert.DeepEqual(t, emailBackend.Emails[0].To, []string{"alice@example.com"}, "email sender mismatch")
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestSendPasswordResetEmail(t *testing.T) {
|
|
testCases := []struct {
|
|
onPremise bool
|
|
expectedSender string
|
|
}{
|
|
{
|
|
onPremise: false,
|
|
expectedSender: "admin@getdnote.com",
|
|
},
|
|
{
|
|
onPremise: true,
|
|
expectedSender: "noreply@example.com",
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(fmt.Sprintf("self hosted %t", tc.onPremise), func(t *testing.T) {
|
|
c := config.Load()
|
|
c.SetOnPremises(tc.onPremise)
|
|
c.WebURL = "http://example.com"
|
|
|
|
emailBackend := testutils.MockEmailbackendImplementation{}
|
|
a := NewTest(&App{
|
|
EmailBackend: &emailBackend,
|
|
Config: c,
|
|
})
|
|
|
|
if err := a.SendPasswordResetEmail("alice@example.com", "mockTokenValue"); err != nil {
|
|
t.Fatal(err, "failed to perform")
|
|
}
|
|
|
|
assert.Equalf(t, len(emailBackend.Emails), 1, "email queue count mismatch")
|
|
assert.Equal(t, emailBackend.Emails[0].From, tc.expectedSender, "email sender mismatch")
|
|
assert.DeepEqual(t, emailBackend.Emails[0].To, []string{"alice@example.com"}, "email sender mismatch")
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestSendSubscriptionConfirmationEmail(t *testing.T) {
|
|
c := config.Load()
|
|
c.SetOnPremises(false)
|
|
c.WebURL = "http://example.com"
|
|
|
|
emailBackend := testutils.MockEmailbackendImplementation{}
|
|
a := NewTest(&App{
|
|
EmailBackend: &emailBackend,
|
|
Config: c,
|
|
})
|
|
|
|
if err := a.SendSubscriptionConfirmationEmail("alice@example.com"); err != nil {
|
|
t.Fatal(err, "failed to perform")
|
|
}
|
|
|
|
assert.Equalf(t, len(emailBackend.Emails), 1, "email queue count mismatch")
|
|
assert.Equal(t, emailBackend.Emails[0].From, "admin@getdnote.com", "email sender mismatch")
|
|
assert.DeepEqual(t, emailBackend.Emails[0].To, []string{"alice@example.com"}, "email sender mismatch")
|
|
}
|
|
|
|
func TestGetSenderEmail(t *testing.T) {
|
|
testCases := []struct {
|
|
onPremise bool
|
|
webURL string
|
|
candidate string
|
|
expectedSender string
|
|
}{
|
|
{
|
|
onPremise: true,
|
|
webURL: "https://www.example.com",
|
|
candidate: "alice@getdnote.com",
|
|
expectedSender: "noreply@example.com",
|
|
},
|
|
{
|
|
onPremise: false,
|
|
webURL: "https://www.getdnote.com",
|
|
candidate: "alice@getdnote.com",
|
|
expectedSender: "alice@getdnote.com",
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(fmt.Sprintf("on premise %t candidate %s", tc.onPremise, tc.candidate), func(t *testing.T) {
|
|
c := config.Load()
|
|
c.SetOnPremises(tc.onPremise)
|
|
c.WebURL = tc.webURL
|
|
|
|
got, err := GetSenderEmail(c, tc.candidate)
|
|
if err != nil {
|
|
t.Fatal(err, "failed to perform")
|
|
}
|
|
|
|
assert.Equal(t, got, tc.expectedSender, "result mismatch")
|
|
})
|
|
}
|
|
}
|