Сравните два soap ответа, используя groovy скрипт - PullRequest
1 голос
/ 06 февраля 2020

Я использую бесплатную версию SoapUI. Мне нужно сравнить soap ответов. Я ожидал ответа в файле Excel. Я хочу сравнить ожидаемый ответ с фактическим ответом от SoapUI и при сравнении мне нужно игнорировать некоторые поля, используя скрипт groovy. Я могу прочитать данные из Excel в строку и ответ из SoapUI в другую строку. Мне нужна помощь в сравнении этих двух значений. У меня не было подходящих ссылок для сравнения. У меня нет кода для сравнения. Пожалуйста, помогите мне с этим

import static java.nio.charset.StandardCharsets.*;
import java.lang.*;
import com.eviware.soapui.model.testsuite.Assertable.AssertionStatus
import com.eviware.soapui.impl.wsdl.teststeps.WsdlTestRequestStep
import com.eviware.soapui.support.XmlHolder
import jxl.*
import jxl.write.*
import org.skyscreamer.jsonassert.JSONAssert
import org.skyscreamer.jsonassert.JSONCompareMode
import groovy.json.JsonSlurper
/*XMLUnit.setIgnoreWhitespace(true)
XMLUnit.setIgnoreComments(true)
XMLUnit.setIgnoreDiffBetweenTextAndCDATA(true)
XMLUnit.setNormalizeWhitespace(true)*/
def count=0,i=1,j=1,k=1
def inputFileName,outputFileName
def inputFile = testRunner.testCase.testSuite.getPropertyValue("inputFileName")
def outputFile = testRunner.testCase.testSuite.getPropertyValue("outputFileName")
def testStep = testRunner.testCase.testSteps["Properties"]

Workbook inputWB = Workbook.getWorkbook(new File(inputFile)) 
Sheet inputSheet = inputWB.getSheet(0)
no_of_rows= inputSheet.getRows().toInteger() 

Workbook existingInputWB=Workbook.getWorkbook(new File(inputFile))
WritableWorkbook outputWB=Workbook.createWorkbook(new File(outputFile),existingInputWB)

testCaseName=testRunner.testCase.name
outputWB.createSheet(testCaseName,2)
WritableSheet sheet_writable = outputWB.getSheet(testCaseName)
jxl.write.Label testStepCell =  new jxl.write.Label(0,0 ,"Test Step")
jxl.write.Label reqUrlCell =  new jxl.write.Label(2,0 ,"Request URL")
jxl.write.Label reqPayloadCell =  new jxl.write.Label(3,0 ,"Request Payload")
jxl.write.Label responseCell =  new jxl.write.Label(4,0 ,"Response")
jxl.write.Label statusCell =  new jxl.write.Label(1,0 ,"Status")
jxl.write.Label reasonCell =  new jxl.write.Label(5,0 ,"Reason")
sheet_writable.addCell(testStepCell)
sheet_writable.addCell(reqUrlCell)
sheet_writable.addCell(reqPayloadCell)
sheet_writable.addCell(responseCell)
sheet_writable.addCell(statusCell)
sheet_writable.addCell(reasonCell)
(0..context.testCase.testStepCount-1).each{
    def step = context.testCase.testStepList[it]
    if ( step instanceof WsdlTestRequestStep) {
        jxl.write.Label stepName =  new jxl.write.Label(0,i ,step.name)
        sheet_writable.addCell(stepName)
        def tr=testRunner.testCase.getTestStepByName(step.name)
          def String endPointUrl= tr.getHttpRequest().getResponse().getURL()
        jxl.write.Label reqUrl =  new jxl.write.Label(2,i ,endPointUrl)
        sheet_writable.addCell(reqUrl)
        def payload = context.expand(step.getPropertyValue('Request'))
        jxl.write.Label reqPayload =  new jxl.write.Label(3,i ,payload)
        sheet_writable.addCell(reqPayload)
         def response = context.expand(step.getPropertyValue('Response'))
        jxl.write.Label reqResponse =  new jxl.write.Label(4,i ,response)
        sheet_writable.addCell(reqResponse)
        count=count+1
        i=i+1
    }
}

(0..context.testCase.testStepCount-1).each{
    def step1 = context.testCase.testStepList[it]
    if ( step1 instanceof WsdlTestRequestStep) {
        for(j=1;j<no_of_rows;j++){
            Cell f=inputSheet.getCell(0,j)
             step_name=f.getContents()
             Cell f1=inputSheet.getCell(3,j)
             def String step_response=f1.getContents()
             step_response=step_response.replaceAll(" ","")
             def String response = context.expand(step1.getPropertyValue('Response')) 
             log.info response
             response=response.replaceAll(" ","") 
             /*if(step1.name==step_name&step1.name!=null){

             }*/

        }
    }
}
outputWB.write()
outputWB.close()
existingInputWB.close()

Данные для сравнения: я хочу игнорировать Auth при сравнении

<env:Envelope xmlns:env="http://www.w3.org/2003/05/soap-envelope">
<env:Header/>
<env:Body>
<ns3:ZeppEsCheckOnlCustIfResponse xmlns:ns3="urn:sap-com:document:sap:soap:functions:mc-style">
<Auth>36962796d68753535353f2a79637f536865636b6f6e6c636573747f213537353839303631393336353c745543545</Auth>
<number>224354</number>
<Ok>X</Ok>
<Failure/>
</ns3:abcd>
</env:Body>
</env:Envelope> 

1 Ответ

1 голос
/ 06 февраля 2020

Есть три основных способа сделать это.

1) Если вы хотите сравнить XML с XML, вы можете использовать библиотеку XMLUnit с Groovy. Я обнаружил, что это хрупко.

2) Вы также можете проанализировать ответ XML с помощью XMLSlurper Groovy и использовать GPath для перехода к указанным c элементам и получения их значений:

def responseXML = context.expand('${mySoapRequestStep#Response}')
def Envelope = new XmlSlurper().parseText(responseXML)
log.info Envelope.Body.someNode.nodeIWantValueFor

3) Третий вариант - создать шаг передачи свойства после шага SOAP Запрос и использовать XPath для сохранения значения в свойстве. Выражение XPath, которое вы используете в этом шаге, имеет следующий формат:

//*[local-name()='someNode']/*[local-name()='nodeIWantValueFor']/text()

На шаге передачи свойства вы указываете, где сохранено значение, например, в testCaseProperty, называемом nodeIWantValueFor.

...