2022-10-25 14:44:28 +02:00
|
|
|
import steps.startupSteps as init_steps
|
2022-07-18 16:56:33 -04:00
|
|
|
from screens.StatusMainScreen import StatusMainScreen
|
|
|
|
from screens.StatusCommunityPortalScreen import StatusCommunityPortalScreen
|
|
|
|
from screens.StatusCommunityScreen import StatusCommunityScreen
|
|
|
|
|
2022-07-21 12:16:25 -04:00
|
|
|
_statusCommunityScreen = StatusCommunityScreen()
|
2022-07-18 16:56:33 -04:00
|
|
|
_statusCommunitityPortal = StatusCommunityPortalScreen()
|
|
|
|
_statusMainScreen = StatusMainScreen()
|
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
#########################
|
|
|
|
### PRECONDITIONS region:
|
|
|
|
#########################
|
|
|
|
@Given("the user opens the community portal section")
|
2022-07-18 16:56:33 -04:00
|
|
|
def step(context: any):
|
2022-10-25 14:44:28 +02:00
|
|
|
init_steps.the_user_opens_the_community_portal_section()
|
2022-07-18 16:56:33 -04:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@Given("the user lands on the community portal section")
|
2022-08-01 20:34:31 +02:00
|
|
|
def step(context):
|
2022-10-25 14:44:28 +02:00
|
|
|
init_steps.the_user_lands_on_the_community_portal_section()
|
|
|
|
|
|
|
|
@Given("the user creates a community named \"|any|\", with description \"|any|\", intro \"|any|\" and outro \"|any|\"")
|
|
|
|
def step(context: any, community_name: str, community_description: str, community_intro: str, community_outro: str):
|
|
|
|
the_user_creates_a_community(community_name, community_description, community_intro, community_outro)
|
|
|
|
|
|
|
|
@Given("the admin creates a community channel named \"|any|\", with description \"|any|\", with the method \"|any|\"")
|
|
|
|
def step(context, community_channel_name, community_channel_description, method):
|
|
|
|
the_admin_creates_a_community_channel(community_channel_name, community_channel_description, method)
|
|
|
|
|
|
|
|
@Given("the user lands on the community named \"|any|\"")
|
|
|
|
def step(context: any, community_name: str):
|
|
|
|
the_user_lands_on_the_community(community_name)
|
2022-10-21 09:17:48 +02:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@Given("the channel named \"|any|\" is open")
|
|
|
|
def step(context, community_channel_name):
|
|
|
|
the_channel_is_open(community_channel_name)
|
|
|
|
|
|
|
|
@Given("the channel count is |integer|")
|
|
|
|
def step(context, community_channel_count: int):
|
|
|
|
the_channel_count_is(community_channel_count)
|
|
|
|
|
|
|
|
@Given("the admin creates a community category named \"|any|\", with channels \"|any|\" and with the method \"|any|\"")
|
|
|
|
def step(context, category_name, channel_names, method):
|
|
|
|
the_admin_creates_a_community_category(category_name, channel_names, method)
|
|
|
|
|
|
|
|
@Given("the category named \"|any|\" contains channels \"|any|\"")
|
|
|
|
def step(context, category_name, channel_names):
|
|
|
|
the_category_contains_channels(category_name, channel_names)
|
2022-07-18 16:56:33 -04:00
|
|
|
|
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
#########################
|
|
|
|
### ACTIONS region:
|
|
|
|
#########################
|
2022-08-01 20:34:31 +02:00
|
|
|
|
2022-10-25 15:08:15 -04:00
|
|
|
@When("the user opens the community named \"|any|\"")
|
|
|
|
def step(context, community_name):
|
|
|
|
_statusMainScreen.click_community(community_name)
|
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@When("the user sends a test image in the current channel")
|
|
|
|
def step(context):
|
|
|
|
_statusCommunityScreen.send_test_image(context.userData["fixtures_root"], False, "")
|
|
|
|
|
|
|
|
@When("the user sends a test image in the current channel with message \"|any|\" with an image")
|
|
|
|
def step(context, message):
|
|
|
|
_statusCommunityScreen.send_test_image(context.userData["fixtures_root"], False, message)
|
|
|
|
|
|
|
|
@When("the user sends multiple test images in the current channel with message \"|any|\" with an image again")
|
|
|
|
def step(context, message):
|
|
|
|
_statusCommunityScreen.send_test_image(context.userData["fixtures_root"], True, message)
|
|
|
|
|
|
|
|
@When("the user pins the message at index |integer|")
|
|
|
|
def step(context, message_index: int):
|
|
|
|
_statusCommunityScreen.toggle_pin_message_at_index(message_index)
|
|
|
|
|
|
|
|
@When("the user unpins the message at index |integer|")
|
|
|
|
def step(context, message_index: int):
|
|
|
|
_statusCommunityScreen.toggle_pin_message_at_index(message_index)
|
|
|
|
|
|
|
|
@When("the user creates a community named \"|any|\", with description \"|any|\", intro \"|any|\" and outro \"|any|\"")
|
|
|
|
def step(context: any, community_name: str, community_description: str, community_intro: str, community_outro: str):
|
|
|
|
the_user_creates_a_community(community_name, community_description, community_intro, community_outro)
|
2022-10-21 09:17:48 +02:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@When("the admin creates a community channel named \"|any|\", with description \"|any|\", with the method \"|any|\"")
|
2022-07-25 16:30:34 -04:00
|
|
|
def step(context, community_channel_name, community_channel_description, method):
|
2022-10-25 14:44:28 +02:00
|
|
|
the_admin_creates_a_community_channel(community_channel_name, community_channel_description, method)
|
2022-08-01 20:34:31 +02:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@When("the admin edits the current community channel to the name \"|any|\"")
|
2022-08-03 16:16:43 -04:00
|
|
|
def step(context, new_community_channel_name):
|
2022-10-25 14:44:28 +02:00
|
|
|
_statusCommunityScreen.edit_community_channel(new_community_channel_name)
|
2022-08-03 16:16:43 -04:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@When("the admin creates a community category named \"|any|\", with channels \"|any|\" and with the method \"|any|\"")
|
|
|
|
def step(context, category_name, channel_names, method):
|
|
|
|
the_admin_creates_a_community_category(category_name, channel_names, method)
|
2022-08-18 16:36:38 +04:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@When("the admin renames the category \"|any|\" to \"|any|\" and toggles the channels \"|any|\"")
|
2022-08-18 16:36:38 +04:00
|
|
|
def step(context, community_category_name, new_community_category_name, community_channel_names):
|
2022-10-25 14:44:28 +02:00
|
|
|
_statusCommunityScreen.edit_community_category(community_category_name, new_community_category_name, community_channel_names)
|
2022-08-16 14:21:39 +04:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@When("the admin deletes category named \"|any|\"")
|
2022-08-16 23:39:32 +04:00
|
|
|
def step(context, community_category_name):
|
2022-10-25 14:44:28 +02:00
|
|
|
_statusCommunityScreen.delete_community_category(community_category_name)
|
|
|
|
|
|
|
|
@When("the admin renames the community to \"|any|\" and description to \"|any|\" and color to \"|any|\"")
|
2022-08-03 16:16:43 -04:00
|
|
|
def step(context, new_community_name, new_community_description, new_community_color):
|
|
|
|
_statusCommunityScreen.edit_community(new_community_name, new_community_description, new_community_color)
|
|
|
|
|
|
|
|
@When("the admin goes back to the community")
|
|
|
|
def step(context):
|
|
|
|
_statusCommunityScreen.go_back_to_community()
|
2022-10-25 14:44:28 +02:00
|
|
|
|
|
|
|
@When("the admin changes the current community channel emoji to \"|any|\"")
|
|
|
|
def step(context, emoji_description: str):
|
|
|
|
_statusCommunityScreen.search_and_change_community_channel_emoji(emoji_description)
|
2022-08-01 20:34:31 +02:00
|
|
|
|
|
|
|
@When("the admin deletes current channel")
|
|
|
|
def step(context):
|
|
|
|
_statusCommunityScreen.delete_current_community_channel()
|
|
|
|
|
2022-10-25 14:39:21 -04:00
|
|
|
@When("the admin invites the user named |any| to the community with message |any|")
|
|
|
|
def step(context, user_name, message):
|
|
|
|
_statusCommunityScreen.invite_user_to_community(user_name, message)
|
2022-08-11 14:24:49 +02:00
|
|
|
|
2022-10-25 15:08:15 -04:00
|
|
|
@When("the admin kicks the user named |any|")
|
|
|
|
def step(context, user_name):
|
|
|
|
_statusCommunityScreen.kick_member_from_community(user_name)
|
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
#########################
|
|
|
|
### VERIFICATIONS region:
|
|
|
|
#########################
|
2022-08-19 10:57:09 -04:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@Then("the user lands on the community named \"|any|\"")
|
|
|
|
def step(context: any, community_name: str):
|
|
|
|
the_user_lands_on_the_community(community_name)
|
2022-10-21 09:17:48 +02:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@Then("the channel named \"|any|\" is open")
|
|
|
|
def step(context, community_channel_name):
|
|
|
|
the_channel_is_open(community_channel_name)
|
2022-10-21 09:17:48 +02:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@Then("the amount of pinned messages is |integer|")
|
|
|
|
def step(context, amount: int):
|
|
|
|
_statusCommunityScreen.check_pin_count(amount)
|
2022-08-19 10:57:09 -04:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@Then("the channel count is |integer|")
|
|
|
|
def step(context, community_channel_count: int):
|
|
|
|
the_channel_count_is(community_channel_count)
|
2022-08-19 10:57:09 -04:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
@Then("the category named \"|any|\" contains channels \"|any|\"")
|
|
|
|
def step(context, category_name, channel_names):
|
|
|
|
the_category_contains_channels(category_name, channel_names)
|
|
|
|
|
|
|
|
@Then("the category named \"|any|\" is missing")
|
|
|
|
def step(context, category_name):
|
|
|
|
_statusCommunityScreen.verify_category_name_missing(category_name)
|
|
|
|
|
|
|
|
@Then("the community channel has emoji \"|any|\"")
|
|
|
|
def step(context, emoji: str):
|
|
|
|
_statusCommunityScreen.check_community_channel_emoji(emoji)
|
|
|
|
|
|
|
|
@Then("the count of communities in navbar is |integer|")
|
|
|
|
def step(context: any, expected_count: int):
|
|
|
|
_statusMainScreen.verify_communities_count(expected_count)
|
|
|
|
|
|
|
|
@Then("the last chat message contains the test image")
|
2022-08-19 10:57:09 -04:00
|
|
|
def step(context):
|
|
|
|
_statusCommunityScreen.verify_sent_test_image(False, False)
|
2022-10-25 14:44:28 +02:00
|
|
|
|
2022-08-19 10:57:09 -04:00
|
|
|
@Then("the test image is displayed just before the last message")
|
|
|
|
def step(context):
|
|
|
|
_statusCommunityScreen.verify_sent_test_image(False, True)
|
|
|
|
|
|
|
|
@Then("the test images are displayed just before the last message")
|
|
|
|
def step(context):
|
2022-10-25 14:44:28 +02:00
|
|
|
_statusCommunityScreen.verify_sent_test_image(True, True)
|
2022-08-22 17:12:35 -04:00
|
|
|
|
2022-10-25 15:08:15 -04:00
|
|
|
@Then("the number of members is |any|")
|
|
|
|
def step(context, amount):
|
|
|
|
_statusCommunityScreen.verify_number_of_members(amount)
|
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
###########################################################################
|
|
|
|
### COMMON methods used in different steps given/when/then region:
|
|
|
|
###########################################################################
|
2022-08-22 17:12:35 -04:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
def the_user_creates_a_community(name:str, description: str, intro:str, outro:str):
|
|
|
|
init_steps.the_user_creates_a_community(name, description, intro, outro)
|
|
|
|
|
|
|
|
def the_user_lands_on_the_community(name: str):
|
|
|
|
init_steps.the_user_lands_on_the_community(name)
|
|
|
|
|
|
|
|
def the_admin_creates_a_community_channel(name: str, description: str, method: str):
|
|
|
|
init_steps.the_admin_creates_a_community_channel(name, description, method)
|
2022-08-22 17:12:35 -04:00
|
|
|
|
2022-10-25 14:44:28 +02:00
|
|
|
def the_channel_is_open(name: str):
|
|
|
|
init_steps.the_channel_is_open(name)
|
|
|
|
|
|
|
|
def the_channel_count_is(community_channel_count: int):
|
|
|
|
_statusCommunityScreen.check_channel_count(community_channel_count)
|
|
|
|
|
|
|
|
def the_admin_creates_a_community_category(name: str, channels: str, method: str):
|
|
|
|
_statusCommunityScreen.create_community_category(name, channels, method)
|
|
|
|
|
|
|
|
def the_category_contains_channels(category_name: str, channels: str):
|
2022-10-25 14:39:21 -04:00
|
|
|
_statusCommunityScreen.verify_category_contains_channels(category_name, channels)
|