Get an observation type
This commit is contained in:
parent
bedddfdec1
commit
4fd7bf8eba
11 changed files with 271 additions and 13 deletions
|
@ -41,6 +41,8 @@ func Handler() *mux.Router {
|
|||
m.Get(router.UpdateStrain).Handler(handler(serveUpdateStrain))
|
||||
m.Get(router.DeleteStrain).Handler(handler(serveDeleteStrain))
|
||||
|
||||
m.Get(router.ObservationType).Handler(handler(serveObservationType))
|
||||
|
||||
return m
|
||||
}
|
||||
|
||||
|
|
22
api/observation_types.go
Normal file
22
api/observation_types.go
Normal file
|
@ -0,0 +1,22 @@
|
|||
package api
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"github.com/gorilla/mux"
|
||||
)
|
||||
|
||||
func serveObservationType(w http.ResponseWriter, r *http.Request) error {
|
||||
id, err := strconv.ParseInt(mux.Vars(r)["Id"], 10, 0)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
observation_type, err := store.ObservationTypes.Get(id)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return writeJSON(w, observation_type)
|
||||
}
|
40
api/observation_types_test.go
Normal file
40
api/observation_types_test.go
Normal file
|
@ -0,0 +1,40 @@
|
|||
package api
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/thermokarst/bactdb/models"
|
||||
)
|
||||
|
||||
func newObservationType() *models.ObservationType {
|
||||
observation_type := models.NewObservationType()
|
||||
return observation_type
|
||||
}
|
||||
|
||||
func TestObservationType_Get(t *testing.T) {
|
||||
setup()
|
||||
|
||||
want := newObservationType()
|
||||
|
||||
calledGet := false
|
||||
|
||||
store.ObservationTypes.(*models.MockObservationTypesService).Get_ = func(id int64) (*models.ObservationType, error) {
|
||||
if id != want.Id {
|
||||
t.Errorf("wanted request for observation_type %d but got %d", want.Id, id)
|
||||
}
|
||||
calledGet = true
|
||||
return want, nil
|
||||
}
|
||||
|
||||
got, err := apiClient.ObservationTypes.Get(want.Id)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
if !calledGet {
|
||||
t.Error("!calledGet")
|
||||
}
|
||||
if !normalizeDeepEqual(want, got) {
|
||||
t.Errorf("got %+v but wanted %+v", got, want)
|
||||
}
|
||||
}
|
Reference in a new issue