First server tests
This commit is contained in:
parent
ab3cc47e27
commit
94b70fbcb9
2 changed files with 66 additions and 12 deletions
2
Makefile
2
Makefile
|
@ -86,7 +86,7 @@ lint:
|
||||||
|
|
||||||
staticcheck: .PHONY
|
staticcheck: .PHONY
|
||||||
rm -rf build/staticcheck
|
rm -rf build/staticcheck
|
||||||
which staticcheck || go get honnef.co/go/tools/cmd/staticcheck
|
which staticcheck || go install honnef.co/go/tools/cmd/staticcheck@latest
|
||||||
mkdir -p build/staticcheck
|
mkdir -p build/staticcheck
|
||||||
ln -s "$(GO)" build/staticcheck/go
|
ln -s "$(GO)" build/staticcheck/go
|
||||||
PATH="$(PWD)/build/staticcheck:$(PATH)" staticcheck ./...
|
PATH="$(PWD)/build/staticcheck:$(PATH)" staticcheck ./...
|
||||||
|
|
|
@ -1,30 +1,59 @@
|
||||||
package server
|
package server
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bufio"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
"heckel.io/ntfy/config"
|
"heckel.io/ntfy/config"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestServer_Publish(t *testing.T) {
|
func TestServer_PublishAndPoll(t *testing.T) {
|
||||||
s := newTestServer(t, newTestConfig())
|
s := newTestServer(t, newTestConfig(t))
|
||||||
|
|
||||||
rr := httptest.NewRecorder()
|
response1 := request(t, s, "PUT", "/mytopic", "my first message")
|
||||||
req, _ := http.NewRequest("PUT", "/mytopic", strings.NewReader("my message"))
|
msg1 := toMessage(t, response1.Body.String())
|
||||||
s.handle(rr, req)
|
assert.NotEmpty(t, msg1.ID)
|
||||||
|
assert.Equal(t, "my first message", msg1.Message)
|
||||||
|
|
||||||
var m message
|
response2 := request(t, s, "PUT", "/mytopic", "my second message")
|
||||||
assert.Nil(t, json.NewDecoder(rr.Body).Decode(&m))
|
msg2 := toMessage(t, response2.Body.String())
|
||||||
assert.NotEmpty(t, m.ID)
|
assert.NotEqual(t, msg1.ID, msg2.ID)
|
||||||
assert.Equal(t, "my message", m.Message)
|
assert.NotEmpty(t, msg2.ID)
|
||||||
|
assert.Equal(t, "my second message", msg2.Message)
|
||||||
|
|
||||||
|
response := request(t, s, "GET", "/mytopic/json?poll=1", "")
|
||||||
|
messages := toMessages(t, response.Body.String())
|
||||||
|
assert.Equal(t, 2, len(messages))
|
||||||
}
|
}
|
||||||
|
|
||||||
func newTestConfig() *config.Config {
|
func TestServer_PublishAndSubscribe(t *testing.T) {
|
||||||
return config.New(":80")
|
s := newTestServer(t, newTestConfig(t))
|
||||||
|
|
||||||
|
response1 := request(t, s, "PUT", "/mytopic", "my first message")
|
||||||
|
msg1 := toMessage(t, response1.Body.String())
|
||||||
|
assert.NotEmpty(t, msg1.ID)
|
||||||
|
assert.Equal(t, "my first message", msg1.Message)
|
||||||
|
|
||||||
|
response2 := request(t, s, "PUT", "/mytopic", "my second message")
|
||||||
|
msg2 := toMessage(t, response2.Body.String())
|
||||||
|
assert.NotEqual(t, msg1.ID, msg2.ID)
|
||||||
|
assert.NotEmpty(t, msg2.ID)
|
||||||
|
assert.Equal(t, "my second message", msg2.Message)
|
||||||
|
|
||||||
|
response := request(t, s, "GET", "/mytopic/json?poll=1", "")
|
||||||
|
messages := toMessages(t, response.Body.String())
|
||||||
|
assert.Equal(t, 2, len(messages))
|
||||||
|
}
|
||||||
|
|
||||||
|
func newTestConfig(t *testing.T) *config.Config {
|
||||||
|
conf := config.New(":80")
|
||||||
|
conf.CacheFile = filepath.Join(t.TempDir(), "cache.db")
|
||||||
|
return conf
|
||||||
}
|
}
|
||||||
|
|
||||||
func newTestServer(t *testing.T, config *config.Config) *Server {
|
func newTestServer(t *testing.T, config *config.Config) *Server {
|
||||||
|
@ -34,3 +63,28 @@ func newTestServer(t *testing.T, config *config.Config) *Server {
|
||||||
}
|
}
|
||||||
return server
|
return server
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func request(t *testing.T, s *Server, method, url, body string) *httptest.ResponseRecorder {
|
||||||
|
rr := httptest.NewRecorder()
|
||||||
|
req, err := http.NewRequest(method, url, strings.NewReader(body))
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
s.handle(rr, req)
|
||||||
|
return rr
|
||||||
|
}
|
||||||
|
|
||||||
|
func toMessages(t *testing.T, s string) []*message {
|
||||||
|
messages := make([]*message, 0)
|
||||||
|
scanner := bufio.NewScanner(strings.NewReader(s))
|
||||||
|
for scanner.Scan() {
|
||||||
|
messages = append(messages, toMessage(t, scanner.Text()))
|
||||||
|
}
|
||||||
|
return messages
|
||||||
|
}
|
||||||
|
|
||||||
|
func toMessage(t *testing.T, s string) *message {
|
||||||
|
var m message
|
||||||
|
assert.Nil(t, json.NewDecoder(strings.NewReader(s)).Decode(&m))
|
||||||
|
return &m
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue