From fd9c399db8c1c0d86cc65d5e1c41968b42a813d1 Mon Sep 17 00:00:00 2001 From: Li Haoyi Date: Sun, 12 Aug 2018 22:18:39 +0800 Subject: auto-upload examples --- example/httpMethods/app/src/HttpMethods.scala | 10 +++++++++ .../httpMethods/app/test/src/ExampleTests.scala | 25 ++++++++++++++++++++++ 2 files changed, 35 insertions(+) create mode 100644 example/httpMethods/app/src/HttpMethods.scala create mode 100644 example/httpMethods/app/test/src/ExampleTests.scala (limited to 'example/httpMethods/app') diff --git a/example/httpMethods/app/src/HttpMethods.scala b/example/httpMethods/app/src/HttpMethods.scala new file mode 100644 index 0000000..5fcbdca --- /dev/null +++ b/example/httpMethods/app/src/HttpMethods.scala @@ -0,0 +1,10 @@ +package app +object HttpMethods extends cask.MainRoutes{ + @cask.route("/login", methods = Seq("get", "post")) + def login(request: cask.Request) = { + if (request.exchange.getRequestMethod.equalToString("post")) "do_the_login" + else "show_the_login_form" + } + + initialize() +} diff --git a/example/httpMethods/app/test/src/ExampleTests.scala b/example/httpMethods/app/test/src/ExampleTests.scala new file mode 100644 index 0000000..e14bcf5 --- /dev/null +++ b/example/httpMethods/app/test/src/ExampleTests.scala @@ -0,0 +1,25 @@ +package app +import io.undertow.Undertow + +import utest._ + +object ExampleTests extends TestSuite{ + def test[T](example: cask.main.BaseMain)(f: String => T): T = { + val server = Undertow.builder + .addHttpListener(8080, "localhost") + .setHandler(example.defaultHandler) + .build + server.start() + val res = + try f("http://localhost:8080") + finally server.stop() + res + } + + val tests = Tests{ + 'HttpMethods - test(HttpMethods){ host => + requests.post(s"$host/login").text() ==> "do_the_login" + requests.get(s"$host/login").text() ==> "show_the_login_form" + } + } +} -- cgit v1.2.3