Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
edx-platform
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
edx-platform
Commits
186b3bad
Commit
186b3bad
authored
Jun 17, 2016
by
Muddasser
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
course-settings.feature conversion to bokchoy
parent
26d49a75
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
360 additions
and
98 deletions
+360
-98
cms/djangoapps/contentstore/features/course-settings.feature
+0
-95
common/test/acceptance/pages/studio/settings.py
+45
-1
common/test/acceptance/pages/studio/utils.py
+11
-0
common/test/acceptance/tests/studio/test_studio_settings.py
+304
-2
No files found.
cms/djangoapps/contentstore/features/course-settings.feature
deleted
100644 → 0
View file @
26d49a75
@shard_2
Feature
:
CMS.Course Settings
As a course author, I want to be able to configure my course settings.
# Safari has trouble keeps dates on refresh
@skip_safari
Scenario
:
User can set course dates
Given
I have opened a new course in Studio
When
I select Schedule and Details
And
I set course dates
And
I press the
"Save"
notification button
And
I reload the page
Then
I see the set dates
# IE has trouble with saving information
@skip_internetexplorer
Scenario
:
User can clear previously set course dates (except start date)
Given
I have set course dates
And
I clear all the dates except start
And
I press the
"Save"
notification button
And
I reload the page
Then
I see cleared dates
# IE has trouble with saving information
@skip_internetexplorer
Scenario
:
User cannot clear the course start date
Given
I have set course dates
And
I press the
"Save"
notification button
And
I clear the course start date
Then
I receive a warning about course start date
And
I reload the page
And
the previously set start date is shown
# IE has trouble with saving information
# Safari gets CSRF token errors
@skip_internetexplorer
@skip_safari
Scenario
:
User can correct the course start date warning
Given
I have tried to clear the course start
And
I have entered a new course start date
And
I press the
"Save"
notification button
Then
The warning about course start date goes away
And
I reload the page
Then
my new course start date is shown
# Safari does not save + refresh properly through sauce labs
@skip_safari
Scenario
:
Settings are only persisted when saved
Given
I have set course dates
And
I press the
"Save"
notification button
When
I change fields
And
I reload the page
Then
I do not see the changes
# Safari does not save + refresh properly through sauce labs
@skip_safari
Scenario
:
Settings are reset on cancel
Given
I have set course dates
And
I press the
"Save"
notification button
When
I change fields
And
I press the
"Cancel"
notification button
Then
I do not see the changes
# Safari gets CSRF token errors
@skip_safari
Scenario
:
Confirmation is shown on save
Given
I have opened a new course in Studio
When
I select Schedule and Details
And
I change the
"<field>"
field to
"<value>"
And
I press the
"Save"
notification button
Then
I see a confirmation that my changes have been saved
# Lettuce hooks don't get called between each example, so we need
# to run the before.each_scenario hook manually to avoid database
# errors.
And
I reset the database
Examples
:
|
field
|
value
|
|
Course
Start
Time
|
11:00
|
|
Course
Introduction
Video
|
4r7wHMg5Yjg
|
|
Course
Effort
|
200:00
|
# Special case because we have to type in code mirror
Scenario
:
Changes in Course Overview show a confirmation
Given
I have opened a new course in Studio
When
I select Schedule and Details
And
I change the course overview
And
I press the
"Save"
notification button
Then
I see a confirmation that my changes have been saved
Scenario
:
User cannot save invalid settings
Given
I have opened a new course in Studio
When
I select Schedule and Details
And
I change the
"Course Start Date"
field to
""
Then
the save notification button is disabled
common/test/acceptance/pages/studio/settings.py
View file @
186b3bad
...
@@ -9,7 +9,10 @@ from bok_choy.javascript import requirejs
...
@@ -9,7 +9,10 @@ from bok_choy.javascript import requirejs
from
common.test.acceptance.pages.studio.course_page
import
CoursePage
from
common.test.acceptance.pages.studio.course_page
import
CoursePage
from
common.test.acceptance.pages.studio.users
import
wait_for_ajax_or_reload
from
common.test.acceptance.pages.studio.users
import
wait_for_ajax_or_reload
from
common.test.acceptance.pages.studio.utils
import
press_the_notification_button
from
common.test.acceptance.pages.studio.utils
import
(
press_the_notification_button
,
type_in_codemirror
)
@requirejs
(
'js/factories/settings'
)
@requirejs
(
'js/factories/settings'
)
...
@@ -70,6 +73,36 @@ class SettingsPage(CoursePage):
...
@@ -70,6 +73,36 @@ class SettingsPage(CoursePage):
results
=
self
.
get_elements
(
css_selector
=
css_selector
)
results
=
self
.
get_elements
(
css_selector
=
css_selector
)
return
results
[
0
]
if
results
else
None
return
results
[
0
]
if
results
else
None
def
set_element_values
(
self
,
element_values
):
"""
Set the values of the elements to those specified
in the element_values dict.
"""
for
css
,
value
in
element_values
.
iteritems
():
element
=
self
.
get_element
(
css
)
element
.
clear
()
element
.
send_keys
(
value
)
def
un_focus_input_field
(
self
):
"""
Makes an input field un-focus by
clicking outside of it.
"""
self
.
get_element
(
'.title-2'
)
.
click
()
def
is_element_present
(
self
,
css_selector
):
"""
Returns boolean based on the presence
of an element with css as passed.
"""
return
self
.
q
(
css
=
css_selector
)
.
present
def
change_course_description
(
self
,
change_text
):
"""
Changes the course description
"""
type_in_codemirror
(
self
,
0
,
change_text
,
find_prefix
=
"$"
)
################
################
# Properties
# Properties
################
################
...
@@ -208,6 +241,17 @@ class SettingsPage(CoursePage):
...
@@ -208,6 +241,17 @@ class SettingsPage(CoursePage):
# Clicks
# Clicks
################
################
def
click_button
(
self
,
name
):
"""
Clicks the button
"""
btn_css
=
'div#page-notification button.action-{}'
.
format
(
name
.
lower
())
EmptyPromise
(
lambda
:
self
.
q
(
css
=
btn_css
)
.
visible
,
'{} button is visible'
.
format
(
name
)
)
.
fulfill
()
press_the_notification_button
(
self
,
name
)
################
################
# Workflows
# Workflows
################
################
...
...
common/test/acceptance/pages/studio/utils.py
View file @
186b3bad
...
@@ -160,6 +160,17 @@ def get_codemirror_value(page, index=0, find_prefix="$"):
...
@@ -160,6 +160,17 @@ def get_codemirror_value(page, index=0, find_prefix="$"):
)
)
def
get_input_value
(
page
,
css_selector
):
"""
Returns the value of the field matching the css selector.
"""
page
.
wait_for_element_presence
(
css_selector
,
'Elements matching "{}" selector are present'
.
format
(
css_selector
)
)
return
page
.
q
(
css
=
css_selector
)
.
attrs
(
'value'
)[
0
]
def
set_input_value
(
page
,
css
,
value
):
def
set_input_value
(
page
,
css
,
value
):
"""
"""
Sets the text field with the given label (display name) to the specified value.
Sets the text field with the given label (display name) to the specified value.
...
...
common/test/acceptance/tests/studio/test_studio_settings.py
View file @
186b3bad
...
@@ -11,12 +11,13 @@ from nose.plugins.attrib import attr
...
@@ -11,12 +11,13 @@ from nose.plugins.attrib import attr
from
base_studio_test
import
StudioCourseTest
from
base_studio_test
import
StudioCourseTest
from
bok_choy.promise
import
EmptyPromise
from
bok_choy.promise
import
EmptyPromise
from
...fixtures.course
import
XBlockFixtureDesc
from
...fixtures.course
import
XBlockFixtureDesc
from
..helpers
import
create_user_partition_json
from
common.test.acceptance.tests.helpers
import
create_user_partition_json
,
element_has_text
from
...pages.studio.overview
import
CourseOutlinePage
from
...pages.studio.overview
import
CourseOutlinePage
from
...pages.studio.settings
import
SettingsPage
from
...pages.studio.settings
import
SettingsPage
from
...pages.studio.settings_advanced
import
AdvancedSettingsPage
from
...pages.studio.settings_advanced
import
AdvancedSettingsPage
from
...pages.studio.settings_group_configurations
import
GroupConfigurationsPage
from
...pages.studio.settings_group_configurations
import
GroupConfigurationsPage
from
...pages.lms.courseware
import
CoursewarePage
from
...pages.lms.courseware
import
CoursewarePage
from
common.test.acceptance.pages.studio.utils
import
get_input_value
from
textwrap
import
dedent
from
textwrap
import
dedent
from
xmodule.partitions.partitions
import
Group
from
xmodule.partitions.partitions
import
Group
...
@@ -588,7 +589,6 @@ class StudioSettingsImageUploadTest(StudioCourseTest):
...
@@ -588,7 +589,6 @@ class StudioSettingsImageUploadTest(StudioCourseTest):
super
(
StudioSettingsImageUploadTest
,
self
)
.
setUp
()
super
(
StudioSettingsImageUploadTest
,
self
)
.
setUp
()
self
.
settings_page
=
SettingsPage
(
self
.
browser
,
self
.
course_info
[
'org'
],
self
.
course_info
[
'number'
],
self
.
settings_page
=
SettingsPage
(
self
.
browser
,
self
.
course_info
[
'org'
],
self
.
course_info
[
'number'
],
self
.
course_info
[
'run'
])
self
.
course_info
[
'run'
])
# from nose.tools import set_trace; set_trace()
self
.
settings_page
.
visit
()
self
.
settings_page
.
visit
()
# Ensure jquery is loaded before running a jQuery
# Ensure jquery is loaded before running a jQuery
...
@@ -616,3 +616,305 @@ class StudioSettingsImageUploadTest(StudioCourseTest):
...
@@ -616,3 +616,305 @@ class StudioSettingsImageUploadTest(StudioCourseTest):
file_to_upload
=
'image.jpg'
file_to_upload
=
'image.jpg'
self
.
settings_page
.
upload_image
(
'#upload-video-thumbnail-image'
,
file_to_upload
)
self
.
settings_page
.
upload_image
(
'#upload-video-thumbnail-image'
,
file_to_upload
)
self
.
assertIn
(
file_to_upload
,
self
.
settings_page
.
get_uploaded_image_path
(
'#video-thumbnail-image'
))
self
.
assertIn
(
file_to_upload
,
self
.
settings_page
.
get_uploaded_image_path
(
'#video-thumbnail-image'
))
class
CourseSettingsTest
(
StudioCourseTest
):
"""
Class to test course settings.
"""
COURSE_START_DATE_CSS
=
"#course-start-date"
COURSE_END_DATE_CSS
=
"#course-end-date"
ENROLLMENT_START_DATE_CSS
=
"#course-enrollment-start-date"
ENROLLMENT_END_DATE_CSS
=
"#course-enrollment-end-date"
COURSE_START_TIME_CSS
=
"#course-start-time"
COURSE_END_TIME_CSS
=
"#course-end-time"
ENROLLMENT_START_TIME_CSS
=
"#course-enrollment-start-time"
ENROLLMENT_END_TIME_CSS
=
"#course-enrollment-end-time"
course_start_date
=
'12/20/2013'
course_end_date
=
'12/26/2013'
enrollment_start_date
=
'12/01/2013'
enrollment_end_date
=
'12/10/2013'
dummy_time
=
"15:30"
def
setUp
(
self
,
is_staff
=
False
,
test_xss
=
True
):
super
(
CourseSettingsTest
,
self
)
.
setUp
()
self
.
settings_page
=
SettingsPage
(
self
.
browser
,
self
.
course_info
[
'org'
],
self
.
course_info
[
'number'
],
self
.
course_info
[
'run'
]
)
# Before every test, make sure to visit the page first
self
.
settings_page
.
visit
()
self
.
ensure_input_fields_are_loaded
()
def
set_course_dates
(
self
):
"""
Set dates for the course.
"""
dates_dictionary
=
{
self
.
COURSE_START_DATE_CSS
:
self
.
course_start_date
,
self
.
COURSE_END_DATE_CSS
:
self
.
course_end_date
,
self
.
ENROLLMENT_START_DATE_CSS
:
self
.
enrollment_start_date
,
self
.
ENROLLMENT_END_DATE_CSS
:
self
.
enrollment_end_date
}
self
.
settings_page
.
set_element_values
(
dates_dictionary
)
def
ensure_input_fields_are_loaded
(
self
):
"""
Ensures values in input fields are loaded.
"""
EmptyPromise
(
lambda
:
self
.
settings_page
.
q
(
css
=
'#course-organization'
)
.
attrs
(
'value'
)[
0
],
"Waiting for input fields to be loaded"
)
.
fulfill
()
def
test_user_can_set_course_date
(
self
):
"""
Scenario: User can set course dates
Given I have opened a new course in Studio
When I select Schedule and Details
And I set course dates
And I press the "Save" notification button
And I reload the page
Then I see the set dates
"""
# Set dates
self
.
set_course_dates
()
# Set times
time_dictionary
=
{
self
.
COURSE_START_TIME_CSS
:
self
.
dummy_time
,
self
.
ENROLLMENT_END_TIME_CSS
:
self
.
dummy_time
}
self
.
settings_page
.
set_element_values
(
time_dictionary
)
# Save changes
self
.
settings_page
.
save_changes
()
self
.
settings_page
.
refresh_and_wait_for_load
()
self
.
ensure_input_fields_are_loaded
()
css_selectors
=
[
self
.
COURSE_START_DATE_CSS
,
self
.
COURSE_END_DATE_CSS
,
self
.
ENROLLMENT_START_DATE_CSS
,
self
.
ENROLLMENT_END_DATE_CSS
,
self
.
COURSE_START_TIME_CSS
,
self
.
ENROLLMENT_END_TIME_CSS
]
expected_values
=
[
self
.
course_start_date
,
self
.
course_end_date
,
self
.
enrollment_start_date
,
self
.
enrollment_end_date
,
self
.
dummy_time
,
self
.
dummy_time
]
# Assert changes have been persistent.
self
.
assertEqual
(
[
get_input_value
(
self
.
settings_page
,
css_selector
)
for
css_selector
in
css_selectors
],
expected_values
)
def
test_clear_previously_set_course_dates
(
self
):
"""
Scenario: User can clear previously set course dates (except start date)
Given I have set course dates
And I clear all the dates except start
And I press the "Save" notification button
And I reload the page
Then I see cleared dates
"""
# Set dates
self
.
set_course_dates
()
# Clear all dates except start date
values_to_set
=
{
self
.
COURSE_END_DATE_CSS
:
''
,
self
.
ENROLLMENT_START_DATE_CSS
:
''
,
self
.
ENROLLMENT_END_DATE_CSS
:
''
}
self
.
settings_page
.
set_element_values
(
values_to_set
)
# Save changes and refresh the page
self
.
settings_page
.
save_changes
()
self
.
settings_page
.
refresh_and_wait_for_load
()
self
.
ensure_input_fields_are_loaded
()
css_selectors
=
[
self
.
COURSE_START_DATE_CSS
,
self
.
COURSE_END_DATE_CSS
,
self
.
ENROLLMENT_START_DATE_CSS
,
self
.
ENROLLMENT_END_DATE_CSS
]
expected_values
=
[
self
.
course_start_date
,
''
,
''
,
''
]
# Assert changes have been persistent.
self
.
assertEqual
(
[
get_input_value
(
self
.
settings_page
,
css_selector
)
for
css_selector
in
css_selectors
],
expected_values
)
def
test_cannot_clear_the_course_start_date
(
self
):
"""
Scenario: User cannot clear the course start date
Given I have set course dates
And I press the "Save" notification button
And I clear the course start date
Then I receive a warning about course start date
And I reload the page
And the previously set start date is shown
"""
# Set dates
self
.
set_course_dates
()
# Save changes
self
.
settings_page
.
save_changes
()
# Get default start date
default_start_date
=
get_input_value
(
self
.
settings_page
,
self
.
COURSE_START_DATE_CSS
)
# Set course start date to empty
self
.
settings_page
.
set_element_values
({
self
.
COURSE_START_DATE_CSS
:
''
})
# Make sure error message is show with appropriate message
error_message_css
=
'.message-error'
self
.
settings_page
.
wait_for_element_presence
(
error_message_css
,
'Error message is present'
)
self
.
assertEqual
(
element_has_text
(
self
.
settings_page
,
error_message_css
,
"The course must have an assigned start date."
),
True
)
# Refresh the page and assert start date has not changed.
self
.
settings_page
.
refresh_and_wait_for_load
()
self
.
ensure_input_fields_are_loaded
()
self
.
assertEqual
(
get_input_value
(
self
.
settings_page
,
self
.
COURSE_START_DATE_CSS
),
default_start_date
)
def
test_user_can_correct_course_start_date_warning
(
self
):
"""
Scenario: User can correct the course start date warning
Given I have tried to clear the course start
And I have entered a new course start date
And I press the "Save" notification button
Then The warning about course start date goes away
And I reload the page
Then my new course start date is shown
"""
# Set course start date to empty
self
.
settings_page
.
set_element_values
({
self
.
COURSE_START_DATE_CSS
:
''
})
# Make sure we get error message
error_message_css
=
'.message-error'
self
.
settings_page
.
wait_for_element_presence
(
error_message_css
,
'Error message is present'
)
self
.
assertEqual
(
element_has_text
(
self
.
settings_page
,
error_message_css
,
"The course must have an assigned start date."
),
True
)
# Set new course start value
self
.
settings_page
.
set_element_values
({
self
.
COURSE_START_DATE_CSS
:
self
.
course_start_date
})
self
.
settings_page
.
un_focus_input_field
()
# Error message disappears
self
.
settings_page
.
wait_for_element_absence
(
error_message_css
,
'Error message is not present'
)
# Save the changes and refresh the page.
self
.
settings_page
.
save_changes
()
self
.
settings_page
.
refresh_and_wait_for_load
()
self
.
ensure_input_fields_are_loaded
()
# Assert changes are persistent.
self
.
assertEqual
(
get_input_value
(
self
.
settings_page
,
self
.
COURSE_START_DATE_CSS
),
self
.
course_start_date
)
def
test_settings_are_only_persisted_when_saved
(
self
):
"""
Scenario: Settings are only persisted when saved
Given I have set course dates
And I press the "Save" notification button
When I change fields
And I reload the page
Then I do not see the changes
"""
# Set course dates.
self
.
set_course_dates
()
# Save changes.
self
.
settings_page
.
save_changes
()
default_value_enrollment_start_date
=
get_input_value
(
self
.
settings_page
,
self
.
ENROLLMENT_START_TIME_CSS
)
# Set the value of enrollment start time and
# reload the page without saving.
self
.
settings_page
.
set_element_values
({
self
.
ENROLLMENT_START_TIME_CSS
:
self
.
dummy_time
})
self
.
settings_page
.
refresh_and_wait_for_load
()
self
.
ensure_input_fields_are_loaded
()
css_selectors
=
[
self
.
COURSE_START_DATE_CSS
,
self
.
COURSE_END_DATE_CSS
,
self
.
ENROLLMENT_START_DATE_CSS
,
self
.
ENROLLMENT_END_DATE_CSS
,
self
.
ENROLLMENT_START_TIME_CSS
]
expected_values
=
[
self
.
course_start_date
,
self
.
course_end_date
,
self
.
enrollment_start_date
,
self
.
enrollment_end_date
,
default_value_enrollment_start_date
]
# Assert that value of enrolment start time
# is not saved.
self
.
assertEqual
(
[
get_input_value
(
self
.
settings_page
,
css_selector
)
for
css_selector
in
css_selectors
],
expected_values
)
def
test_settings_are_reset_on_cancel
(
self
):
"""
Scenario: Settings are reset on cancel
Given I have set course dates
And I press the "Save" notification button
When I change fields
And I press the "Cancel" notification button
Then I do not see the changes
"""
# Set course date
self
.
set_course_dates
()
# Save changes
self
.
settings_page
.
save_changes
()
default_value_enrollment_start_date
=
get_input_value
(
self
.
settings_page
,
self
.
ENROLLMENT_START_TIME_CSS
)
# Set value but don't save it.
self
.
settings_page
.
set_element_values
({
self
.
ENROLLMENT_START_TIME_CSS
:
self
.
dummy_time
})
self
.
settings_page
.
click_button
(
"cancel"
)
# Make sure changes are not saved after cancel.
css_selectors
=
[
self
.
COURSE_START_DATE_CSS
,
self
.
COURSE_END_DATE_CSS
,
self
.
ENROLLMENT_START_DATE_CSS
,
self
.
ENROLLMENT_END_DATE_CSS
,
self
.
ENROLLMENT_START_TIME_CSS
]
expected_values
=
[
self
.
course_start_date
,
self
.
course_end_date
,
self
.
enrollment_start_date
,
self
.
enrollment_end_date
,
default_value_enrollment_start_date
]
self
.
assertEqual
(
[
get_input_value
(
self
.
settings_page
,
css_selector
)
for
css_selector
in
css_selectors
],
expected_values
)
def
test_confirmation_is_shown_on_save
(
self
):
"""
Scenario: Confirmation is shown on save
Given I have opened a new course in Studio
When I select Schedule and Details
And I change the "<field>" field to "<value>"
And I press the "Save" notification button
Then I see a confirmation that my changes have been saved
"""
# Set date
self
.
settings_page
.
set_element_values
({
self
.
COURSE_START_DATE_CSS
:
self
.
course_start_date
})
# Confirmation is showed upon save.
# Save_changes function ensures that save
# confirmation is shown.
self
.
settings_page
.
save_changes
()
def
test_changes_in_course_overview_show_a_confirmation
(
self
):
"""
Scenario: Changes in Course Overview show a confirmation
Given I have opened a new course in Studio
When I select Schedule and Details
And I change the course overview
And I press the "Save" notification button
Then I see a confirmation that my changes have been saved
"""
# Change the value of course overview
self
.
settings_page
.
change_course_description
(
'Changed overview'
)
# Save changes
# Save_changes function ensures that save
# confirmation is shown.
self
.
settings_page
.
save_changes
()
def
test_user_cannot_save_invalid_settings
(
self
):
"""
Scenario: User cannot save invalid settings
Given I have opened a new course in Studio
When I select Schedule and Details
And I change the "Course Start Date" field to ""
Then the save notification button is disabled
"""
# Change the course start date to invalid date.
self
.
settings_page
.
set_element_values
({
self
.
COURSE_START_DATE_CSS
:
''
})
# Confirm that save button is disabled.
self
.
assertEqual
(
self
.
settings_page
.
is_element_present
(
".action-primary.action-save.is-disabled"
),
True
)
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment