Genera: api.

This commit is contained in:
Matthew Dillon 2014-10-13 10:15:33 -08:00
parent 533adbdd09
commit 59a0cfd4bf
4 changed files with 160 additions and 3 deletions

61
api/genera.go Normal file
View 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
View 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)
}
}

View file

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

View file

@ -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)
);