mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-04-19 13:39:26 +00:00
Some checks failed
/ release (push) Waiting to run
testing / backend-checks (push) Has been skipped
testing / frontend-checks (push) Has been skipped
testing / test-unit (push) Has been skipped
testing / test-e2e (push) Has been skipped
testing / test-mysql (push) Has been skipped
testing / test-pgsql (push) Has been skipped
testing / test-sqlite (push) Has been skipped
testing / test-remote-cacher (redis) (push) Has been skipped
testing / test-remote-cacher (valkey) (push) Has been skipped
testing / test-remote-cacher (garnet) (push) Has been skipped
testing / test-remote-cacher (redict) (push) Has been skipped
testing / security-check (push) Has been skipped
Integration tests for the release process / release-simulation (push) Has been cancelled
Co-authored-by: Renovate Bot <forgejo-renovate-action@forgejo.org> Co-committed-by: Renovate Bot <forgejo-renovate-action@forgejo.org>
74 lines
1.7 KiB
Go
74 lines
1.7 KiB
Go
// Copyright 2024 The Forgejo Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package setting
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func Test_loadIncomingEmailFrom(t *testing.T) {
|
|
makeBaseConfig := func() (ConfigProvider, ConfigSection) {
|
|
cfg, _ := NewConfigProviderFromData("")
|
|
sec := cfg.Section("email.incoming")
|
|
sec.NewKey("ENABLED", "true")
|
|
sec.NewKey("REPLY_TO_ADDRESS", "forge+%{token}@example.com")
|
|
|
|
return cfg, sec
|
|
}
|
|
resetIncomingEmailPort := func() func() {
|
|
return func() {
|
|
IncomingEmail.Port = 0
|
|
}
|
|
}
|
|
|
|
t.Run("aliases", func(t *testing.T) {
|
|
cfg, sec := makeBaseConfig()
|
|
sec.NewKey("USER", "jane.doe@example.com")
|
|
sec.NewKey("PASSWD", "y0u'll n3v3r gUess th1S!!1")
|
|
|
|
loadIncomingEmailFrom(cfg)
|
|
|
|
assert.Equal(t, "jane.doe@example.com", IncomingEmail.Username)
|
|
assert.Equal(t, "y0u'll n3v3r gUess th1S!!1", IncomingEmail.Password)
|
|
})
|
|
|
|
t.Run("Port settings", func(t *testing.T) {
|
|
t.Run("no port, no tls", func(t *testing.T) {
|
|
defer resetIncomingEmailPort()()
|
|
cfg, sec := makeBaseConfig()
|
|
|
|
// False is the default, but we test it explicitly.
|
|
sec.NewKey("USE_TLS", "false")
|
|
|
|
loadIncomingEmailFrom(cfg)
|
|
|
|
assert.Equal(t, 143, IncomingEmail.Port)
|
|
})
|
|
|
|
t.Run("no port, with tls", func(t *testing.T) {
|
|
defer resetIncomingEmailPort()()
|
|
cfg, sec := makeBaseConfig()
|
|
|
|
sec.NewKey("USE_TLS", "true")
|
|
|
|
loadIncomingEmailFrom(cfg)
|
|
|
|
assert.Equal(t, 993, IncomingEmail.Port)
|
|
})
|
|
|
|
t.Run("port overrides tls", func(t *testing.T) {
|
|
defer resetIncomingEmailPort()()
|
|
cfg, sec := makeBaseConfig()
|
|
|
|
sec.NewKey("PORT", "1993")
|
|
sec.NewKey("USE_TLS", "true")
|
|
|
|
loadIncomingEmailFrom(cfg)
|
|
|
|
assert.Equal(t, 1993, IncomingEmail.Port)
|
|
})
|
|
})
|
|
}
|