workflow_tests: preserve response of webservice assertion on test duplication (#88729)
gitea/wcs/pipeline/head There was a failure building this commit
Details
gitea/wcs/pipeline/head There was a failure building this commit
Details
This commit is contained in:
parent
d0358afa40
commit
de4998e4e3
|
@ -1167,6 +1167,11 @@ def test_tests_duplicate(pub):
|
|||
response.name = 'Response xxx'
|
||||
response.store()
|
||||
|
||||
testdef.workflow_tests.actions.append(
|
||||
workflow_tests.AssertWebserviceCall(id='3', webservice_response_uuid=response.uuid),
|
||||
)
|
||||
testdef.store()
|
||||
|
||||
app = login(get_app(pub))
|
||||
|
||||
assert TestDef.count() == 1
|
||||
|
@ -1196,6 +1201,8 @@ def test_tests_duplicate(pub):
|
|||
assert testdef2.workflow_tests.actions[0].button_name == 'Go to end status'
|
||||
assert testdef1.get_webservice_responses()[0].name == 'Changed'
|
||||
assert testdef2.get_webservice_responses()[0].name == 'Response xxx'
|
||||
assert testdef1.workflow_tests.actions[2].details_label == 'Changed'
|
||||
assert testdef2.workflow_tests.actions[2].details_label == 'Response xxx'
|
||||
|
||||
resp = app.get('/backoffice/forms/1/tests/%s/' % testdef.id)
|
||||
resp = resp.click('Duplicate')
|
||||
|
|
|
@ -21,6 +21,7 @@ import io
|
|||
import json
|
||||
import socket
|
||||
import urllib.parse
|
||||
import uuid
|
||||
import xml.etree.ElementTree as ET
|
||||
from contextlib import contextmanager
|
||||
|
||||
|
@ -75,8 +76,8 @@ class TestDefXmlProxy(XmlStorableObject):
|
|||
}
|
||||
excluded_fields = ['id', 'object_type', 'object_id']
|
||||
extra_fields = [
|
||||
('workflow_tests', 'workflow_tests'),
|
||||
('_webservice_responses', 'webservice_responses'),
|
||||
('workflow_tests', 'workflow_tests'),
|
||||
]
|
||||
|
||||
return [
|
||||
|
@ -674,6 +675,7 @@ class WebserviceResponse(XmlStorableObject):
|
|||
_names = 'webservice-response'
|
||||
xml_root_node = 'webservice-response'
|
||||
|
||||
uuid = None
|
||||
testdef_id = None
|
||||
name = ''
|
||||
payload = None
|
||||
|
@ -684,6 +686,7 @@ class WebserviceResponse(XmlStorableObject):
|
|||
post_data = None
|
||||
|
||||
XML_NODES = [
|
||||
('uuid', 'str'),
|
||||
('testdef_id', 'int'),
|
||||
('name', 'str'),
|
||||
('payload', 'str'),
|
||||
|
@ -694,6 +697,10 @@ class WebserviceResponse(XmlStorableObject):
|
|||
('post_data', 'kv_data'),
|
||||
]
|
||||
|
||||
def __init__(self, **kwargs):
|
||||
super().__init__(**kwargs)
|
||||
self.uuid = str(uuid.uuid4())
|
||||
|
||||
def __str__(self):
|
||||
return self.name
|
||||
|
||||
|
|
|
@ -661,20 +661,22 @@ class AssertWebserviceCall(WorkflowTestAction):
|
|||
label = _('Assert webservice call')
|
||||
|
||||
key = 'assert-webservice-call'
|
||||
webservice_response_id = None
|
||||
webservice_response_uuid = None
|
||||
call_count = 1
|
||||
|
||||
optional_fields = ['call_count']
|
||||
|
||||
XML_NODES = WorkflowTestAction.XML_NODES + [
|
||||
('webservice_response_id', 'str'),
|
||||
('webservice_response_uuid', 'str'),
|
||||
('call_count', 'int'),
|
||||
]
|
||||
|
||||
@property
|
||||
def details_label(self):
|
||||
webservice_responses = [
|
||||
x for x in self.parent.testdef.get_webservice_responses() if x.id == self.webservice_response_id
|
||||
x
|
||||
for x in self.parent.testdef.get_webservice_responses()
|
||||
if x.uuid == self.webservice_response_uuid
|
||||
]
|
||||
if webservice_responses:
|
||||
return webservice_responses[0].name
|
||||
|
@ -694,13 +696,17 @@ class AssertWebserviceCall(WorkflowTestAction):
|
|||
|
||||
def perform(self, formdata):
|
||||
try:
|
||||
response = WebserviceResponse.get(self.webservice_response_id)
|
||||
webservice_response = [
|
||||
x
|
||||
for x in self.parent.testdef.get_webservice_responses()
|
||||
if x.uuid == self.webservice_response_uuid
|
||||
][0]
|
||||
except KeyError:
|
||||
raise WorkflowTestError(_('Broken, missing webservice response'))
|
||||
|
||||
call_count = 0
|
||||
for used_response in formdata.used_webservice_responses.copy():
|
||||
if used_response.id == self.webservice_response_id:
|
||||
if used_response.uuid == self.webservice_response_uuid:
|
||||
formdata.used_webservice_responses.remove(used_response)
|
||||
call_count += 1
|
||||
|
||||
|
@ -712,7 +718,7 @@ class AssertWebserviceCall(WorkflowTestAction):
|
|||
|
||||
def fill_admin_form(self, form, formdef):
|
||||
webservice_response_options = [
|
||||
(response.id, response.name, response.id)
|
||||
(response.uuid, response.name, response.uuid)
|
||||
for response in self.parent.testdef.get_webservice_responses()
|
||||
]
|
||||
|
||||
|
@ -721,11 +727,11 @@ class AssertWebserviceCall(WorkflowTestAction):
|
|||
|
||||
form.add(
|
||||
SingleSelectWidget,
|
||||
'webservice_response_id',
|
||||
'webservice_response_uuid',
|
||||
title=_('Webservice response'),
|
||||
options=webservice_response_options,
|
||||
required=True,
|
||||
value=self.webservice_response_id,
|
||||
value=self.webservice_response_uuid,
|
||||
)
|
||||
form.add(IntWidget, 'call_count', title=_('Call count'), required=True, value=self.call_count)
|
||||
|
||||
|
|
Loading…
Reference in New Issue