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/decorated2/app/src/Decorated2.scala | 37 ++++++++++++++++++++++ example/decorated2/app/test/src/ExampleTests.scala | 27 ++++++++++++++++ example/decorated2/build.sc | 18 +++++++++++ 3 files changed, 82 insertions(+) create mode 100644 example/decorated2/app/src/Decorated2.scala create mode 100644 example/decorated2/app/test/src/ExampleTests.scala create mode 100644 example/decorated2/build.sc (limited to 'example/decorated2') diff --git a/example/decorated2/app/src/Decorated2.scala b/example/decorated2/app/src/Decorated2.scala new file mode 100644 index 0000000..014965e --- /dev/null +++ b/example/decorated2/app/src/Decorated2.scala @@ -0,0 +1,37 @@ +package app +object Decorated2 extends cask.MainRoutes{ + class User{ + override def toString = "[haoyi]" + } + class loggedIn extends cask.Decorator { + def wrapFunction(ctx: cask.ParamContext, delegate: Delegate): Returned = { + delegate(Map("user" -> new User())) + } + } + class withExtra extends cask.Decorator { + def wrapFunction(ctx: cask.ParamContext, delegate: Delegate): Returned = { + delegate(Map("extra" -> 31337)) + } + } + + override def decorators = Seq(new withExtra()) + + @cask.get("/hello/:world") + def hello(world: String)(extra: Int) = { + world + extra + } + + @loggedIn() + @cask.get("/internal-extra/:world") + def internalExtra(world: String)(user: User)(extra: Int) = { + world + user + extra + } + + @loggedIn() + @cask.get("/ignore-extra/:world") + def ignoreExtra(world: String)(user: User)(extra: Int) = { + world + user + } + + initialize() +} diff --git a/example/decorated2/app/test/src/ExampleTests.scala b/example/decorated2/app/test/src/ExampleTests.scala new file mode 100644 index 0000000..7fec82a --- /dev/null +++ b/example/decorated2/app/test/src/ExampleTests.scala @@ -0,0 +1,27 @@ +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{ + 'Decorated2 - test(Decorated2){ host => + requests.get(s"$host/hello/woo").text() ==> "woo31337" + requests.get(s"$host/internal-extra/goo").text() ==> "goo[haoyi]31337" + requests.get(s"$host/ignore-extra/boo").text() ==> "boo[haoyi]" + + } + } +} diff --git a/example/decorated2/build.sc b/example/decorated2/build.sc new file mode 100644 index 0000000..6b3ab3f --- /dev/null +++ b/example/decorated2/build.sc @@ -0,0 +1,18 @@ +import mill._, scalalib._ + + +trait AppModule extends ScalaModule{ + def scalaVersion = "2.12.6" + def ivyDeps = Agg( + ivy"com.lihaoyi::cask:0.0.1", + ) + + object test extends Tests{ + def testFrameworks = Seq("utest.runner.Framework") + def forkArgs = Seq("--illegal-access=deny") + def ivyDeps = Agg( + ivy"com.lihaoyi::utest::0.6.3", + ivy"com.lihaoyi::requests::0.1.2", + ) + } +} \ No newline at end of file -- cgit v1.2.3