2022-01-20 16:52:37 +05:30
|
|
|
package test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2022-05-31 08:14:03 +05:30
|
|
|
"strings"
|
2022-01-20 16:52:37 +05:30
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/authorizerdev/authorizer/server/constants"
|
2022-02-28 21:26:49 +05:30
|
|
|
"github.com/authorizerdev/authorizer/server/crypto"
|
2022-01-20 16:52:37 +05:30
|
|
|
"github.com/authorizerdev/authorizer/server/graph/model"
|
2022-05-30 09:19:55 +05:30
|
|
|
"github.com/authorizerdev/authorizer/server/memorystore"
|
2022-01-20 16:52:37 +05:30
|
|
|
"github.com/authorizerdev/authorizer/server/resolvers"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func updateEnvTests(t *testing.T, s TestSetup) {
|
|
|
|
t.Helper()
|
|
|
|
t.Run(`should update envs`, func(t *testing.T) {
|
|
|
|
req, ctx := createContext(s)
|
2022-05-30 12:47:50 +05:30
|
|
|
originalAppURL, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeyAppURL)
|
|
|
|
assert.Nil(t, err)
|
2022-01-20 16:52:37 +05:30
|
|
|
|
|
|
|
data := model.UpdateEnvInput{}
|
2022-05-30 12:47:50 +05:30
|
|
|
_, err = resolvers.UpdateEnvResolver(ctx, data)
|
2022-01-21 13:34:04 +05:30
|
|
|
|
2022-01-20 16:52:37 +05:30
|
|
|
assert.NotNil(t, err)
|
|
|
|
|
2022-05-30 12:47:50 +05:30
|
|
|
adminSecret, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeyAdminSecret)
|
2022-01-20 16:52:37 +05:30
|
|
|
assert.Nil(t, err)
|
2022-05-30 12:47:50 +05:30
|
|
|
h, err := crypto.EncryptPassword(adminSecret)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
req.Header.Set("Cookie", fmt.Sprintf("%s=%s", constants.AdminCookieName, h))
|
2022-01-20 16:52:37 +05:30
|
|
|
newURL := "https://test.com"
|
|
|
|
disableLoginPage := true
|
|
|
|
allowedOrigins := []string{"http://localhost:8080"}
|
|
|
|
data = model.UpdateEnvInput{
|
|
|
|
AppURL: &newURL,
|
|
|
|
DisableLoginPage: &disableLoginPage,
|
|
|
|
AllowedOrigins: allowedOrigins,
|
|
|
|
}
|
|
|
|
_, err = resolvers.UpdateEnvResolver(ctx, data)
|
2022-05-30 12:47:50 +05:30
|
|
|
assert.Nil(t, err)
|
|
|
|
|
|
|
|
appURL, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeyAppURL)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.Equal(t, appURL, newURL)
|
|
|
|
|
|
|
|
isLoginPageDisabled, err := memorystore.Provider.GetBoolStoreEnvVariable(constants.EnvKeyDisableLoginPage)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.True(t, isLoginPageDisabled)
|
2022-01-20 16:52:37 +05:30
|
|
|
|
2022-05-31 08:14:03 +05:30
|
|
|
storedOriginsStrings, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeyAllowedOrigins)
|
2022-01-20 16:52:37 +05:30
|
|
|
assert.Nil(t, err)
|
2022-05-31 08:14:03 +05:30
|
|
|
storedOrigins := strings.Split(storedOriginsStrings, ",")
|
2022-05-30 12:47:50 +05:30
|
|
|
assert.Equal(t, storedOrigins, allowedOrigins)
|
2022-01-20 16:52:37 +05:30
|
|
|
|
|
|
|
disableLoginPage = false
|
|
|
|
data = model.UpdateEnvInput{
|
|
|
|
AppURL: &originalAppURL,
|
|
|
|
DisableLoginPage: &disableLoginPage,
|
|
|
|
AllowedOrigins: []string{"*"},
|
|
|
|
}
|
|
|
|
_, err = resolvers.UpdateEnvResolver(ctx, data)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
})
|
|
|
|
}
|