49 lines
2.0 KiB
Python
49 lines
2.0 KiB
Python
from unittest.mock import patch
|
|
|
|
from tests.base_test import BaseTest
|
|
|
|
from crc import session, app
|
|
from crc.models.study import StudyModel
|
|
from crc.services.study_service import StudyService
|
|
from crc.services.workflow_processor import WorkflowProcessor
|
|
from crc.services.workflow_service import WorkflowService
|
|
|
|
class TestSudySponsorsScript(BaseTest):
|
|
test_uid = "dhf8r"
|
|
test_study_id = 1
|
|
|
|
|
|
@patch('crc.services.protocol_builder.requests.get')
|
|
def test_study_sponsors_script_validation(self, mock_get):
|
|
mock_get.return_value.ok = True
|
|
mock_get.return_value.text = self.protocol_builder_response('sponsors.json')
|
|
app.config['PB_ENABLED'] = True
|
|
|
|
self.load_example_data() # study_info script complains if irb_documents.xls is not loaded
|
|
# during the validate phase I'm going to assume that we will never
|
|
# have a case where irb_documents.xls is not loaded ??
|
|
|
|
self.load_test_spec("study_sponsors")
|
|
WorkflowService.test_spec("study_sponsors") # This would raise errors if it didn't validate
|
|
|
|
|
|
@patch('crc.services.protocol_builder.requests.get')
|
|
def test_study_sponsors_script(self, mock_get):
|
|
|
|
mock_get.return_value.ok = True
|
|
mock_get.return_value.text = self.protocol_builder_response('sponsors.json')
|
|
app.config['PB_ENABLED'] = True
|
|
|
|
self.load_example_data()
|
|
self.create_reference_document()
|
|
study = session.query(StudyModel).first()
|
|
workflow_spec_model = self.load_test_spec("study_sponsors")
|
|
workflow_model = StudyService._create_workflow_model(study, workflow_spec_model)
|
|
WorkflowService.test_spec("study_sponsors")
|
|
processor = WorkflowProcessor(workflow_model)
|
|
processor.do_engine_steps()
|
|
self.assertTrue(processor.bpmn_workflow.is_completed())
|
|
data = processor.next_task().data
|
|
self.assertIn('sponsors', data)
|
|
self.assertEqual(3, len(data['sponsors']))
|