summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/srp/spec/helper.js
diff options
context:
space:
mode:
authorazul <azul@riseup.net>2017-03-23 13:23:42 +0000
committerazul <azul@riseup.net>2017-03-23 13:23:42 +0000
commit94ba8eae189ef6d60ddfa194e73b672123e17d6f (patch)
tree0e901532c839d7d0db922cb97d064df279090116 /app/assets/javascripts/srp/spec/helper.js
parentfca8411e2359eafd4c50dbb6a6b8539a7e8593c7 (diff)
parent372b15afed0b7477bd83062feaa7f24c4d40e38d (diff)
Merge branch 'install/subrepos' into 'master'
Install/subrepos See merge request !28 Fixes github issue #238
Diffstat (limited to 'app/assets/javascripts/srp/spec/helper.js')
m---------app/assets/javascripts/srp0
-rw-r--r--app/assets/javascripts/srp/spec/helper.js48
2 files changed, 48 insertions, 0 deletions
diff --git a/app/assets/javascripts/srp b/app/assets/javascripts/srp
deleted file mode 160000
-Subproject 9e1a41733468d4a3f5102b04277b9cd7b52d0a4
diff --git a/app/assets/javascripts/srp/spec/helper.js b/app/assets/javascripts/srp/spec/helper.js
new file mode 100644
index 0000000..d1c699b
--- /dev/null
+++ b/app/assets/javascripts/srp/spec/helper.js
@@ -0,0 +1,48 @@
+var specHelper = (function() {
+ // HELPERS
+
+ function setupFakeXHR() {
+ this.xhr = sinon.useFakeXMLHttpRequest();
+ var requests = this.requests = [];
+ this.xhr.onCreate = function (xhr) {
+ requests.push(xhr);
+ };
+ this.expectRequest = expectRequest;
+ this.respondJSON = respondJSON;
+ this.respondXML = respondXML;
+ }
+
+ // TODO: validate http verb
+ function expectRequest(url, content, verb) {
+ expect(this.requests.length).toBe(1);
+ expect(this.requests[0].url).toBe(url);
+ expect(decodeURI(this.requests[0].requestBody)).toBe(content);
+ if (verb) {
+ expect(this.requests[0].method).toBe(verb);
+ }
+ }
+
+ function respondXML(content) {
+ var request = this.requests.pop();
+ header = { "Content-Type": "application/xml;charset=utf-8" };
+ body = '<?xml version="1.0" encoding="UTF-8"?>\n';
+ body += content;
+ request.respond(200, header, body);
+ }
+
+ function respondJSON(object, responseCode) {
+ var request = this.requests.pop();
+ header = { "Content-Type": "application/json;charset=utf-8" };
+ body = JSON.stringify(object);
+ request.respond(responseCode || 200, header, body);
+ }
+
+ return {
+ setupFakeXHR: setupFakeXHR,
+ }
+
+})();
+
+beforeEach(function () {
+ setFixtures("<form action='.' onsubmit='return register()'> <table> <tr><td>Username:</td><td><input type='text' id='srp_username' value='testuser' /></td></tr> <tr><td>Password:</td><td><input type='password' id='srp_password' value='password'/></td></tr> </table> <input type='submit'/> </form> ");
+});