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"
|
2023-05-30 08:26:44 -04:00
|
|
|
"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 {
|
2022-11-07 19:03:45 -05:00
|
|
|
{{#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}}
|
2022-11-07 19:03:45 -05:00
|
|
|
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
|
2022-11-07 19:03:45 -05:00
|
|
|
host host.Model
|
|
|
|
cert certificate.Model
|
2022-07-21 04:02:07 -04:00
|
|
|
want want
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "Basic Template enabled",
|
2022-11-07 19:03:45 -05:00
|
|
|
host: host.Model{
|
|
|
|
IsDisabled: false,
|
|
|
|
},
|
|
|
|
cert: certificate.Model{
|
2023-07-23 23:42:50 -04:00
|
|
|
ModelBase: model.ModelBase{
|
2023-05-25 21:04:43 -04:00
|
|
|
ID: 77,
|
|
|
|
},
|
2022-11-07 19:03:45 -05:00
|
|
|
Status: certificate.StatusProvided,
|
|
|
|
Type: certificate.TypeHTTP,
|
2023-05-30 08:26:44 -04:00
|
|
|
CertificateAuthorityID: types.NullableDBUint{Uint: 99},
|
2022-11-07 19:03:45 -05:00
|
|
|
},
|
|
|
|
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,
|
2022-11-07 19:03:45 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Basic Template custom ssl",
|
|
|
|
host: host.Model{
|
|
|
|
IsDisabled: false,
|
|
|
|
},
|
|
|
|
cert: certificate.Model{
|
2023-07-23 23:42:50 -04:00
|
|
|
ModelBase: model.ModelBase{
|
2023-05-25 21:04:43 -04:00
|
|
|
ID: 66,
|
|
|
|
},
|
2022-11-07 19:03:45 -05:00
|
|
|
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",
|
2022-11-07 19:03:45 -05:00
|
|
|
host: host.Model{
|
|
|
|
IsDisabled: true,
|
2022-07-21 04:02:07 -04:00
|
|
|
},
|
2022-11-07 19:03:45 -05:00
|
|
|
cert: certificate.Model{},
|
2022-07-21 04:02:07 -04:00
|
|
|
want: want{
|
2022-11-07 19:03:45 -05:00
|
|
|
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) {
|
2022-11-07 19:03:45 -05:00
|
|
|
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)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|