Files
home-automation/src/components/homeassistant/homeassistant_test.go
T

47 lines
1.1 KiB
Go
Raw Normal View History

2024-10-18 17:14:10 +02:00
package homeassistant
import (
2024-10-22 14:09:51 +02:00
"bytes"
"log/slog"
2024-10-18 17:14:10 +02:00
"net/http"
"net/http/httptest"
"strings"
"testing"
2024-10-22 14:09:51 +02:00
"github.com/spf13/viper"
"github.com/stretchr/testify/assert"
2024-10-18 17:14:10 +02:00
)
2024-10-22 14:09:51 +02:00
var (
loggerText = new(bytes.Buffer)
)
2024-10-18 17:14:10 +02:00
2024-10-22 14:09:51 +02:00
func LoggerSetupTeardown(t *testing.T) func() {
logger := slog.New(slog.NewTextHandler(loggerText, nil))
defaultLogger := slog.Default()
slog.SetDefault(logger)
2024-10-18 17:14:10 +02:00
2024-10-22 14:09:51 +02:00
return func() {
slog.SetDefault(defaultLogger)
loggerText.Reset()
2024-10-18 17:14:10 +02:00
}
}
2024-10-22 14:09:51 +02:00
func TestHandlePooRecorderMsgGetLatest(t *testing.T) {
teardown := LoggerSetupTeardown(t)
defer teardown()
requestBody := `{"target": "poo_recorder", "action": "get_latest", "content": ""}`
2024-10-18 17:14:10 +02:00
req := httptest.NewRequest(http.MethodPost, "/homeassistant/publish", strings.NewReader(requestBody))
w := httptest.NewRecorder()
2024-10-22 14:09:51 +02:00
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
assert.Equal(t, "/poo/latest", r.URL.Path)
}))
defer server.Close()
port := strings.Split(server.URL, ":")[2]
viper.Set("port", port)
HandleHaMessage(w, req)
assert.Equal(t, http.StatusOK, w.Code)
assert.Empty(t, loggerText.String())
2024-10-18 17:14:10 +02:00
}