mirror of
https://github.com/status-im/spiff-arena.git
synced 2025-01-28 10:45:07 +00:00
492681e5de
10c443a2 Merge pull request #130 from sartography/feature/data 71c803aa allow passing in the log level into the app w/ burnettk daeb82d9 Merge pull request #126 from sartography/dependabot/pip/typing-extensions-4.4.0 14c8f52c Merge pull request #123 from sartography/dependabot/pip/dot-github/workflows/poetry-1.2.2 92d204e6 Merge remote-tracking branch 'origin/main' into feature/data 1cb77901 run the save all bpmn script on server boot w/ burnettk 16a6f476 Bump typing-extensions from 4.3.0 to 4.4.0 d8ac61fc Bump poetry from 1.2.1 to 1.2.2 in /.github/workflows 3be27786 Merge pull request #131 from sartography/feature/permissions2 1fd8fc78 Merge remote-tracking branch 'origin/main' into feature/permissions2 d29621ae data setup on app boot 0b21a5d4 refactor bin/save_all_bpmn.py into service code 02fb9d61 lint c95db461 refactor scripts 98628fc2 This caused a problem with scopes when token timed out. d8b2323b merged in main and resolved conflicts d01b4fc7 updated sentry-sdk to resolve deprecation warnings 5851ddf5 update for mypy in python 3.9 508f9900 merged in main and resolved conflicts 68d69978 precommit w/ burnettk 85a4ee16 removed debug print statements w/ burnettk 93eb91f4 added keycloak configs and user perms for staging w/ burnettk e4ded8fc added method to import permissions from yml file w/ burnettk 22ba89ae use percents instead of asterisks to better support db syntax w/ burnettk 0c116ae8 postgres does not use backticks w/ burnettk 621ad3ef attempting to see if sql like statement works in other dbs as well w/ burnettk git-subtree-dir: spiffworkflow-backend git-subtree-split: 10c443a2d82752e8ed9d1679afe6409d81029006
109 lines
3.8 KiB
Python
109 lines
3.8 KiB
Python
"""Grabs tickets from csv and makes process instances."""
|
|
import csv
|
|
|
|
from flask_bpmn.models.db import db
|
|
|
|
from spiffworkflow_backend import get_hacked_up_app_for_script
|
|
from spiffworkflow_backend.models.process_instance import ProcessInstanceModel
|
|
from spiffworkflow_backend.models.user import UserModel
|
|
from spiffworkflow_backend.services.process_instance_processor import (
|
|
ProcessInstanceProcessor,
|
|
)
|
|
from spiffworkflow_backend.services.process_instance_service import (
|
|
ProcessInstanceService,
|
|
)
|
|
|
|
|
|
def print_process_instance_count(process_model_identifier_ticket: str) -> None:
|
|
"""Print process instance count."""
|
|
process_instances = ProcessInstanceModel.query.filter_by(
|
|
process_model_identifier=process_model_identifier_ticket
|
|
).all()
|
|
process_instance_count = len(process_instances)
|
|
print(f"process_instance_count: {process_instance_count}")
|
|
|
|
|
|
def main():
|
|
"""Main."""
|
|
app = get_hacked_up_app_for_script()
|
|
with app.app_context():
|
|
|
|
process_model_identifier_ticket = "ticket"
|
|
db.session.query(ProcessInstanceModel).filter(
|
|
ProcessInstanceModel.process_model_identifier
|
|
== process_model_identifier_ticket
|
|
).delete()
|
|
db.session.commit()
|
|
|
|
"""Print process instance count."""
|
|
process_instances = ProcessInstanceModel.query.filter_by(
|
|
process_model_identifier=process_model_identifier_ticket
|
|
).all()
|
|
process_instance_count = len(process_instances)
|
|
print(f"process_instance_count: {process_instance_count}")
|
|
|
|
columns_to_data_key_mappings = {
|
|
"Month": "month",
|
|
"MS": "milestone",
|
|
"ID": "req_id",
|
|
"Dev Days": "dev_days",
|
|
"Feature": "feature",
|
|
"Priority": "priority",
|
|
}
|
|
columns_to_header_index_mappings = {}
|
|
|
|
user = UserModel.query.first()
|
|
|
|
with open("tests/files/tickets.csv") as infile:
|
|
reader = csv.reader(infile, delimiter=",")
|
|
|
|
# first row is garbage
|
|
next(reader)
|
|
|
|
header = next(reader)
|
|
for column_name in columns_to_data_key_mappings:
|
|
columns_to_header_index_mappings[column_name] = header.index(
|
|
column_name
|
|
)
|
|
id_index = header.index("ID")
|
|
priority_index = header.index("Priority")
|
|
print(f"header: {header}")
|
|
for row in reader:
|
|
ticket_identifier = row[id_index]
|
|
priority = row[priority_index]
|
|
print(f"ticket_identifier: {ticket_identifier}")
|
|
print(f"priority: {priority}")
|
|
|
|
process_instance = ProcessInstanceService.create_process_instance(
|
|
process_model_identifier_ticket,
|
|
user,
|
|
process_group_identifier="sartography-admin",
|
|
)
|
|
processor = ProcessInstanceProcessor(process_instance)
|
|
|
|
processor.do_engine_steps()
|
|
# processor.save()
|
|
|
|
for (
|
|
column_name,
|
|
desired_data_key,
|
|
) in columns_to_data_key_mappings.items():
|
|
appropriate_index = columns_to_header_index_mappings[column_name]
|
|
processor.bpmn_process_instance.data[desired_data_key] = row[
|
|
appropriate_index
|
|
]
|
|
|
|
print(f"datas: {processor.bpmn_process_instance.data}")
|
|
if processor.bpmn_process_instance.data["month"] == "":
|
|
continue
|
|
|
|
# you at least need a month, or else this row in the csv is considered garbage
|
|
# if processor.bpmn_process_instance.data["month"] is None:
|
|
# continue
|
|
|
|
processor.save()
|
|
|
|
|
|
# if __name__ == "__main__":
|
|
main()
|