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
|
|
|
}
|