mirror of
https://github.com/yusing/godoxy.git
synced 2025-05-20 04:42:33 +02:00
91 lines
2.4 KiB
Go
91 lines
2.4 KiB
Go
package middleware
|
|
|
|
import (
|
|
_ "embed"
|
|
"net"
|
|
"net/http"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/yusing/go-proxy/internal/gperr"
|
|
"github.com/yusing/go-proxy/internal/utils"
|
|
expect "github.com/yusing/go-proxy/internal/utils/testing"
|
|
)
|
|
|
|
//go:embed test_data/cidr_whitelist_test.yml
|
|
var testCIDRWhitelistCompose []byte
|
|
var deny, accept *Middleware
|
|
|
|
func TestCIDRWhitelistValidation(t *testing.T) {
|
|
const testMessage = "test-message"
|
|
t.Run("valid", func(t *testing.T) {
|
|
_, err := CIDRWhiteList.New(OptionsRaw{
|
|
"allow": []string{"192.168.2.100/32"},
|
|
"message": testMessage,
|
|
})
|
|
expect.NoError(t, err)
|
|
_, err = CIDRWhiteList.New(OptionsRaw{
|
|
"allow": []string{"192.168.2.100/32"},
|
|
"message": testMessage,
|
|
"status": 403,
|
|
})
|
|
expect.NoError(t, err)
|
|
_, err = CIDRWhiteList.New(OptionsRaw{
|
|
"allow": []string{"192.168.2.100/32"},
|
|
"message": testMessage,
|
|
"status_code": 403,
|
|
})
|
|
expect.NoError(t, err)
|
|
})
|
|
t.Run("missing allow", func(t *testing.T) {
|
|
_, err := CIDRWhiteList.New(OptionsRaw{
|
|
"message": testMessage,
|
|
})
|
|
expect.ErrorIs(t, utils.ErrValidationError, err)
|
|
})
|
|
t.Run("invalid cidr", func(t *testing.T) {
|
|
_, err := CIDRWhiteList.New(OptionsRaw{
|
|
"allow": []string{"192.168.2.100/123"},
|
|
"message": testMessage,
|
|
})
|
|
expect.ErrorT[*net.ParseError](t, err)
|
|
})
|
|
t.Run("invalid status code", func(t *testing.T) {
|
|
_, err := CIDRWhiteList.New(OptionsRaw{
|
|
"allow": []string{"192.168.2.100/32"},
|
|
"status_code": 600,
|
|
"message": testMessage,
|
|
})
|
|
expect.ErrorIs(t, utils.ErrValidationError, err)
|
|
})
|
|
}
|
|
|
|
func TestCIDRWhitelist(t *testing.T) {
|
|
errs := gperr.NewBuilder("")
|
|
mids := BuildMiddlewaresFromYAML("", testCIDRWhitelistCompose, errs)
|
|
expect.NoError(t, errs.Error())
|
|
deny = mids["deny@file"]
|
|
accept = mids["accept@file"]
|
|
if deny == nil || accept == nil {
|
|
panic("bug occurred")
|
|
}
|
|
|
|
t.Run("deny", func(t *testing.T) {
|
|
t.Parallel()
|
|
for range 10 {
|
|
result, err := newMiddlewareTest(deny, nil)
|
|
expect.NoError(t, err)
|
|
expect.Equal(t, result.ResponseStatus, cidrWhitelistDefaults.StatusCode)
|
|
expect.Equal(t, strings.TrimSpace(string(result.Data)), cidrWhitelistDefaults.Message)
|
|
}
|
|
})
|
|
|
|
t.Run("accept", func(t *testing.T) {
|
|
t.Parallel()
|
|
for range 10 {
|
|
result, err := newMiddlewareTest(accept, nil)
|
|
expect.NoError(t, err)
|
|
expect.Equal(t, result.ResponseStatus, http.StatusOK)
|
|
}
|
|
})
|
|
}
|