Skip to content

Commit

Permalink
internal: Add Netty Rx response test (#3286)
Browse files Browse the repository at this point in the history
  • Loading branch information
xerial authored Nov 20, 2023
1 parent ebb4357 commit 8282d54
Showing 1 changed file with 49 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package wvlet.airframe.http.netty

import wvlet.airframe.http.client.SyncClient
import wvlet.airframe.http.{Http, RPC, RxRouter}
import wvlet.airframe.rx.Rx
import wvlet.airspec.AirSpec

object NettyRxResponseTest extends AirSpec {

@RPC
class RxApi {
def helloRx(message: String): Rx[String] = {
Rx.single(s"Hello ${message}!")
}
}

initDesign {
_.add(
Netty.server
.withRouter(RxRouter.of[RxApi])
.designWithSyncClient
)
}

test("hello rx") { (client: SyncClient) =>
val resp = client.send(
Http
.POST("/wvlet.airframe.http.netty.NettyRxResponseTest.RxApi/helloRx")
.withJson("""{"message":"Rx"}""")
)

resp.statusCode shouldBe 200
resp.contentString shouldBe "Hello Rx!"
}

}

0 comments on commit 8282d54

Please sign in to comment.