【发布时间】:2017-11-29 21:47:49
【问题描述】:
我有一条有效的 cxfrs 路线。我可以使用带有 json 对象的 SoapUi 访问其余服务并获得响应。
我想编写单元测试,但我想使用 CamelTestSupport。我的 routebuilder configure() 方法如下所示:
from(cxfrsEndpoint)
.recipientList(simple("direct:${header.operationName}"))
.setHeader(Exchange.CONTENT_LENGTH, simple("-1"));
from("direct:submitRequest")
.bean("responseBean", "checkJson")
.bean("responseBean", "createSuccessResponse");
当我将来自 SoapUi (http://localhost:8181/cxf/myContext/submitRequest) 的 URL 作为带有适当 json 字符串的 POST 时,我得到一个“成功”的 json。很酷。
在我的单元测试中,我创建了一个覆盖的 createRouteBuilder 方法:
@Override
protected RouteBuilder createRouteBuilder() {
MyRouteBuilder myRouteBuilder = new MyRouteBuilder();
myRouteBuilder.setCxfrsEndpoint("direct:start");
return myRouteBuilder;
}
然后我的单元测试(我认为)看起来像这样:
@Test
public void thisIsATest() throws Exception {
MyRequest myRequest = new MyRequest();
request.setSomeProperty("Some property value");
ObjectMapper objectMapper = new ObjectMapper();
String goodJsonRequest = objectMapper.writeValueAsString(request);
String response = (String) template.requestBodyAndHeader(START_POINT, goodJsonRequest, "operationName", "submitRequest");
assertNotNull(response);
//Omitted: further assertions for content of the response json
}
好吧,当我执行单元测试时,我得到一个解组异常,原因如下:
Caused by: com.ctc.wstx.exc.WstxUnexpectedCharException: Unexpected character '{' (code 123) in prolog; expected '<'
at [row,col {unknown-source}]: [1,1]
at com.ctc.wstx.sr.StreamScanner.throwUnexpectedChar(StreamScanner.java:647)
at com.ctc.wstx.sr.BasicStreamReader.nextFromProlog(BasicStreamReader.java:2054)
at com.ctc.wstx.sr.BasicStreamReader.next(BasicStreamReader.java:1131)
at com.sun.xml.bind.v2.runtime.unmarshaller.StAXStreamConnector.bridge(StAXStreamConnector.java:164)
at com.sun.xml.bind.v2.runtime.unmarshaller.UnmarshallerImpl.unmarshal0(UnmarshallerImpl.java:415)
... 74 more
它不喜欢我的 json 字符串。真正接受的服务是什么?
在真实路由上,我在 blueprint.xml 中启用了端点日志记录,如下所示:
<!-- RouteBuilder declarations -->
<bean id="myRouteBuilder" class="com.mycompany.MyRouteBuilder">
<property name="cxfrsEndpoint" value="cxfrs:bean:cxfrsEndpoint?bindingStyle=SimpleConsumer&loggingFeatureEnabled=true" />
</bean>
我在日志中看到的作为“有效负载:”的 json 字符串与我通过 template.requestBodyAndHeader(...) 发送的 json 字符串看起来没有任何不同。
我错过了什么或者我做错了什么?
谢谢!
【问题讨论】:
-
在我看来,您的端点期望有效负载以 XML 请求的形式出现,而不是 JSON。当您覆盖
myRouteBuilder.setCxfrsEndpoint("direct:start");中的端点时,您正在更改路由的预期方式。 -
如果您需要更多详细信息,我可以将其公开为答案。
标签: json unit-testing apache-camel cxfrs