Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(147)

Unified Diff: appengine/gaemiddleware/appengine_test.go

Issue 2043423004: Make HTTP middleware easier to use (Closed) Base URL: https://github.com/luci/luci-go@master
Patch Set: Update tests Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: appengine/gaemiddleware/appengine_test.go
diff --git a/appengine/gaemiddleware/appengine_test.go b/appengine/gaemiddleware/appengine_test.go
index a95bc160401b2b597e28ae51485249722fbd3f81..e02a624a7c37fcf1dbe9c6c16919c33cdc9c900d 100644
--- a/appengine/gaemiddleware/appengine_test.go
+++ b/appengine/gaemiddleware/appengine_test.go
@@ -11,6 +11,7 @@ import (
"github.com/julienschmidt/httprouter"
"github.com/luci/luci-go/appengine/gaetesting"
+ "github.com/luci/luci-go/server/router"
. "github.com/smartystreets/goconvey/convey"
"golang.org/x/net/context"
)
@@ -23,16 +24,25 @@ func init() {
func TestRequireCron(t *testing.T) {
t.Parallel()
+ initialize := func(w http.ResponseWriter, r *http.Request, p httprouter.Params) router.Handler {
+ return func(c *router.Context) {
+ c.Writer = w
+ c.Request = r
+ c.Params = p
+ }
+ }
+
Convey("Test RequireCron", t, func() {
hit := false
- f := func(c context.Context, rw http.ResponseWriter, r *http.Request, p httprouter.Params) {
+
+ f := func(c *router.Context) {
hit = true
- rw.Write([]byte("ok"))
+ c.Writer.Write([]byte("ok"))
}
Convey("from non-cron fails", func() {
rec := httptest.NewRecorder()
- gaetesting.BaseTest(RequireCron(f))(rec, &http.Request{}, nil)
+ router.ChainHandlers(initialize(rec, &http.Request{}, nil), gaetesting.BaseTest(), RequireCron(), f)()
So(hit, ShouldBeFalse)
So(rec.Body.String(), ShouldEqual, "error: must be run from cron")
So(rec.Code, ShouldEqual, http.StatusForbidden)
@@ -40,11 +50,11 @@ func TestRequireCron(t *testing.T) {
Convey("from cron succeeds", func() {
rec := httptest.NewRecorder()
- gaetesting.BaseTest(RequireCron(f))(rec, &http.Request{
+ router.ChainHandlers(initialize(rec, &http.Request{
Header: http.Header{
http.CanonicalHeaderKey("x-appengine-cron"): []string{"true"},
},
- }, nil)
+ }, nil), gaetesting.BaseTest(), RequireCron(), f)()
So(hit, ShouldBeTrue)
So(rec.Body.String(), ShouldEqual, "ok")
So(rec.Code, ShouldEqual, http.StatusOK)
@@ -55,16 +65,24 @@ func TestRequireCron(t *testing.T) {
func TestRequireTQ(t *testing.T) {
t.Parallel()
+ initialize := func(w http.ResponseWriter, r *http.Request, p httprouter.Params) router.Handler {
+ return func(c *router.Context) {
+ c.Writer = w
+ c.Request = r
+ c.Params = p
+ }
+ }
+
Convey("Test RequireTQ", t, func() {
hit := false
- f := func(c context.Context, rw http.ResponseWriter, r *http.Request, p httprouter.Params) {
+ f := func(c *router.Context) {
hit = true
- rw.Write([]byte("ok"))
+ c.Writer.Write([]byte("ok"))
}
Convey("from non-tq fails (wat)", func() {
rec := httptest.NewRecorder()
- gaetesting.BaseTest(RequireTaskQueue("wat", f))(rec, &http.Request{}, nil)
+ router.ChainHandlers(initialize(rec, &http.Request{}, nil), gaetesting.BaseTest(), RequireTaskQueue("wat"), f)()
So(hit, ShouldBeFalse)
So(rec.Body.String(), ShouldEqual, "error: must be run from the correct taskqueue")
So(rec.Code, ShouldEqual, http.StatusForbidden)
@@ -72,7 +90,7 @@ func TestRequireTQ(t *testing.T) {
Convey("from non-tq fails", func() {
rec := httptest.NewRecorder()
- gaetesting.BaseTest(RequireTaskQueue("", f))(rec, &http.Request{}, nil)
+ router.ChainHandlers(initialize(rec, &http.Request{}, nil), gaetesting.BaseTest(), RequireTaskQueue(""), f)()
So(hit, ShouldBeFalse)
So(rec.Body.String(), ShouldEqual, "error: must be run from the correct taskqueue")
So(rec.Code, ShouldEqual, http.StatusForbidden)
@@ -80,11 +98,11 @@ func TestRequireTQ(t *testing.T) {
Convey("from wrong tq fails (wat)", func() {
rec := httptest.NewRecorder()
- gaetesting.BaseTest(RequireTaskQueue("wat", f))(rec, &http.Request{
+ router.ChainHandlers(initialize(rec, &http.Request{
Header: http.Header{
http.CanonicalHeaderKey("x-appengine-queuename"): []string{"else"},
},
- }, nil)
+ }, nil), gaetesting.BaseTest(), RequireTaskQueue("wat"), f)()
So(hit, ShouldBeFalse)
So(rec.Body.String(), ShouldEqual, "error: must be run from the correct taskqueue")
So(rec.Code, ShouldEqual, http.StatusForbidden)
@@ -92,11 +110,11 @@ func TestRequireTQ(t *testing.T) {
Convey("from right tq succeeds (wat)", func() {
rec := httptest.NewRecorder()
- gaetesting.BaseTest(RequireTaskQueue("wat", f))(rec, &http.Request{
+ router.ChainHandlers(initialize(rec, &http.Request{
Header: http.Header{
http.CanonicalHeaderKey("x-appengine-queuename"): []string{"wat"},
},
- }, nil)
+ }, nil), gaetesting.BaseTest(), RequireTaskQueue("wat"), f)()
So(hit, ShouldBeTrue)
So(rec.Body.String(), ShouldEqual, "ok")
So(rec.Code, ShouldEqual, http.StatusOK)
@@ -104,11 +122,11 @@ func TestRequireTQ(t *testing.T) {
Convey("from any tq succeeds", func() {
rec := httptest.NewRecorder()
- gaetesting.BaseTest(RequireTaskQueue("", f))(rec, &http.Request{
+ router.ChainHandlers(initialize(rec, &http.Request{
Header: http.Header{
http.CanonicalHeaderKey("x-appengine-queuename"): []string{"wat"},
},
- }, nil)
+ }, nil), gaetesting.BaseTest(), RequireTaskQueue(""), f)()
So(hit, ShouldBeTrue)
So(rec.Body.String(), ShouldEqual, "ok")
So(rec.Code, ShouldEqual, http.StatusOK)

Powered by Google App Engine
This is Rietveld 408576698