2017-11-01 52 views
1

나는 Citrus Framework를 사용하여 SOAP을 테스트했습니다. 여기에 내가 주어진 페이로드와 XML 파일에서 가져와야하지만 콘솔에서 다른 위치를 가리키고 있습니다.SOAP 스크립트를 실행하는 중에 "Unmarshalling Error : unexpected element"라는 오류 메시지 받기

soap() 
     .client(todoClient) 
     .send() 
     .soapAction("loginSOAP") 
     .payload(new ClassPathResource("data/loginSOAP.xml")); 

soap() 
     .client(todoClient) 
     .receive()   
     .payload(new ClassPathResource("data/loginSOAPResponse.xml")); 

실행 중에 오류가 발생하는 경우 Unmarshalling Error: unexpected element (uri:"http://soap.myapp.mycomm.org/", local:"userName"). Expected elements are <{}password>,<{}userName>입니다.

여기 좀 도와 주실 수 있습니까? 오류가 발생하는 이유는 무엇입니까?

업데이트 여기 는 스택 추적

10:28:06,169 DEBUG estExecutionListener| After test method: context [[email protected] testClass = SOAP, testInstance = [email protected], testMethod = [email protected], testException = com.consol.citrus.exceptions.TestCaseFailedException: Test case failed, mergedContextConfiguration = [[email protected] testClass = SOAP, locations = '{}', classes = '{class com.consol.citrus.config.CitrusSpringConfig}', contextInitializerClasses = '[]', activeProfiles = '{}', propertySourceLocations = '{}', propertySourceProperties = '{}', contextCustomizers = set[[empty]], contextLoader = 'org.springframework.test.context.support.DelegatingSmartContextLoader', parent = [null]]], class annotated with @DirtiesContext [false] with mode [null], method ann 
otated with @DirtiesContext [false] with mode [null]. 
10:28:06,189 DEBUG estExecutionListener| After test class: context [[email protected] testClass = SOAP, testInstance = [null], testMethod = [null], testException = [null], mergedContextConfiguration = [[email protected] testClass = SOAP, locations = '{}', classes = '{class com.consol.citrus.config.CitrusSpringConfig}', contextInitializerClasses = '[]', activeProfiles = '{}', propertySourceLocations = '{}', propertySourceProperties = '{}', contextCustomizers = set[[empty]], contextLoader = 'org.springframework.test.context.support.DelegatingSmartContextLoader', parent = [null]]], class annotated with @DirtiesContext [false] with mode [null]. 
FAILED: TestPost({Param_18=, Param_17=, Param_16=, Param_15=, Param_9=, Param_14=, Param_8=, Param_13=, Param_7=, Param_12=, Param_6=, Param_11=, Param_5=, Param_10=, Param_4=, Runmode=Y, Param_3=, Param_2=admin, Param_1=admin}) 
com.consol.citrus.exceptions.TestCaseFailedException: Test case failed 
    at com.consol.citrus.TestCase.executeAction(TestCase.java:236) 
    at com.consol.citrus.TestCase.doExecute(TestCase.java:145) 
    at com.consol.citrus.actions.AbstractTestAction.execute(AbstractTestAction.java:42) 
    at com.consol.citrus.Citrus.run(Citrus.java:281) 
    at com.consol.citrus.dsl.testng.TestNGCitrusTest.invokeTestMethod(TestNGCitrusTest.java:136) 
    at com.consol.citrus.dsl.testng.TestNGCitrusTestDesigner.invokeTestMethod(TestNGCitrusTestDesigner.java:73) 
    at com.consol.citrus.dsl.testng.TestNGCitrusTest.run(TestNGCitrusTest.java:111) 
    at com.consol.citrus.dsl.testng.TestNGCitrusTest.run(TestNGCitrusTest.java:57) 
    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.testng.internal.MethodInvocationHelper.invokeHookable(MethodInvocationHelper.java:194) 
    at org.testng.internal.Invoker.invokeMethod(Invoker.java:707) 
    at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:901) 
    at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1231) 
    at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:127) 
    at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111) 
    at org.testng.TestRunner.privateRun(TestRunner.java:767) 
    at org.testng.TestRunner.run(TestRunner.java:617) 
    at org.testng.SuiteRunner.runTest(SuiteRunner.java:334) 
    at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:329) 
    at org.testng.SuiteRunner.privateRun(SuiteRunner.java:291) 
    at org.testng.SuiteRunner.run(SuiteRunner.java:240) 
    at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52) 
    at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86) 
    at org.testng.TestNG.runSuitesSequentially(TestNG.java:1198) 
    at org.testng.TestNG.runSuitesLocally(TestNG.java:1123) 
    at org.testng.TestNG.run(TestNG.java:1031) 
    at org.testng.remote.AbstractRemoteTestNG.run(AbstractRemoteTestNG.java:132) 
    at org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:230) 
    at org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:76) 
Caused by: org.springframework.ws.soap.client.SoapFaultClientException: Unmarshalling Error: unexpected element (uri:"http://soap.myapp.mycomm.org/", local:"userName"). Expected elements are <{}password>,<{}userName> 
    at org.springframework.ws.soap.client.core.SoapFaultMessageResolver.resolveFault(SoapFaultMessageResolver.java:38) 
    at com.consol.citrus.ws.client.WebServiceClient$InternalFaultMessageResolver.resolveFault(WebServiceClient.java:243) 
    at org.springframework.ws.client.core.WebServiceTemplate.handleFault(WebServiceTemplate.java:830) 
    at org.springframework.ws.client.core.WebServiceTemplate.doSendAndReceive(WebServiceTemplate.java:624) 
    at org.springframework.ws.client.core.WebServiceTemplate.sendAndReceive(WebServiceTemplate.java:555) 
    at org.springframework.ws.client.core.WebServiceTemplate.sendAndReceive(WebServiceTemplate.java:531) 
    at com.consol.citrus.ws.client.WebServiceClient.send(WebServiceClient.java:126) 
    at com.consol.citrus.actions.SendMessageAction.doExecute(SendMessageAction.java:118) 
    at com.consol.citrus.actions.AbstractTestAction.execute(AbstractTestAction.java:42) 
    at com.consol.citrus.dsl.actions.DelegatingTestAction.doExecute(DelegatingTestAction.java:54) 
    at com.consol.citrus.actions.AbstractTestAction.execute(AbstractTestAction.java:42) 
    at com.consol.citrus.TestCase.executeAction(TestCase.java:229) 
    ... 31 more 


=============================================== 
    Default test 
    Tests run: 1, Failures: 1, Skips: 0 
=============================================== 

219875 [main] INFO com.consol.citrus.Citrus - 
219875 [main] INFO com.consol.citrus.Citrus - ------------------------------------------------------------------------ 
219875 [main] INFO com.consol.citrus.Citrus - 
219876 [main] INFO com.consol.citrus.Citrus - 
219876 [main] INFO com.consol.citrus.Citrus - AFTER TEST SUITE: SUCCESS 
219876 [main] INFO com.consol.citrus.Citrus - ------------------------------------------------------------------------ 
219876 [main] INFO com.consol.citrus.Citrus - 
219876 [main] INFO com.consol.citrus.Citrus - ------------------------------------------------------------------------ 
219876 [main] INFO com.consol.citrus.Citrus - 
219876 [main] INFO com.consol.citrus.Citrus - CITRUS TEST RESULTS 
219876 [main] INFO com.consol.citrus.Citrus - 
219883 [main] INFO com.consol.citrus.Citrus - SOAP.TestPost([{Param_18=, Param_17=, Param_16=, Param_15=, Param_9=, Param_14=, Param_8=, Param_13=, Param_7=, Param_12=, Param_6=, Param_11=, Param_5=, Param_10=, Param_4=, Runmode=Y, Param_3=, Param_2=admin, Param_1=admin}]) FAILED 
219884 [main] INFO com.consol.citrus.Citrus - FAILURE: Caused by: SoapFaultClientException: Unmarshalling Error: unexpected element (uri:"http://soap.myapp.mycomm.org/", local:"userName"). Expected elements are <{}password>,<{}userName> 
219884 [main] INFO com.consol.citrus.Citrus - 
219885 [main] INFO com.consol.citrus.Citrus - TOTAL: 1 
219886 [main] INFO com.consol.citrus.Citrus - FAILED: 1 (100.0%) 
219886 [main] INFO com.consol.citrus.Citrus - SUCCESS: 0 (0.0%) 
219886 [main] INFO com.consol.citrus.Citrus - 
219886 [main] INFO com.consol.citrus.Citrus - ------------------------------------------------------------------------ 
220110 [main] INFO com.consol.citrus.report.HtmlReporter - Generated HTML test report 

=============================================== 
Default suite 
Total tests run: 1, Failures: 1, Skips: 0 
=============================================== 
+0

전체 오류 스택 추적을 제공해주십시오. 정확히 무슨 일이 일어나는지 이해하는 데 많은 도움이됩니다. 고마워 –

답변

3

여기에 점점 오류는 테스트 케이스에 있지만, 호출하는 서버에서 발생하지 않습니다이다. 클라이언트 인 Citrus가 SoapFaultClientException을 발생시키는 SOAP 오류로 오류를 수신합니다. 분명히 서버는 페이로드로 보내는 loginSOAP.xml의 내용에 만족하지 않습니다.

SOAP 서버 로그도 확인하십시오. 요청을 처리하는 동안 오류가 발생 했으므로 여기에 오류가 표시되어야합니다.