authorizer/server/test/webhook_logs_test.go

50 lines
1.6 KiB
Go
Raw Permalink Normal View History

2022-07-11 05:12:42 +00:00
package test
2022-07-11 14:10:54 +00:00
import (
"fmt"
"testing"
"time"
2022-07-11 14:10:54 +00:00
"github.com/authorizerdev/authorizer/server/constants"
"github.com/authorizerdev/authorizer/server/crypto"
"github.com/authorizerdev/authorizer/server/graph/model"
"github.com/authorizerdev/authorizer/server/memorystore"
2022-07-15 16:41:08 +00:00
"github.com/authorizerdev/authorizer/server/refs"
2022-07-11 14:10:54 +00:00
"github.com/authorizerdev/authorizer/server/resolvers"
"github.com/stretchr/testify/assert"
)
func webhookLogsTest(t *testing.T, s TestSetup) {
time.Sleep(30 * time.Second) // add sleep for webhooklogs to get generated as they are async
2022-07-11 14:10:54 +00:00
t.Helper()
t.Run("should get webhook logs", func(t *testing.T) {
req, ctx := createContext(s)
adminSecret, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeyAdminSecret)
assert.NoError(t, err)
h, err := crypto.EncryptPassword(adminSecret)
assert.NoError(t, err)
req.Header.Set("Cookie", fmt.Sprintf("%s=%s", constants.AdminCookieName, h))
webhookLogs, err := resolvers.WebhookLogsResolver(ctx, nil)
2022-07-11 14:10:54 +00:00
assert.NoError(t, err)
assert.Greater(t, len(webhookLogs.WebhookLogs), 1)
webhooks, err := resolvers.WebhooksResolver(ctx, nil)
assert.NoError(t, err)
assert.NotEmpty(t, webhooks)
2022-07-11 14:10:54 +00:00
for _, w := range webhooks.Webhooks {
t.Run(fmt.Sprintf("should get webhook for webhook_id:%s", w.ID), func(t *testing.T) {
webhookLogs, err := resolvers.WebhookLogsResolver(ctx, &model.ListWebhookLogRequest{
WebhookID: &w.ID,
})
assert.NoError(t, err)
assert.GreaterOrEqual(t, len(webhookLogs.WebhookLogs), 1)
for _, wl := range webhookLogs.WebhookLogs {
2022-07-15 16:41:08 +00:00
assert.Equal(t, refs.StringValue(wl.WebhookID), w.ID)
}
2022-07-11 14:10:54 +00:00
})
}
})
}