nginx-proxy-manager-zh/backend/internal/nginx/template_test.go

126 lines
2.7 KiB
Go
Raw Normal View History

2022-07-21 04:02:07 -04:00
package nginx
import (
"testing"
"npm/internal/entity/certificate"
"npm/internal/entity/host"
2023-07-23 23:42:50 -04:00
"npm/internal/model"
2023-07-28 01:01:54 -04:00
"npm/internal/test"
"npm/internal/types"
2022-07-21 04:02:07 -04:00
"github.com/stretchr/testify/assert"
2023-11-07 18:57:15 -05:00
"go.uber.org/goleak"
2022-07-21 04:02:07 -04:00
)
2023-07-28 01:01:54 -04:00
func TestRenderTemplate(t *testing.T) {
2023-11-07 18:57:15 -05:00
// goleak is used to detect goroutine leaks
defer goleak.VerifyNone(t, goleak.IgnoreAnyFunction("database/sql.(*DB).connectionOpener"))
2023-07-28 01:01:54 -04:00
test.InitConfig(t)
2022-07-21 04:02:07 -04:00
template := `
{{#if Host.IsDisabled}}
# Host is disabled
{{else}}
server {
{{#if Certificate.IsProvided}}
{{#if Certificate.IsAcme}}
include {{ConfDir}}/npm/conf.d/acme-challenge.conf;
include {{ConfDir}}/npm/conf.d/include/ssl-ciphers.conf;
2022-07-21 04:02:07 -04:00
{{/if}}
ssl_certificate {{Certificate.Folder}}/fullchain.pem;
ssl_certificate_key {{Certificate.Folder}}/privkey.pem;
2022-07-21 04:02:07 -04:00
{{/if}}
}
{{/if}}
`
type want struct {
output string
err error
}
tests := []struct {
name string
data TemplateData
host host.Model
cert certificate.Model
2022-07-21 04:02:07 -04:00
want want
}{
{
name: "Basic Template enabled",
host: host.Model{
IsDisabled: false,
},
cert: certificate.Model{
2023-07-23 23:42:50 -04:00
ModelBase: model.ModelBase{
ID: 77,
},
Status: certificate.StatusProvided,
Type: certificate.TypeHTTP,
CertificateAuthorityID: types.NullableDBUint{Uint: 99},
},
want: want{
2023-07-28 01:01:54 -04:00
output: `
server {
include /etc/nginx/conf.d/npm/conf.d/acme-challenge.conf;
include /etc/nginx/conf.d/npm/conf.d/include/ssl-ciphers.conf;
ssl_certificate /data/.acme.sh/certs/npm-77/fullchain.pem;
ssl_certificate_key /data/.acme.sh/certs/npm-77/privkey.pem;
}
`,
err: nil,
},
},
{
name: "Basic Template custom ssl",
host: host.Model{
IsDisabled: false,
},
cert: certificate.Model{
2023-07-23 23:42:50 -04:00
ModelBase: model.ModelBase{
ID: 66,
},
Status: certificate.StatusProvided,
Type: certificate.TypeCustom,
2022-07-21 04:02:07 -04:00
},
want: want{
2023-07-28 01:01:54 -04:00
output: `
server {
ssl_certificate /data/custom_ssl/npm-66/fullchain.pem;
ssl_certificate_key /data/custom_ssl/npm-66/privkey.pem;
}
`,
err: nil,
2022-07-21 04:02:07 -04:00
},
},
{
name: "Basic Template disabled",
host: host.Model{
IsDisabled: true,
2022-07-21 04:02:07 -04:00
},
cert: certificate.Model{},
2022-07-21 04:02:07 -04:00
want: want{
output: "\n # Host is disabled\n",
2022-07-21 04:02:07 -04:00
err: nil,
},
},
}
for _, test := range tests {
t.Run(test.name, func(st *testing.T) {
templateData := TemplateData{
ConfDir: "/etc/nginx/conf.d",
DataDir: "/data",
Host: test.host.GetTemplate(),
Certificate: test.cert.GetTemplate(),
}
2023-01-05 20:42:02 -05:00
output, err := renderTemplate(template, templateData)
2022-07-21 04:02:07 -04:00
assert.Equal(t, test.want.err, err)
assert.Equal(t, test.want.output, output)
})
}
}