2017-06-15 18 views
0

以下は今まで絶対にうまく動作していたテストコードですが、現在以下の例外を投げています。以下はcom.fasterxml.jackson.databind.JsonMappingException新しいMavenエントリのため

import com.google.gson.JsonObject; 
import com.google.gson.JsonParser; 
import static io.restassured.RestAssured.given; 
import io.restassured.response.Response; 

RequestSpecification spec = new RequestSpecBuilder().setBaseUri(someBaseUri).setBasePath(someEndpoint).build(); 
JsonParser parser = new JsonParser(); 
JsonObject jsonObject = parser.parse("{\r\n\"otp\":\""+sentOtp+"\",\r\n\"otpToken\":\""+otpToken+"\"\r\n}").getAsJsonObject(); 
response = given().spec(spec).headers("key","value").body(jsonObject).when().post(); //the exception is thrown at this line 

例外トレースです:戻ってそれを配置しながら

いくつかの分離に
com.fasterxml.jackson.databind.JsonMappingException: JsonObject (through reference chain: com.google.gson.JsonObject["asString"]) 
    at com.google.gson.JsonElement.getAsString(JsonElement.java:191) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.get(BeanPropertyWriter.java:679) 
    at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:534) 
    at com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:597) 
    at com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:142) 
    at com.fasterxml.jackson.databind.ser.DefaultSerializerProvider.serializeValue(DefaultSerializerProvider.java:118) 
    at com.fasterxml.jackson.databind.ObjectMapper.writeValue(ObjectMapper.java:1819) 
    at com.fasterxml.jackson.databind.ObjectMapper$writeValue$0.call(Unknown Source) 
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48) 
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113) 
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:133) 
    at io.restassured.internal.mapping.Jackson2Mapper.serialize(Jackson2Mapper.groovy:53) 
    at io.restassured.internal.mapping.Jackson2Mapper.serialize(Jackson2Mapper.groovy) 
    at io.restassured.mapper.ObjectMapper$serialize.call(Unknown Source) 
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48) 
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113) 
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:125) 
    at io.restassured.internal.mapping.ObjectMapping.serializeWithJackson2(ObjectMapping.groovy:181) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:93) 
    at org.codehaus.groovy.runtime.callsite.StaticMetaMethodSite$StaticMetaMethodSiteNoUnwrapNoCoerce.invoke(StaticMetaMethodSite.java:151) 
    at org.codehaus.groovy.runtime.callsite.StaticMetaMethodSite.callStatic(StaticMetaMethodSite.java:102) 
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallStatic(CallSiteArray.java:56) 
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callStatic(AbstractCallSite.java:194) 
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callStatic(AbstractCallSite.java:214) 
    at io.restassured.internal.mapping.ObjectMapping.serialize(ObjectMapping.groovy:130) 
    at io.restassured.internal.mapping.ObjectMapping$serialize.call(Unknown Source) 
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48) 
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113) 
    at io.restassured.internal.RequestSpecificationImpl.body(RequestSpecificationImpl.groovy:829) 
    ... 

と私のテストプロジェクトのコミットの歴史を見直し、私は、コードの塊の下に除去することが魔法のように問題を解決することを見出しましたpom.xmlで元の問題に再び遭遇します。

<dependency> 
    <groupId>io.rest-assured</groupId> 
    <artifactId>json-schema-validator</artifactId> 
    <version>3.0.3</version> 
    </dependency> 
    <dependency> 
    <groupId>com.github.fge</groupId> 
    <artifactId>json-schema-validator</artifactId> 
    <version>2.2.6</version> 
    </dependency> 
    <dependency> 
    <groupId>com.github.fge</groupId> 
    <artifactId>json-schema-core</artifactId> 
    <version>1.2.5</version> 
    </dependency> 

助けてください。

答えて

0

あなたはGsonを渡したい場合は、明示的シリアライザを指定する必要があります:実際に

given().log().all().contentType(ContentType.JSON).headers("key", "value").body(jsonObject, ObjectMapperType.GSON).when().post(); 

contentType(ContentType.JSON)は、あなたの出力は

+0

ああを清書ようになります!私はそれを知らなかった。情報をありがとう。しかし、回避策として、JsonObjectとして 'body()'メソッドに渡す代わりに、文字列をそのまま渡すようにコードを修正しました。しかし、それは私のためにも機能するので、私はあなたの答えを受け入れるでしょう。 :) –

+0

ええ、文字列を直接渡すより簡単な方法です。 – RocketRaccoon

関連する問題