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
52b6ef89
Commit
52b6ef89
authored
Nov 17, 2014
by
Renzo Lucioni
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #5976 from edx/hotfix-2014-11-17
disable "go to payment button" on click (ECOM-643)
parents
1a4ad061
4db5b311
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
38 additions
and
7 deletions
+38
-7
cms/envs/bok_choy.auth.json
+1
-1
lms/djangoapps/verify_student/tests/test_views.py
+14
-0
lms/djangoapps/verify_student/views.py
+1
-0
lms/envs/bok_choy.auth.json
+1
-1
lms/static/js/spec/photocapture_spec.js
+12
-1
lms/static/js/verify_student/photocapture.js
+2
-0
lms/templates/verify_student/verified.html
+4
-1
scripts/reset-test-db.sh
+3
-3
No files found.
cms/envs/bok_choy.auth.json
View file @
52b6ef89
...
...
@@ -26,7 +26,7 @@
"default"
:
{
"ENGINE"
:
"django.db.backends.mysql"
,
"HOST"
:
"localhost"
,
"NAME"
:
"test"
,
"NAME"
:
"
edx
test"
,
"PASSWORD"
:
""
,
"PORT"
:
"3306"
,
"USER"
:
"root"
...
...
lms/djangoapps/verify_student/tests/test_views.py
View file @
52b6ef89
...
...
@@ -141,6 +141,20 @@ class TestCreateOrderView(ModuleStoreTestCase):
self
.
assertIn
(
'This course doesn
\'
t support verified certificates'
,
response
.
content
)
@patch.dict
(
settings
.
FEATURES
,
{
'AUTOMATIC_VERIFY_STUDENT_IDENTITY_FOR_TESTING'
:
True
})
def
test_create_order_fail_with_get
(
self
):
"""
Test that create_order will not work if wrong http method used
"""
create_order_post_data
=
{
'contribution'
:
50
,
'course_id'
:
self
.
course_id
,
'face_image'
:
','
,
'photo_id_image'
:
','
}
response
=
self
.
client
.
get
(
reverse
(
'verify_student_create_order'
),
create_order_post_data
)
self
.
assertEqual
(
response
.
status_code
,
405
)
@patch.dict
(
settings
.
FEATURES
,
{
'AUTOMATIC_VERIFY_STUDENT_IDENTITY_FOR_TESTING'
:
True
})
def
test_create_order_success
(
self
):
"""
Test that the order is created successfully when given valid data
...
...
lms/djangoapps/verify_student/views.py
View file @
52b6ef89
...
...
@@ -167,6 +167,7 @@ class VerifiedView(View):
return
render_to_response
(
'verify_student/verified.html'
,
context
)
@require_POST
@login_required
def
create_order
(
request
):
"""
...
...
lms/envs/bok_choy.auth.json
View file @
52b6ef89
...
...
@@ -26,7 +26,7 @@
"default"
:
{
"ENGINE"
:
"django.db.backends.mysql"
,
"HOST"
:
"localhost"
,
"NAME"
:
"test"
,
"NAME"
:
"
edx
test"
,
"PASSWORD"
:
""
,
"PORT"
:
"3306"
,
"USER"
:
"root"
...
...
lms/static/js/spec/photocapture_spec.js
View file @
52b6ef89
...
...
@@ -4,7 +4,7 @@ define(['backbone', 'jquery', 'js/verify_student/photocapture'],
describe
(
"Photo Verification"
,
function
()
{
beforeEach
(
function
()
{
setFixtures
(
'<div id="order-error" style="display: none;"></div><input type="radio" name="contribution" value="35" id="contribution-35" checked="checked"><input type="radio" id="contribution-other" name="contribution" value=""><input type="text" size="9" name="contribution-other-amt" id="contribution-other-amt" value="30"><img id="face_image" src="src=""><img id="photo_id_image" src="src="">'
);
setFixtures
(
'<div id="order-error" style="display: none;"></div><input type="radio" name="contribution" value="35" id="contribution-35" checked="checked"><input type="radio" id="contribution-other" name="contribution" value=""><input type="text" size="9" name="contribution-other-amt" id="contribution-other-amt" value="30"><img id="face_image" src="src=""><img id="photo_id_image" src="src="">
<button id="pay_button">pay button</button>
'
);
});
it
(
'retake photo'
,
function
()
{
...
...
@@ -27,6 +27,7 @@ define(['backbone', 'jquery', 'js/verify_student/photocapture'],
});
submitToPaymentProcessing
();
expect
(
window
.
submitForm
).
toHaveBeenCalled
();
expect
(
$
(
"#pay_button"
)).
toHaveClass
(
"is-disabled"
);
});
it
(
'Error during process'
,
function
()
{
...
...
@@ -36,8 +37,18 @@ define(['backbone', 'jquery', 'js/verify_student/photocapture'],
spyOn
(
$
,
"ajax"
).
andCallFake
(
function
(
e
)
{
e
.
error
({});
});
spyOn
(
$
.
fn
,
"addClass"
).
andCallThrough
();
spyOn
(
$
.
fn
,
"removeClass"
).
andCallThrough
();
submitToPaymentProcessing
();
expect
(
window
.
showSubmissionError
).
toHaveBeenCalled
();
// make sure the button isn't disabled
expect
(
$
(
"#pay_button"
)).
not
.
toHaveClass
(
"is-disabled"
);
// but also make sure that it was disabled during the ajax call
expect
(
$
.
fn
.
addClass
).
toHaveBeenCalledWith
(
"is-disabled"
);
expect
(
$
.
fn
.
removeClass
).
toHaveBeenCalledWith
(
"is-disabled"
);
});
});
...
...
lms/static/js/verify_student/photocapture.js
View file @
52b6ef89
...
...
@@ -69,6 +69,7 @@ function refereshPageMessage() {
}
var
submitToPaymentProcessing
=
function
()
{
$
(
"#pay_button"
).
addClass
(
'is-disabled'
);
var
contribution_input
=
$
(
"input[name='contribution']:checked"
)
var
contribution
=
0
;
if
(
contribution_input
.
attr
(
'id'
)
==
'contribution-other'
)
{
...
...
@@ -95,6 +96,7 @@ var submitToPaymentProcessing = function() {
}
},
error
:
function
(
xhr
,
status
,
error
)
{
$
(
"#pay_button"
).
removeClass
(
'is-disabled'
);
showSubmissionError
()
}
});
...
...
lms/templates/verify_student/verified.html
View file @
52b6ef89
...
...
@@ -12,6 +12,7 @@
<script
type=
"text/javascript"
>
var
submitToPaymentProcessing
=
function
(
event
)
{
event
.
preventDefault
();
$
(
"#pay_button"
).
addClass
(
"is-disabled"
);
var
xhr
=
$
.
post
(
"${create_order_url}"
,
{
...
...
@@ -30,7 +31,9 @@ var submitToPaymentProcessing = function(event) {
.
done
(
function
(
data
)
{
$
(
"#pay_form"
).
submit
();
})
.
fail
(
function
(
jqXhr
,
text_status
,
error_thrown
)
{
alert
(
jqXhr
.
responseText
);
});
.
fail
(
function
(
jqXhr
,
text_status
,
error_thrown
)
{
$
(
"#pay_button"
).
removeClass
(
"is-disabled"
);
alert
(
jqXhr
.
responseText
);
});
}
$
(
document
).
ready
(
function
()
{
$
(
"#pay_button"
).
click
(
submitToPaymentProcessing
);
...
...
scripts/reset-test-db.sh
View file @
52b6ef89
...
...
@@ -25,7 +25,7 @@
DB_CACHE_DIR
=
"common/test/db_cache"
# Ensure the test database exists.
echo
"CREATE DATABASE IF NOT EXISTS test;"
| mysql
-u
root
echo
"CREATE DATABASE IF NOT EXISTS
edx
test;"
| mysql
-u
root
# Clear out the test database
./manage.py lms
--settings
bok_choy reset_db
--traceback
--noinput
...
...
@@ -34,7 +34,7 @@ echo "CREATE DATABASE IF NOT EXISTS test;" | mysql -u root
if
[[
-f
$DB_CACHE_DIR
/bok_choy_schema.sql
&&
-f
$DB_CACHE_DIR
/bok_choy_data.json
]]
;
then
# Load the schema, then the data (including the migration history)
mysql
-u
root
test
<
$DB_CACHE_DIR
/bok_choy_schema.sql
mysql
-u
root
edx
test <
$DB_CACHE_DIR
/bok_choy_schema.sql
./manage.py lms
--settings
bok_choy loaddata
$DB_CACHE_DIR
/bok_choy_data.json
# Re-run migrations to ensure we are up-to-date
...
...
@@ -52,6 +52,6 @@ else
# Dump the schema and data to the cache
./manage.py lms
--settings
bok_choy dumpdata
>
$DB_CACHE_DIR
/bok_choy_data.json
mysqldump
-u
root
--no-data
--skip-comments
--skip-dump-date
test
>
$DB_CACHE_DIR
/bok_choy_schema.sql
mysqldump
-u
root
--no-data
--skip-comments
--skip-dump-date
edx
test
>
$DB_CACHE_DIR
/bok_choy_schema.sql
fi
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