Genera: api.
This commit is contained in:
parent
533adbdd09
commit
59a0cfd4bf
4 changed files with 160 additions and 3 deletions
61
api/genera.go
Normal file
61
api/genera.go
Normal file
|
@ -0,0 +1,61 @@
|
|||
package api
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"strconv"
|
||||
|
||||
"github.com/gorilla/mux"
|
||||
|
||||
"net/http"
|
||||
|
||||
"github.com/thermokarst/bactdb/models"
|
||||
)
|
||||
|
||||
func serveGenus(w http.ResponseWriter, r *http.Request) error {
|
||||
id, err := strconv.ParseInt(mux.Vars(r)["Id"], 10, 0)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
genus, err := store.Genera.Get(id)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return writeJSON(w, genus)
|
||||
}
|
||||
|
||||
func serveCreateGenus(w http.ResponseWriter, r *http.Request) error {
|
||||
var genus models.Genus
|
||||
err := json.NewDecoder(r.Body).Decode(&genus)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
created, err := store.Genera.Create(&genus)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if created {
|
||||
w.WriteHeader(http.StatusCreated)
|
||||
}
|
||||
|
||||
return writeJSON(w, genus)
|
||||
}
|
||||
|
||||
func serveGenera(w http.ResponseWriter, r *http.Request) error {
|
||||
var opt models.GenusListOptions
|
||||
if err := schemaDecoder.Decode(&opt, r.URL.Query()); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
genera, err := store.Genera.List(&opt)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if genera == nil {
|
||||
genera = []*models.Genus{}
|
||||
}
|
||||
|
||||
return writeJSON(w, genera)
|
||||
}
|
90
api/genera_test.go
Normal file
90
api/genera_test.go
Normal file
|
@ -0,0 +1,90 @@
|
|||
package api
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/thermokarst/bactdb/models"
|
||||
)
|
||||
|
||||
func TestGenus_Get(t *testing.T) {
|
||||
setup()
|
||||
|
||||
want := &models.Genus{Id: 1, GenusName: "Test Genus"}
|
||||
|
||||
calledGet := false
|
||||
store.Genera.(*models.MockGeneraService).Get_ = func(id int64) (*models.Genus, error) {
|
||||
if id != want.Id {
|
||||
t.Errorf("wanted request for genus %d but got %d", want.Id, id)
|
||||
}
|
||||
calledGet = true
|
||||
return want, nil
|
||||
}
|
||||
|
||||
got, err := apiClient.Genera.Get(want.Id)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
if !calledGet {
|
||||
t.Error("!calledGet")
|
||||
}
|
||||
if !normalizeDeepEqual(want, got) {
|
||||
t.Errorf("got genus %+v but wanted genus %+v", got, want)
|
||||
}
|
||||
}
|
||||
|
||||
func TestGenus_Create(t *testing.T) {
|
||||
setup()
|
||||
|
||||
want := &models.Genus{Id: 1, GenusName: "Test Genus"}
|
||||
|
||||
calledPost := false
|
||||
store.Genera.(*models.MockGeneraService).Create_ = func(genus *models.Genus) (bool, error) {
|
||||
if !normalizeDeepEqual(want, genus) {
|
||||
t.Errorf("wanted request for genus %d but got %d", want, genus)
|
||||
}
|
||||
calledPost = true
|
||||
return true, nil
|
||||
}
|
||||
|
||||
success, err := apiClient.Genera.Create(want)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
if !calledPost {
|
||||
t.Error("!calledPost")
|
||||
}
|
||||
if !success {
|
||||
t.Error("!success")
|
||||
}
|
||||
}
|
||||
|
||||
func TestGenus_List(t *testing.T) {
|
||||
setup()
|
||||
|
||||
want := []*models.Genus{{Id: 1, GenusName: "Test Genus"}}
|
||||
wantOpt := &models.GenusListOptions{ListOptions: models.ListOptions{Page: 1, PerPage: 10}}
|
||||
|
||||
calledList := false
|
||||
store.Genera.(*models.MockGeneraService).List_ = func(opt *models.GenusListOptions) ([]*models.Genus, error) {
|
||||
if !normalizeDeepEqual(wantOpt, opt) {
|
||||
t.Errorf("wanted options %d but got %d", wantOpt, opt)
|
||||
}
|
||||
calledList = true
|
||||
return want, nil
|
||||
}
|
||||
|
||||
genera, err := apiClient.Genera.List(wantOpt)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
if !calledList {
|
||||
t.Error("!calledList")
|
||||
}
|
||||
|
||||
if !normalizeDeepEqual(&want, &genera) {
|
||||
t.Errorf("got genera %+v but wanted genera %+v", genera, want)
|
||||
}
|
||||
}
|
|
@ -18,9 +18,15 @@ var (
|
|||
|
||||
func Handler() *mux.Router {
|
||||
m := router.API()
|
||||
|
||||
m.Get(router.User).Handler(handler(serveUser))
|
||||
m.Get(router.CreateUser).Handler(handler(serveCreateUser))
|
||||
m.Get(router.Users).Handler(handler(serveUsers))
|
||||
|
||||
m.Get(router.Genus).Handler(handler(serveGenus))
|
||||
m.Get(router.CreateGenus).Handler(handler(serveCreateGenus))
|
||||
m.Get(router.Genera).Handler(handler(serveGenera))
|
||||
|
||||
return m
|
||||
}
|
||||
|
||||
|
|
|
@ -5,9 +5,9 @@ CREATE TABLE genera (
|
|||
id BIGSERIAL NOT NULL,
|
||||
genusname CHARACTER VARYING(100),
|
||||
|
||||
created_at TIMESTAMP WITH TIME ZONE,
|
||||
updated_at TIMESTAMP WITH TIME ZONE,
|
||||
deleted_at TIMESTAMP WITH TIME ZONE,
|
||||
createdat TIMESTAMP WITH TIME ZONE,
|
||||
updatedat TIMESTAMP WITH TIME ZONE,
|
||||
deletedat TIMESTAMP WITH TIME ZONE,
|
||||
|
||||
CONSTRAINT genus_pkey PRIMARY KEY (id)
|
||||
);
|
||||
|
|
Reference in a new issue