-
Notifications
You must be signed in to change notification settings - Fork 149
/
Copy pathxsclogerrorevent_test.go
60 lines (50 loc) · 1.86 KB
/
xsclogerrorevent_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
package tests
import (
"encoding/json"
"github.com/jfrog/jfrog-client-go/http/jfroghttpclient"
"github.com/jfrog/jfrog-client-go/xsc/services"
"github.com/jfrog/jfrog-client-go/xsc/services/utils"
"github.com/stretchr/testify/assert"
"net/http"
"net/http/httptest"
"testing"
)
const errorMessageContentForTest = "THIS IS NOT A REAL ERROR! This Error is posted as part of TestXscSendLogErrorEvent test"
func TestXscSendLogErrorEvent(t *testing.T) {
initXscTest(t, services.LogErrorMinXscVersion, utils.MinXrayVersionXscTransitionToXray)
mockServer, logErrorService := createXscMockServerForLogEvent(t)
defer mockServer.Close()
event := &services.ExternalErrorLog{
Log_level: "error",
Source: "cli",
Message: errorMessageContentForTest,
}
assert.NoError(t, logErrorService.SendLogErrorEvent(event))
}
func createXscMockServerForLogEvent(t *testing.T) (mockServer *httptest.Server, logErrorService *services.LogErrorEventService) {
mockServer = httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
if r.RequestURI == "/xray/api/v1/xsc/event/logMessage" && r.Method == http.MethodPost {
var reqBody services.ExternalErrorLog
decoder := json.NewDecoder(r.Body)
err := decoder.Decode(&reqBody)
assert.NoError(t, err, "Invalid JSON request body")
if err != nil {
return
}
assert.Equal(t, "error", reqBody.Log_level)
assert.Equal(t, "cli", reqBody.Source)
assert.Equal(t, errorMessageContentForTest, reqBody.Message)
w.WriteHeader(http.StatusCreated)
return
} else {
assert.Fail(t, "received an unexpected request")
}
}))
xrayDetails := GetXrayDetails()
xrayDetails.SetUrl(mockServer.URL + "/xray")
client, err := jfroghttpclient.JfrogClientBuilder().Build()
assert.NoError(t, err)
logErrorService = services.NewLogErrorEventService(client)
logErrorService.XrayDetails = xrayDetails
return
}