save a process model file after running all validations w/ burnettk

This commit is contained in:
jasquat 2023-01-10 14:13:06 -05:00
parent e97bf81e5c
commit 0fe537e84f
2 changed files with 41 additions and 15 deletions

View File

@ -80,9 +80,22 @@ class SpecFileService(FileSystemService):
) )
return references return references
@staticmethod @classmethod
def get_references_for_file( def get_references_for_file(
file: File, process_model_info: ProcessModelInfo cls, file: File, process_model_info: ProcessModelInfo
) -> list[SpecReference]:
"""Get_references_for_file."""
full_file_path = SpecFileService.full_file_path(process_model_info, file.name)
file_contents: bytes = b""
with open(full_file_path) as f:
file_contents = f.read().encode()
return cls.get_references_for_file_contents(
process_model_info, file.name, file_contents
)
@classmethod
def get_references_for_file_contents(
cls, process_model_info: ProcessModelInfo, file_name: str, binary_data: bytes
) -> list[SpecReference]: ) -> list[SpecReference]:
"""Uses spiffworkflow to parse BPMN and DMN files to determine how they can be externally referenced. """Uses spiffworkflow to parse BPMN and DMN files to determine how they can be externally referenced.
@ -93,8 +106,8 @@ class SpecFileService(FileSystemService):
type = {str} 'process' / 'decision' type = {str} 'process' / 'decision'
""" """
references: list[SpecReference] = [] references: list[SpecReference] = []
full_file_path = SpecFileService.full_file_path(process_model_info, file.name) file_path = os.path.join(process_model_info.id_for_file_path(), file_name)
file_path = os.path.join(process_model_info.id_for_file_path(), file.name) file_type = FileSystemService.file_type(file_name)
parser = MyCustomParser() parser = MyCustomParser()
parser_type = None parser_type = None
sub_parser = None sub_parser = None
@ -104,14 +117,14 @@ class SpecFileService(FileSystemService):
messages = {} messages = {}
correlations = {} correlations = {}
start_messages = [] start_messages = []
if file.type == FileType.bpmn.value: if file_type.value == FileType.bpmn.value:
parser.add_bpmn_file(full_file_path) parser.add_bpmn_xml(etree.fromstring(binary_data))
parser_type = "process" parser_type = "process"
sub_parsers = list(parser.process_parsers.values()) sub_parsers = list(parser.process_parsers.values())
messages = parser.messages messages = parser.messages
correlations = parser.correlations correlations = parser.correlations
elif file.type == FileType.dmn.value: elif file_type.value == FileType.dmn.value:
parser.add_dmn_file(full_file_path) parser.add_dmn_xml(etree.fromstring(binary_data))
sub_parsers = list(parser.dmn_parsers.values()) sub_parsers = list(parser.dmn_parsers.values())
parser_type = "decision" parser_type = "decision"
else: else:
@ -131,7 +144,7 @@ class SpecFileService(FileSystemService):
display_name=sub_parser.get_name(), display_name=sub_parser.get_name(),
process_model_id=process_model_info.id, process_model_id=process_model_info.id,
type=parser_type, type=parser_type,
file_name=file.name, file_name=file_name,
relative_path=file_path, relative_path=file_path,
has_lanes=has_lanes, has_lanes=has_lanes,
is_executable=is_executable, is_executable=is_executable,
@ -172,17 +185,15 @@ class SpecFileService(FileSystemService):
"""Update_file.""" """Update_file."""
SpecFileService.assert_valid_file_name(file_name) SpecFileService.assert_valid_file_name(file_name)
cls.validate_bpmn_xml(file_name, binary_data) cls.validate_bpmn_xml(file_name, binary_data)
full_file_path = SpecFileService.full_file_path(process_model_info, file_name)
SpecFileService.write_file_data_to_system(full_file_path, binary_data)
file = SpecFileService.to_file_object(file_name, full_file_path)
references = SpecFileService.get_references_for_file(file, process_model_info) references = cls.get_references_for_file_contents(
process_model_info, file_name, binary_data
)
primary_process_ref = next( primary_process_ref = next(
(ref for ref in references if ref.is_primary and ref.is_executable), None (ref for ref in references if ref.is_primary and ref.is_executable), None
) )
SpecFileService.clear_caches_for_file(file_name, process_model_info) SpecFileService.clear_caches_for_file(file_name, process_model_info)
for ref in references: for ref in references:
# If no valid primary process is defined, default to the first process in the # If no valid primary process is defined, default to the first process in the
# updated file. # updated file.
@ -203,7 +214,11 @@ class SpecFileService(FileSystemService):
update_hash, update_hash,
) )
SpecFileService.update_caches(ref) SpecFileService.update_caches(ref)
return file
# make sure we save the file as the last thing we do to ensure validations have run
full_file_path = SpecFileService.full_file_path(process_model_info, file_name)
SpecFileService.write_file_data_to_system(full_file_path, binary_data)
return SpecFileService.to_file_object(file_name, full_file_path)
@staticmethod @staticmethod
def get_data(process_model_info: ProcessModelInfo, file_name: str) -> bytes: def get_data(process_model_info: ProcessModelInfo, file_name: str) -> bytes:

View File

@ -87,6 +87,14 @@ class TestSpecFileService(BaseTest):
in str(exception.value) in str(exception.value)
) )
process_model = ProcessModelService.get_process_model(
"call_activity_nested_duplicate"
)
full_file_path = SpecFileService.full_file_path(
process_model, "call_activity_nested_duplicate.bpmn"
)
assert not os.path.isfile(full_file_path)
def test_updates_relative_file_path_when_appropriate( def test_updates_relative_file_path_when_appropriate(
self, self,
app: Flask, app: Flask,
@ -225,3 +233,6 @@ class TestSpecFileService(BaseTest):
SpecFileService.update_file( SpecFileService.update_file(
process_model, "bad_xml.bpmn", b"THIS_IS_NOT_VALID_XML" process_model, "bad_xml.bpmn", b"THIS_IS_NOT_VALID_XML"
) )
full_file_path = SpecFileService.full_file_path(process_model, "bad_xml.bpmn")
assert not os.path.isfile(full_file_path)