mirror of
https://github.com/status-im/spiff-arena.git
synced 2025-01-16 21:24:19 +00:00
Merge pull request #11 from sartography/feature/add_script_to_get_frontend_url
added script to get the frontend url w/ burnettk
This commit is contained in:
commit
17eba4cfd5
@ -0,0 +1,25 @@
|
|||||||
|
"""Get_env."""
|
||||||
|
from typing import Any
|
||||||
|
from flask import current_app
|
||||||
|
|
||||||
|
from spiffworkflow_backend.models.script_attributes_context import (
|
||||||
|
ScriptAttributesContext,
|
||||||
|
)
|
||||||
|
from spiffworkflow_backend.scripts.script import Script
|
||||||
|
|
||||||
|
|
||||||
|
class GetFrontendUrl(Script):
|
||||||
|
"""GetFrontendUrl."""
|
||||||
|
|
||||||
|
def get_description(self) -> str:
|
||||||
|
"""Get_description."""
|
||||||
|
return """Return the url to the frontend."""
|
||||||
|
|
||||||
|
def run(
|
||||||
|
self,
|
||||||
|
script_attributes_context: ScriptAttributesContext,
|
||||||
|
*args: Any,
|
||||||
|
**kwargs: Any
|
||||||
|
) -> Any:
|
||||||
|
"""Run."""
|
||||||
|
return current_app.config['SPIFFWORKFLOW_FRONTEND_URL']
|
@ -1,7 +1,8 @@
|
|||||||
"""Get_env."""
|
"""Get_env."""
|
||||||
from typing import Any
|
from typing import Any
|
||||||
from spiffworkflow_backend.models.group import GroupModel, GroupNotFoundError
|
|
||||||
|
|
||||||
|
from spiffworkflow_backend.models.group import GroupModel
|
||||||
|
from spiffworkflow_backend.models.group import GroupNotFoundError
|
||||||
from spiffworkflow_backend.models.script_attributes_context import (
|
from spiffworkflow_backend.models.script_attributes_context import (
|
||||||
ScriptAttributesContext,
|
ScriptAttributesContext,
|
||||||
)
|
)
|
||||||
@ -19,14 +20,15 @@ class GetGroupMembers(Script):
|
|||||||
self,
|
self,
|
||||||
script_attributes_context: ScriptAttributesContext,
|
script_attributes_context: ScriptAttributesContext,
|
||||||
*args: Any,
|
*args: Any,
|
||||||
**kwargs: Any
|
**kwargs: Any,
|
||||||
) -> Any:
|
) -> Any:
|
||||||
"""Run."""
|
"""Run."""
|
||||||
group_identifier = args[0]
|
group_identifier = args[0]
|
||||||
group = GroupModel.query.filter_by(identifier=group_identifier).first()
|
group = GroupModel.query.filter_by(identifier=group_identifier).first()
|
||||||
if group is None:
|
if group is None:
|
||||||
raise GroupNotFoundError(
|
raise GroupNotFoundError(
|
||||||
f"Script 'get_group_members' could not find group with identifier '{group_identifier}'.")
|
f"Script 'get_group_members' could not find group with identifier '{group_identifier}'."
|
||||||
|
)
|
||||||
|
|
||||||
usernames = [u.username for u in group.users]
|
usernames = [u.username for u in group.users]
|
||||||
return usernames
|
return usernames
|
||||||
|
@ -1,15 +1,14 @@
|
|||||||
"""Test_get_localtime."""
|
"""Test_get_localtime."""
|
||||||
from spiffworkflow_backend.services.user_service import UserService
|
|
||||||
from flask_bpmn.models.db import db
|
|
||||||
from spiffworkflow_backend.models.group import GroupModel
|
|
||||||
|
|
||||||
from flask.app import Flask
|
from flask.app import Flask
|
||||||
|
from flask_bpmn.models.db import db
|
||||||
from tests.spiffworkflow_backend.helpers.base_test import BaseTest
|
from tests.spiffworkflow_backend.helpers.base_test import BaseTest
|
||||||
from tests.spiffworkflow_backend.helpers.test_data import load_test_spec
|
from tests.spiffworkflow_backend.helpers.test_data import load_test_spec
|
||||||
|
|
||||||
|
from spiffworkflow_backend.models.group import GroupModel
|
||||||
from spiffworkflow_backend.services.process_instance_processor import (
|
from spiffworkflow_backend.services.process_instance_processor import (
|
||||||
ProcessInstanceProcessor,
|
ProcessInstanceProcessor,
|
||||||
)
|
)
|
||||||
|
from spiffworkflow_backend.services.user_service import UserService
|
||||||
|
|
||||||
|
|
||||||
class TestGetGroupMembers(BaseTest):
|
class TestGetGroupMembers(BaseTest):
|
||||||
@ -25,18 +24,19 @@ class TestGetGroupMembers(BaseTest):
|
|||||||
testuser1 = self.find_or_create_user("testuser1")
|
testuser1 = self.find_or_create_user("testuser1")
|
||||||
testuser2 = self.find_or_create_user("testuser2")
|
testuser2 = self.find_or_create_user("testuser2")
|
||||||
testuser3 = self.find_or_create_user("testuser3")
|
testuser3 = self.find_or_create_user("testuser3")
|
||||||
groupA = GroupModel(identifier="groupA")
|
group_a = GroupModel(identifier="groupA")
|
||||||
groupB = GroupModel(identifier="groupB")
|
group_b = GroupModel(identifier="groupB")
|
||||||
db.session.add(groupA)
|
db.session.add(group_a)
|
||||||
db.session.add(groupB)
|
db.session.add(group_b)
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
|
|
||||||
UserService.add_user_to_group(testuser1, groupA)
|
UserService.add_user_to_group(testuser1, group_a)
|
||||||
UserService.add_user_to_group(testuser2, groupA)
|
UserService.add_user_to_group(testuser2, group_a)
|
||||||
UserService.add_user_to_group(testuser3, groupB)
|
UserService.add_user_to_group(testuser3, group_b)
|
||||||
|
|
||||||
process_model = load_test_spec(
|
process_model = load_test_spec(
|
||||||
process_model_id="get_group_members", bpmn_file_name="get_group_members.bpmn"
|
process_model_id="get_group_members",
|
||||||
|
bpmn_file_name="get_group_members.bpmn",
|
||||||
)
|
)
|
||||||
process_instance = self.create_process_instance_from_process_model(
|
process_instance = self.create_process_instance_from_process_model(
|
||||||
process_model=process_model, user=initiator_user
|
process_model=process_model, user=initiator_user
|
||||||
@ -45,5 +45,8 @@ class TestGetGroupMembers(BaseTest):
|
|||||||
processor.do_engine_steps(save=True)
|
processor.do_engine_steps(save=True)
|
||||||
|
|
||||||
assert processor.bpmn_process_instance.data
|
assert processor.bpmn_process_instance.data
|
||||||
assert processor.bpmn_process_instance.data['members_a'] == ['testuser1', 'testuser2']
|
assert processor.bpmn_process_instance.data["members_a"] == [
|
||||||
assert processor.bpmn_process_instance.data['members_b'] == ['testuser3']
|
"testuser1",
|
||||||
|
"testuser2",
|
||||||
|
]
|
||||||
|
assert processor.bpmn_process_instance.data["members_b"] == ["testuser3"]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user