// 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.EqualValues(t, "jane.doe@example.com", IncomingEmail.Username) assert.EqualValues(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.EqualValues(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.EqualValues(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.EqualValues(t, 1993, IncomingEmail.Port) }) }) }