Get a measurement

This commit is contained in:
Matthew Dillon 2014-11-30 20:05:54 -09:00
parent eccbffb86d
commit ca1fbe882c
11 changed files with 280 additions and 0 deletions

View file

@ -65,6 +65,8 @@ func Handler() *mux.Router {
m.Get(router.UpdateUnitType).Handler(handler(serveUpdateUnitType))
m.Get(router.DeleteUnitType).Handler(handler(serveDeleteUnitType))
m.Get(router.Measurement).Handler(handler(serveMeasurement))
return m
}

22
api/measurements.go Normal file
View file

@ -0,0 +1,22 @@
package api
import (
"net/http"
"strconv"
"github.com/gorilla/mux"
)
func serveMeasurement(w http.ResponseWriter, r *http.Request) error {
id, err := strconv.ParseInt(mux.Vars(r)["Id"], 10, 0)
if err != nil {
return err
}
measurement, err := store.Measurements.Get(id)
if err != nil {
return err
}
return writeJSON(w, measurement)
}

40
api/measurements_test.go Normal file
View file

@ -0,0 +1,40 @@
package api
import (
"testing"
"github.com/thermokarst/bactdb/models"
)
func newMeasurement() *models.Measurement {
measurement := models.NewMeasurement()
return measurement
}
func TestMeasurement_Get(t *testing.T) {
setup()
want := newMeasurement()
calledGet := false
store.Measurements.(*models.MockMeasurementsService).Get_ = func(id int64) (*models.Measurement, error) {
if id != want.Id {
t.Errorf("wanted request for measurement %d but got %d", want.Id, id)
}
calledGet = true
return want, nil
}
got, err := apiClient.Measurements.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)
}
}