2017-09-20 8 views
0

AmazonのAWS SDK for Javaを使用してEC2 Instanceデータにクエリを実行するアプリケーションがあります。このインスタンスはAWS SDKに含まれるJacksonラッパークラスを使用してJSON Stringにシリアル化されます。後で、Jackson.fromJsonString(String, Class)メソッドを使用して、JSON文字列を逆シリアル化してEC2 Instanceオブジェクトに戻すことができます。ジャネット:JUnitテストの「プロパティのセッター定義の競合」

これはすべて私のアプリケーションコードでうまくいきます。ただし、Eclipse内のJUnitテストから実行すると、毎回失敗します。私はまったく同じデータと、まったく同じ逆シリアル化コードを使用しています。地球上で何が間違ってここに行くことができ

com.amazonaws.SdkClientException: Unable to parse Json String. 
    at com.amazonaws.util.json.Jackson.fromJsonString(Jackson.java:66) 
    at com.myapp.filters.test.AbstractResourceFilterCriteriaTest.testMeetsCriteria_Fail(AbstractResourceFilterCriteriaTest.java:166) 
    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.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) 
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) 
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) 
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27) 
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57) 
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) 
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) 
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) 
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) 
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363) 
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86) 
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:678) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192) 
Caused by: com.fasterxml.jackson.databind.JsonMappingException: Conflicting setter definitions for property "instanceType": com.amazonaws.services.ec2.model.Instance#setInstanceType(1 params) vs com.amazonaws.services.ec2.model.Instance#setInstanceType(1 params) 
    at com.fasterxml.jackson.databind.deser.DeserializerCache._createAndCache2(DeserializerCache.java:269) 
    at com.fasterxml.jackson.databind.deser.DeserializerCache._createAndCacheValueDeserializer(DeserializerCache.java:244) 
    at com.fasterxml.jackson.databind.deser.DeserializerCache.findValueDeserializer(DeserializerCache.java:142) 
    at com.fasterxml.jackson.databind.DeserializationContext.findRootValueDeserializer(DeserializationContext.java:461) 
    at com.fasterxml.jackson.databind.ObjectMapper._findRootDeserializer(ObjectMapper.java:3838) 
    at com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:3732) 
    at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:2726) 
    at com.amazonaws.util.json.Jackson.fromJsonString(Jackson.java:64) 
    ... 26 more 
Caused by: java.lang.IllegalArgumentException: Conflicting setter definitions for property "instanceType": com.amazonaws.services.ec2.model.Instance#setInstanceType(1 params) vs com.amazonaws.services.ec2.model.Instance#setInstanceType(1 params) 
    at com.fasterxml.jackson.databind.introspect.POJOPropertyBuilder.getSetter(POJOPropertyBuilder.java:300) 
    at com.fasterxml.jackson.databind.deser.BeanDeserializerFactory.filterBeanProps(BeanDeserializerFactory.java:619) 
    at com.fasterxml.jackson.databind.deser.BeanDeserializerFactory.addBeanProps(BeanDeserializerFactory.java:515) 
    at com.fasterxml.jackson.databind.deser.BeanDeserializerFactory.buildBeanDeserializer(BeanDeserializerFactory.java:256) 
    at com.fasterxml.jackson.databind.deser.BeanDeserializerFactory.createBeanDeserializer(BeanDeserializerFactory.java:169) 
    at com.fasterxml.jackson.databind.deser.DeserializerCache._createDeserializer2(DeserializerCache.java:403) 
    at com.fasterxml.jackson.databind.deser.DeserializerCache._createDeserializer(DeserializerCache.java:352) 
    at com.fasterxml.jackson.databind.deser.DeserializerCache._createAndCache2(DeserializerCache.java:264) 
    ... 33 more 

任意のアイデア:私はJUnitテストからそれを実行すると、しかし、私は次の例外を取得しますか?主なアプリケーションコードで正常に動作しますが、JUnitテストとして実行すると失敗するのはなぜですか?私はInstanceオブジェクト(AmazonのSDKの一部です)を所有していないので、私はジャクソンの注釈を変更することはできません。どのように私は私のユニットテストのためにこれを回避することができますか?

+1

['Instance'](http://docs.aws.amazon.com/AWSJavaSDK/latest/javadoc/com/amazonaws/services/ec2/model/Instance.html)ソースを見ると、2つの' setInstanceType 'メソッドであり、一つは' String'引数を持ち、もう一つは 'InstanceType' enum引数を持つものです。これは混乱を説明するかもしれません。どちらが使用されているかわかっている場合は、mixin([ここ](https://github.com/FasterXML/jackson-databind/issues/1251)など)を使用して、他のものを無視しようとすることができます。なぜこれが起こっているかに関しては、2つのプロセス間のクラスパスの違いしか考えられませんが、実際に指を置くことはできません。 – Morfic

+0

@Morfic +1 [JacksonMixInAnnotations](https://github.com/FasterXML/jackson-docs/wiki/JacksonMixInAnnotations)おそらく助けることができます – varren

答えて

2

おそらく、テストとプロダクションの間にSDKのバージョンの問題があると思います。このクラスの彼らのソースコードを見てみると:

https://github.com/aws/aws-sdk-java/blob/master/aws-java-sdk-ec2/src/main/java/com/amazonaws/services/ec2/model/Instance.java

彼らはそれがシリアライズ/デシリアライズするために使用する1つです指定し、2つのセッターの1にジャクソンのための注釈を持っているように見えます。これは最新のバージョンですが、古いバージョンでこれが見つからなかったかどうかを私は履歴で確認しませんでした。

+0

開発用ワークステーションでアプリケーションコードとJUnitテストの両方を実行しています。同じJDK、同じAWS SDK、同じものすべて(私が知る限り)しかし、アプリケーションの一部として同じコードブロックを実行すると(たとえば、JSFアクションを開始するなど)、JUnitテストは失敗します。 – Shadowman

+0

完全なクラスパスを比較する - アプリケーションとユニットテストの両方をIDEから起動する場合、IDEはコンソールに完全なクラスパスを持つべきjavaコマンドを表示する必要があります。両方のためにそれを保存し、比較を行います。私はjunitのようなテストの依存関係にいくつかの違いがあると思っていますが、ジャクソンやAWSに関連する違いがキーになることがわかっているとします。あなたがMavenの場合、POMファイルがバージョンでロックされていない場合、一般的な相違点があります。 –

+0

私はMavenを依存関係管理に使用しています。私のPOMファイルに明示的にバージョンが記述されています。まだ何が起こっているのかは分かりません。 – Shadowman

関連する問題