test files

master
breel 2020-08-08 21:33:06 -06:00
parent f88ade0d73
commit a406287127
2 changed files with 129 additions and 2 deletions

View File

@ -33,7 +33,11 @@ func (rest *REST) filesCreate(w http.ResponseWriter, r *http.Request) {
rest.respConflict(w) rest.respConflict(w)
return return
} }
f, err := os.Open(localPath) if err := os.MkdirAll(path.Dir(localPath), os.ModePerm); err != nil {
rest.respError(w, err)
return
}
f, err := os.Create(localPath)
if err != nil { if err != nil {
rest.respError(w, err) rest.respError(w, err)
return return
@ -89,7 +93,7 @@ func (rest *REST) filesUpdate(w http.ResponseWriter, r *http.Request) {
rest.respConflict(w) rest.respConflict(w)
return return
} }
f, err := os.Open(localPath) f, err := os.Create(localPath + ".tmp")
if err != nil { if err != nil {
rest.respError(w, err) rest.respError(w, err)
return return
@ -97,6 +101,11 @@ func (rest *REST) filesUpdate(w http.ResponseWriter, r *http.Request) {
defer f.Close() defer f.Close()
if _, err := io.Copy(f, r.Body); err != nil { if _, err := io.Copy(f, r.Body); err != nil {
rest.respError(w, err) rest.respError(w, err)
return
}
if err := os.Rename(localPath+".tmp", localPath); err != nil {
rest.respError(w, err)
return
} }
rest.respOK(w) rest.respOK(w)
} }

118
server/files_test.go Normal file
View File

@ -0,0 +1,118 @@
package server
import (
"net/http"
"net/http/httptest"
"strings"
"testing"
"github.com/google/uuid"
)
func TestFiles(t *testing.T) {
cases := map[string]func(*testing.T, *REST, func(*http.Request)){
"create-get": func(t *testing.T, rest *REST, scope func(r *http.Request)) {
s := uuid.New().String()
w := testFilesPost(t, rest, s, scope, s)
if w.Code != http.StatusOK {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
w = testFilesGet(t, rest, s, scope)
if w.Code != http.StatusOK {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
if s2 := string(w.Body.Bytes()); s2 != s {
t.Fatalf("want %q, got %q", s, s2)
}
},
"create-collision": func(t *testing.T, rest *REST, scope func(r *http.Request)) {
s := uuid.New().String()
for i := 0; i < 2; i++ {
w := testFilesPost(t, rest, s, scope, s)
ok := false
switch i {
case 0:
ok = w.Code == http.StatusOK
default:
ok = w.Code == http.StatusConflict
}
if !ok {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
}
},
"delete": func(t *testing.T, rest *REST, scope func(r *http.Request)) {
s := uuid.New().String()
w := testFilesPost(t, rest, s, scope, s)
if w.Code != http.StatusOK {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
w = testFilesDelete(t, rest, s, scope)
if w.Code != http.StatusOK {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
w = testFilesGet(t, rest, s, scope)
if w.Code != http.StatusNotFound {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
},
"404": func(t *testing.T, rest *REST, scope func(r *http.Request)) {
s := uuid.New().String()
w := testFilesGet(t, rest, s, scope)
if w.Code != http.StatusNotFound {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
},
"update": func(t *testing.T, rest *REST, scope func(r *http.Request)) {
s := uuid.New().String()
w := testFilesPost(t, rest, s, scope, s)
if w.Code != http.StatusOK {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
w = testFilesPut(t, rest, s, scope, s+"new")
if w.Code != http.StatusOK {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
w = testFilesGet(t, rest, s, scope)
if w.Code != http.StatusOK {
t.Fatal(w.Code, string(w.Body.Bytes()))
}
if v := string(w.Body.Bytes()); v != s+"new" {
t.Fatal(v)
}
},
}
for name, foo := range cases {
bar := foo
t.Run(name, func(t *testing.T) {
rest, scope, clean := testREST(t)
bar(t, rest, scope)
defer clean()
})
}
}
func testFilesDelete(t *testing.T, rest *REST, id string, scope func(*http.Request)) *httptest.ResponseRecorder {
return testFilesReq(t, rest, id, scope, http.MethodDelete, "")
}
func testFilesGet(t *testing.T, rest *REST, id string, scope func(*http.Request)) *httptest.ResponseRecorder {
return testFilesReq(t, rest, id, scope, http.MethodGet, "")
}
func testFilesPut(t *testing.T, rest *REST, id string, scope func(*http.Request), body string) *httptest.ResponseRecorder {
return testFilesReq(t, rest, id, scope, http.MethodPut, body)
}
func testFilesPost(t *testing.T, rest *REST, id string, scope func(*http.Request), body string) *httptest.ResponseRecorder {
return testFilesReq(t, rest, id, scope, http.MethodPost, body)
}
func testFilesReq(t *testing.T, rest *REST, id string, scope func(*http.Request), method, body string) *httptest.ResponseRecorder {
r := httptest.NewRequest(method, "/"+id, strings.NewReader(body))
scope(r)
w := httptest.NewRecorder()
rest.files(w, r)
return w
}