有人可以解释为什么这个httpunit测试用例在wc.getResponse中使用“bad file descriptor”失败了。我添加了is.close()作为猜测并在失败之前和之后移动它但是没有效果。此测试将请求发送到Dropwizard应用程序。
public class TestCircuitRequests
{
static WebConversation wc = new WebConversation();
static String url = "http://localhost:8888/funl/circuit/test.circuit1";
@Test
public void testPut() throws Exception
{
InputStream is = new FileInputStream("src/test/resources/TestCircuit.json");
WebRequest rq = new PutMethodWebRequest(url, is, "application/json");
wc.setAuthentication("FUNL", "foo", "bar");
WebResponse response = wc.getResponse(rq);
is.close();
}
答案 0 :(得分:0)
没有回复?所以我会根据我学到的东西来尝试自己。
Httpunit是一个古老的熟悉的工具,如果可以的话,我会使用它。但它已经两年多没有更新了,所以我收集它对@PUT请求的支持是不对的。
所以我改为泽西客户。在经历了一系列艰难的努力之后,我完成了这段似乎有用的代码:
@Test
public void testPut() throws Exception
{
InputStream is = new FileInputStream("src/test/resources/TestCircuit.json");
String circuit = StreamUtil.readFully(is);
is.close();
Authenticator.setDefault(new MyAuthenticator());
ClientConfig config = new DefaultClientConfig();
Client client = Client.create(config);
com.sun.jersey.api.client.WebResource service = client.resource(url);
Builder builder = service.accept(MediaType.APPLICATION_JSON);
builder.entity(circuit, MediaType.APPLICATION_JSON);
builder.put(String.class, circuit);
return;
}
这有意避免JAX-RS从JSON字符串自动构造bean。