Merge pull request #18690 from edx/awais/lett_2_bc_discussion_components

discussion component bokchoy tests
This commit is contained in:
Agha Awais
2018-08-01 16:44:54 +05:00
committed by GitHub
3 changed files with 112 additions and 0 deletions

View File

@@ -197,6 +197,15 @@ class ContainerPage(PageObject, HelpMixin):
confirm_prompt(self)
self.wait_for_ajax()
@property
def xblock_titles(self):
"""
Get titles of x-block present on the page.
Returns:
list: A list of X-block titles
"""
return self.q(css='.wrapper-xblock .level-element .header-details').text
@property
def is_staff_locked(self):
""" Returns True if staff lock is currently enabled, False otherwise """

View File

@@ -0,0 +1,33 @@
"""
Discussion component editor in studio
"""
from common.test.acceptance.pages.studio.xblock_editor import XBlockEditorView
from common.test.acceptance.pages.common.utils import click_css
class DiscussionComponentEditor(XBlockEditorView):
"""
Discussion Editor view in studio
"""
@property
def edit_discussion_field_values(self):
"""
Get field values of discussion edit dialogue.
Returns:
list: A list of string indicating field values
"""
return self.q(css='.field-data-control').attrs('value')
def set_field_val(self, field_display_name, field_value):
"""
If editing, set the value of a field.
"""
selector = '.xblock-studio_view li.field label:contains("{}") + input'.format(field_display_name)
script = "$(arguments[0]).val(arguments[1]).change();"
self.browser.execute_script(script, selector, field_value)
def save(self):
"""
Clicks save button.
"""
click_css(self, '.save-button')

View File

@@ -0,0 +1,70 @@
"""
Acceptance tests for discussion component in studio
"""
from common.test.acceptance.tests.studio.base_studio_test import ContainerBase
from common.test.acceptance.fixtures.course import XBlockFixtureDesc
from common.test.acceptance.pages.studio.container import ContainerPage
from common.test.acceptance.pages.studio.utils import add_component
from common.test.acceptance.pages.studio.discussion_component_editor import DiscussionComponentEditor
class DiscussionComponentTest(ContainerBase):
"""
Feature: CMS.Component Adding
As a course author, I want to be able to add and edit Discussion component
"""
def setUp(self, is_staff=True):
"""
Create a course with a section, subsection, and unit to which to add the component.
"""
super(DiscussionComponentTest, self).setUp(is_staff=is_staff)
self.component = 'discussion'
self.unit = self.go_to_unit_page()
self.container_page = ContainerPage(self.browser, None)
# Add Discussion component
add_component(self.container_page, 'discussion', self.component)
self.component = self.unit.xblocks[1]
self.container_page.edit()
self.discussion_editor = DiscussionComponentEditor(self.browser, self.component.locator)
def populate_course_fixture(self, course_fixture):
"""
Adds a course fixture
"""
course_fixture.add_children(
XBlockFixtureDesc('chapter', 'Test Section').add_children(
XBlockFixtureDesc('sequential', 'Test Subsection').add_children(
XBlockFixtureDesc('vertical', 'Test Unit')
)
)
)
def test_view_discussion_component_metadata(self):
"""
Scenario: Staff user can view discussion component metadata
Given I am in Studio and I have added a Discussion component
When I edit Discussion component
Then I see three settings and their expected values
"""
field_values = self.discussion_editor.edit_discussion_field_values
self.assertEqual(
field_values,
['Discussion', 'Week 1', 'Topic-Level Student-Visible Label']
)
def test_edit_discussion_component(self):
"""
Scenario: Staff user can modify display name
Given I am in Studio and I have added a Discussion component
When I open Discussion component's edit dialogue
Then I can modify the display name
And My display name change is persisted on save
"""
field_name = 'Display Name'
new_name = 'Test Name'
self.discussion_editor.set_field_val(field_name, new_name)
self.discussion_editor.save()
component_name = self.unit.xblock_titles[0]
self.assertEqual(component_name, new_name)