2017-09-20 4 views
0

Java 용 Amazon AWS SDK를 사용하여 EC2 Instance 데이터에 쿼리하는 응용 프로그램이 있습니다. 인스턴스는 AWS SDK에 포함 된 Jackson 래퍼 클래스를 사용하여 JSON String에 직렬화됩니다. 나중에 Jackson.fromJsonString(String, Class) 메서드를 사용하여 JSON 문자열을 deserialize하여 EC2 Instance 개체로 되돌릴 수 있습니다.Jackson : JUnit 테스트의 "속성에 대한 setter 정의 충돌"

이 모든 것이 내 응용 프로그램 코드에서 잘 작동합니다. 그러나 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의 일부 임) 나는 Jackson 주석을 수정할 수 없다. 어떻게 내 단위 테스트를 위해이 문제를 해결할 수 있을지 생각해?

+1

['Instance'] (http://docs.aws.amazon.com/AWSJavaSDK/latest/javadoc/com/amazonaws/services/ec2/model/Instance.html) 소스를 보면 2 개의'setInstanceType '메소드 중 하나는'String' 인자를 가지며, 하나는'InstanceType' enum 인자를가집니다. 이것은 혼동을 설명 할 수 있습니다. 어떤 것을 사용하는지 알고 있다면 믹스 인을 사용하여 다른 것을 무시할 수 있습니다 (예 : [https://github.com/FasterXML/jackson-databind/issues/1251]). 왜 이런 일이 벌어지는 지에 관해서는 두 프로세스 사이의 classpath 차이 만 생각할 수는 있지만 실제로는 손가락으로 볼 수는 없습니다 ... – 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

그들은 그 직렬화/역 직렬화에 사용하는 하나 지정하여 두 세터 중 하나에 잭슨에 대한 주석을 가지고있는 것 같습니다. 이것은 최신 버전입니다. 이전 버전에서 누락 된 부분이 있는지 기록하기 위해 다시 도구로 사용하지 않았습니다.

+0

개발 워크 스테이션에서 응용 프로그램 코드와 JUnit 테스트를 모두 실행하고 있습니다. 동일한 JDK, 동일한 AWS SDK, 동일한 모든 것 (내가 말할 수있는 최선의 방법). 하지만 응용 프로그램의 일부로 동일한 코드 블록을 실행하면 (예 : JSF 작업 시작) 작동하지만 JUnit 테스트가 실패합니다. – Shadowman

+0

전체 클래스 경로 비교 - IDE에서 응용 프로그램과 유닛 테스트를 모두 실행하는 경우 IDE에서 콘솔에서 Java 명령을 실행하여 전체 클래스 경로를 표시해야합니다. 둘 다 위해 그것을 저장하고 비교하십시오. junit과 같은 테스트 종속성에 대한 몇 가지 차이점을 기대할 수 있습니다. 그러나 잭슨이나 AWS와 관련된 차이점이 핵심이라고 생각하면됩니다. Paven 파일이 버전에서 잠기지 않는 경우 일반적인 방법 차이가 있습니다. –

+0

종속성 관리에 Maven을 사용하고 있습니다. 내 POM 파일은 명시 적으로 버전을 언급합니다. 아직도 무슨 일이 벌어 질지 몰라. – Shadowman