Newer
Older
/*
* Copyright (C) 2023-2024
* Das Land Schleswig-Holstein vertreten durch den
* Ministerpräsidenten des Landes Schleswig-Holstein
* Staatskanzlei
* Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
*
* Lizenziert unter der EUPL, Version 1.2 oder - sobald
* diese von der Europäischen Kommission genehmigt wurden -
* Folgeversionen der EUPL ("Lizenz");
* Sie dürfen dieses Werk ausschließlich gemäß
* dieser Lizenz nutzen.
* Eine Kopie der Lizenz finden Sie hier:
*
* https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
*
* Sofern nicht durch anwendbare Rechtsvorschriften
* gefordert oder in schriftlicher Form vereinbart, wird
* die unter der Lizenz verbreitete Software "so wie sie
* ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
* ausdrücklich oder stillschweigend - verbreitet.
* Die sprachspezifischen Genehmigungen und Beschränkungen
* unter der Lizenz sind dem Lizenztext zu entnehmen.
*/
package server
import (
"antragsraum-proxy/internal/mock"
"github.com/stretchr/testify/assert"
"net/http"
"testing"
)
func TestRequestLoggingMiddleware(t *testing.T) {
logger := logrus.New()
logger.SetFormatter(&ecslogrus.Formatter{})
log.SetOutput(logger.Writer())
mock.SetUpGrpcServer()
SetUpGrpcRouter()
SetUpHttpGateway()
jsonData := []byte(`{"postfachId": "testPostfachId"}`)
req, _ := http.NewRequest("POST", "http://localhost:8082/api/v1/rueckfragen", bytes.NewBuffer(jsonData))
req.Header.Set(GrpcAddressHeader, "localhost")
var buf bytes.Buffer
log.SetOutput(&buf)
defer func() {
log.SetOutput(nil)
}()
client := &http.Client{}
client.Do(req)
logOutput := buf.String()
assert.Contains(t, "successfully handled POST request for /api/v1/rueckfragen with body: {\"postfachId\": \"testPostfachId\"}", logOutput)
})
t.Run("should not log request", func(t *testing.T) {
mock.SetUpGrpcServer()
SetUpHttpGateway()
var buf bytes.Buffer
}()
http.Get("http://localhost:8082/")
logOutput := buf.String()
assert.Empty(t, logOutput)
})