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
baee2da2
Commit
baee2da2
authored
Aug 20, 2014
by
Ben McMorran
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve javascript test coverage
parent
7bf9c1a7
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
108 additions
and
17 deletions
+108
-17
cms/static/js/index.js
+1
-1
cms/static/js/spec/views/pages/course_rerun_spec.js
+59
-4
cms/static/js/spec/views/pages/index_spec.js
+33
-5
cms/static/js/views/course_rerun.js
+3
-3
cms/static/js/views/utils/create_course_utils.js
+3
-3
cms/static/js/views/utils/view_utils.js
+9
-1
No files found.
cms/static/js/index.js
View file @
baee2da2
...
...
@@ -82,7 +82,7 @@ define(["domReady", "jquery", "underscore", "js/utils/cancel_on_escape", "js/vie
var
onReady
=
function
()
{
$
(
'.new-course-button'
).
bind
(
'click'
,
addNewCourse
);
$
(
'.dismiss-button'
).
bind
(
'click'
,
ViewUtils
.
deleteNotificationHandler
(
function
()
{
window
.
location
.
reload
();
ViewUtils
.
reload
();
}));
};
...
...
cms/static/js/spec/views/pages/course_rerun_spec.js
View file @
baee2da2
define
([
"jquery"
,
"js/spec_helpers/create_sinon"
,
"js/spec_helpers/view_helpers"
,
"js/views/course_rerun"
,
"js/views/utils/create_course_utils"
,
"jquery.simulate"
],
function
(
$
,
create_sinon
,
view_helpers
,
CourseRerunUtils
,
CreateCourseUtilsFactory
)
{
"js/views/utils/create_course_utils"
,
"j
s/views/utils/view_utils"
,
"j
query.simulate"
],
function
(
$
,
create_sinon
,
view_helpers
,
CourseRerunUtils
,
CreateCourseUtilsFactory
,
ViewUtils
)
{
describe
(
"Create course rerun page"
,
function
()
{
var
selectors
=
{
org
:
'.rerun-course-org'
,
...
...
@@ -66,6 +66,11 @@ define(["jquery", "js/spec_helpers/create_sinon", "js/spec_helpers/view_helpers"
return
element
;
};
var
type
=
function
(
input
,
value
)
{
input
.
val
(
value
);
input
.
simulate
(
"keyup"
,
{
keyCode
:
$
.
simulate
.
keyCode
.
SPACE
});
};
it
(
"shows an error message"
,
function
()
{
var
element
=
setErrorMessage
(
selectors
.
org
,
'error message'
);
expect
(
element
).
toHaveClass
(
classes
.
error
);
...
...
@@ -104,15 +109,55 @@ define(["jquery", "js/spec_helpers/create_sinon", "js/spec_helpers/view_helpers"
it
(
"shows an error message when non URL characters are entered"
,
function
()
{
var
input
=
$
(
selectors
.
org
);
expect
(
input
.
parent
()).
not
.
toHaveClass
(
classes
.
error
);
input
.
val
(
"%"
)
type
(
input
,
"%"
);
expect
(
input
.
parent
()).
toHaveClass
(
classes
.
error
);
});
it
(
"does not show an error message when tabbing into a field"
,
function
()
{
var
input
=
$
(
selectors
.
number
);
input
.
val
(
''
);
expect
(
input
.
parent
()).
not
.
toHaveClass
(
classes
.
error
);
input
.
simulate
(
"keyup"
,
{
keyCode
:
$
.
simulate
.
keyCode
.
TAB
});
expect
(
input
.
parent
()).
not
.
toHaveClass
(
classes
.
error
);
});
it
(
"shows an error message when a required field is empty"
,
function
()
{
var
input
=
$
(
selectors
.
org
);
input
.
val
(
''
);
expect
(
input
.
parent
()).
not
.
toHaveClass
(
classes
.
error
);
input
.
simulate
(
"keyup"
,
{
keyCode
:
$
.
simulate
.
keyCode
.
ENTER
});
expect
(
input
.
parent
()).
toHaveClass
(
classes
.
error
);
});
it
(
"shows an error message when spaces are entered and unicode is allowed"
,
function
()
{
var
input
=
$
(
selectors
.
org
);
$
(
selectors
.
allowUnicode
).
val
(
'True'
);
expect
(
input
.
parent
()).
not
.
toHaveClass
(
classes
.
error
);
type
(
input
,
' '
);
expect
(
input
.
parent
()).
toHaveClass
(
classes
.
error
);
});
it
(
"shows an error message when total length exceeds 65 characters"
,
function
()
{
expect
(
$
(
selectors
.
errorWrapper
)).
not
.
toHaveClass
(
classes
.
shown
);
type
(
$
(
selectors
.
org
),
'ThisIsAVeryLongNameThatWillExceedTheSixtyFiveCharacterLimit'
);
type
(
$
(
selectors
.
number
),
'ThisIsAVeryLongNameThatWillExceedTheSixtyFiveCharacterLimit'
);
type
(
$
(
selectors
.
run
),
'ThisIsAVeryLongNameThatWillExceedTheSixtyFiveCharacterLimit'
);
expect
(
$
(
selectors
.
errorWrapper
)).
toHaveClass
(
classes
.
shown
);
});
describe
(
"Name field"
,
function
()
{
it
(
"does not show an error message when non URL characters are entered"
,
function
()
{
var
input
=
$
(
selectors
.
name
);
expect
(
input
.
parent
()).
not
.
toHaveClass
(
classes
.
error
);
type
(
input
,
"%"
);
expect
(
input
.
parent
()).
not
.
toHaveClass
(
classes
.
error
);
});
});
});
it
(
"saves course reruns"
,
function
()
{
var
requests
=
create_sinon
.
requests
(
this
);
window
.
source_course_key
=
'test_course_key'
;
var
redirectSpy
=
spyOn
(
ViewUtils
,
'redirect'
)
fillInFields
(
'DemoX'
,
'DM101'
,
'2014'
,
'Demo course'
);
$
(
selectors
.
save
).
click
();
create_sinon
.
expectJsonRequest
(
requests
,
'POST'
,
'/course/'
,
{
...
...
@@ -125,6 +170,10 @@ define(["jquery", "js/spec_helpers/create_sinon", "js/spec_helpers/view_helpers"
expect
(
$
(
selectors
.
save
)).
toHaveClass
(
classes
.
disabled
);
expect
(
$
(
selectors
.
save
)).
toHaveClass
(
classes
.
processing
);
expect
(
$
(
selectors
.
cancel
)).
toHaveClass
(
classes
.
hidden
);
create_sinon
.
respondWithJson
(
requests
,
{
url
:
'dummy_test_url'
});
expect
(
redirectSpy
).
toHaveBeenCalledWith
(
'dummy_test_url'
);
});
it
(
"displays an error when saving fails"
,
function
()
{
...
...
@@ -146,5 +195,11 @@ define(["jquery", "js/spec_helpers/create_sinon", "js/spec_helpers/view_helpers"
$
(
selectors
.
save
).
click
();
expect
(
requests
.
length
).
toBe
(
0
);
});
it
(
"can be canceled"
,
function
()
{
var
redirectSpy
=
spyOn
(
ViewUtils
,
'redirect'
);
$
(
selectors
.
cancel
).
click
();
expect
(
redirectSpy
).
toHaveBeenCalledWith
(
'/course/'
);
});
});
});
cms/static/js/spec/views/pages/index_spec.js
View file @
baee2da2
define
([
"jquery"
,
"js/spec_helpers/create_sinon"
,
"js/spec_helpers/view_helpers"
,
"js/index"
],
function
(
$
,
create_sinon
,
view_helpers
,
IndexUtils
)
{
define
([
"jquery"
,
"js/spec_helpers/create_sinon"
,
"js/spec_helpers/view_helpers"
,
"js/index"
,
"js/views/utils/view_utils"
],
function
(
$
,
create_sinon
,
view_helpers
,
IndexUtils
,
ViewUtils
)
{
describe
(
"Course listing page"
,
function
()
{
var
mockIndexPageHTML
=
readFixtures
(
'mock/mock-index-page.underscore'
);
var
mockIndexPageHTML
=
readFixtures
(
'mock/mock-index-page.underscore'
),
fillInFields
;
var
fillInFields
=
function
(
org
,
number
,
run
,
name
)
{
$
(
'.new-course-org'
).
val
(
org
);
$
(
'.new-course-number'
).
val
(
number
);
$
(
'.new-course-run'
).
val
(
run
);
$
(
'.new-course-name'
).
val
(
name
);
};
beforeEach
(
function
()
{
view_helpers
.
installMockAnalytics
();
...
...
@@ -16,8 +24,29 @@ define(["jquery", "js/spec_helpers/create_sinon", "js/spec_helpers/view_helpers"
it
(
"can dismiss notifications"
,
function
()
{
var
requests
=
create_sinon
.
requests
(
this
);
var
reloadSpy
=
spyOn
(
ViewUtils
,
'reload'
);
$
(
'.dismiss-button'
).
click
();
create_sinon
.
expectJsonRequest
(
requests
,
'DELETE'
,
'dummy_dismiss_url'
);
create_sinon
.
respondToDelete
(
requests
);
expect
(
reloadSpy
).
toHaveBeenCalled
();
});
it
(
"saves new courses"
,
function
()
{
var
requests
=
create_sinon
.
requests
(
this
);
var
redirectSpy
=
spyOn
(
ViewUtils
,
'redirect'
);
$
(
'.new-course-button'
).
click
()
fillInFields
(
'DemoX'
,
'DM101'
,
'2014'
,
'Demo course'
);
$
(
'.new-course-save'
).
click
();
create_sinon
.
expectJsonRequest
(
requests
,
'POST'
,
'/course/'
,
{
org
:
'DemoX'
,
number
:
'DM101'
,
run
:
'2014'
,
display_name
:
'Demo course'
});
create_sinon
.
respondWithJson
(
requests
,
{
url
:
'dummy_test_url'
});
expect
(
redirectSpy
).
toHaveBeenCalledWith
(
'dummy_test_url'
);
});
});
});
\ No newline at end of file
});
cms/static/js/views/course_rerun.js
View file @
baee2da2
define
([
"domReady"
,
"jquery"
,
"underscore"
,
"js/views/utils/create_course_utils"
],
function
(
domReady
,
$
,
_
,
CreateCourseUtilsFactory
)
{
define
([
"domReady"
,
"jquery"
,
"underscore"
,
"js/views/utils/create_course_utils"
,
"js/views/utils/view_utils"
],
function
(
domReady
,
$
,
_
,
CreateCourseUtilsFactory
,
ViewUtils
)
{
var
CreateCourseUtils
=
CreateCourseUtilsFactory
({
name
:
'.rerun-course-name'
,
org
:
'.rerun-course-org'
,
...
...
@@ -62,7 +62,7 @@ define(["domReady", "jquery", "underscore", "js/views/utils/create_course_utils"
$
(
'#course_rerun_error'
).
html
(
''
);
$
(
'wrapper-error'
).
removeClass
(
'is-shown'
).
addClass
(
'is-hidden'
);
$
(
'.rerun-course-save'
).
off
(
'click'
);
window
.
location
.
href
=
'/course/'
;
ViewUtils
.
redirect
(
'/course/'
)
;
};
var
onReady
=
function
()
{
...
...
cms/static/js/views/utils/create_course_utils.js
View file @
baee2da2
/**
* Provides utilities for validating courses during creation, for both new courses and reruns.
*/
define
([
"jquery"
,
"underscore"
,
"gettext"
],
function
(
$
,
_
,
gettext
)
{
define
([
"jquery"
,
"underscore"
,
"gettext"
,
"js/views/utils/view_utils"
],
function
(
$
,
_
,
gettext
,
ViewUtils
)
{
return
function
(
selectors
,
classes
)
{
var
validateRequiredField
,
validateCourseItemEncoding
,
validateTotalCourseItemsLength
,
setNewCourseFieldInErr
,
hasInvalidRequiredFields
,
createCourse
,
validateFilledFields
,
configureHandlers
;
...
...
@@ -84,7 +84,7 @@ define(["jquery", "underscore", "gettext"],
courseInfo
,
function
(
data
)
{
if
(
data
.
url
!==
undefined
)
{
window
.
location
=
data
.
url
;
ViewUtils
.
redirect
(
data
.
url
)
;
}
else
if
(
data
.
ErrMsg
!==
undefined
)
{
errorHandler
(
data
.
ErrMsg
);
}
...
...
cms/static/js/views/utils/view_utils.js
View file @
baee2da2
...
...
@@ -5,7 +5,7 @@ define(["jquery", "underscore", "gettext", "js/views/feedback_notification", "js
function
(
$
,
_
,
gettext
,
NotificationView
,
PromptView
)
{
var
toggleExpandCollapse
,
showLoadingIndicator
,
hideLoadingIndicator
,
confirmThenRunOperation
,
runOperationShowingMessage
,
disableElementWhileRunning
,
getScrollOffset
,
setScrollOffset
,
setScrollTop
,
redirect
,
hasChangedAttributes
,
deleteNotificationHandler
;
setScrollTop
,
redirect
,
reload
,
hasChangedAttributes
,
deleteNotificationHandler
;
/**
* Toggles the expanded state of the current element.
...
...
@@ -148,6 +148,13 @@ define(["jquery", "underscore", "gettext", "js/views/feedback_notification", "js
};
/**
* Reloads the page. This is broken out as its own function for unit testing.
*/
reload
=
function
()
{
window
.
location
.
reload
();
};
/**
* Returns true if a model has changes to at least one of the specified attributes.
* @param model The model in question.
* @param attributes The list of attributes to be compared.
...
...
@@ -178,6 +185,7 @@ define(["jquery", "underscore", "gettext", "js/views/feedback_notification", "js
'getScrollOffset'
:
getScrollOffset
,
'setScrollOffset'
:
setScrollOffset
,
'redirect'
:
redirect
,
'reload'
:
reload
,
'hasChangedAttributes'
:
hasChangedAttributes
};
});
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