diff options
Diffstat (limited to 'javascript/spec')
-rw-r--r-- | javascript/spec/DjangoSpecRunner.html | 3 | ||||
-rw-r--r-- | javascript/spec/login.js | 46 | ||||
-rw-r--r-- | javascript/spec/signup.js | 20 | ||||
-rw-r--r-- | javascript/spec/specHelper.js | 17 |
4 files changed, 70 insertions, 16 deletions
diff --git a/javascript/spec/DjangoSpecRunner.html b/javascript/spec/DjangoSpecRunner.html index 7e045e4..dfa0b8c 100644 --- a/javascript/spec/DjangoSpecRunner.html +++ b/javascript/spec/DjangoSpecRunner.html @@ -23,6 +23,7 @@ <script type="text/javascript" src="../srp_register.js"></script> <!-- include spec files here... --> + <script type="text/javascript" src="specHelper.js"></script> <script type="text/javascript" src="signup.js"></script> <script type="text/javascript" src="login.js"></script> @@ -64,7 +65,7 @@ <tr><td>Username:</td><td><input type="text" id="srp_username" value="user" /></td></tr> <tr><td>Password:</td><td><input type="password" id="srp_password" value="opensesami"/></td></tr> <input type="hidden" id="srp_url" value=""/> - <input type="hidden" id="srp_forward" value="/login/"/> + <input type="hidden" id="srp_forward" value="#logged_in"/> <input type="hidden" id="srp_server" value="django"/> </table> <input type="submit"/> diff --git a/javascript/spec/login.js b/javascript/spec/login.js index e69de29..d73f9d7 100644 --- a/javascript/spec/login.js +++ b/javascript/spec/login.js @@ -0,0 +1,46 @@ +describe("Login", function() { + + beforeEach(function() { + this.srp = new SRP(); + this.xhr = sinon.useFakeXMLHttpRequest(); + var requests = this.requests = []; + this.xhr.onCreate = function (xhr) { + requests.push(xhr); + }; + }); + + afterEach(function() { + this.xhr.restore(); + }); + + it("has an identify function", function() { + expect(typeof this.srp.identify).toBe('function'); + }); + + it("logs in successfully (INTEGRATION)", function(){ + var callback = sinon.spy(); + var a = 'af141ae6'; + var B = '887005895b1f5528b4e4dfdce914f73e763b96d3c901d2f41d8b8cd26255a75'; + var salt = '5d3055e0acd3ddcfc15'; + var M = 'be6d7db2186d5f6a2c55788479b6eaf75229a7ca0d9e7dc1f886f1970a0e8065' + var M2 = '2547cf26318519090f506ab73a68995a2626b1c948e6f603ef9e1b0b78bf0f7b'; + srp = new SRP() + srp.success = callback; + var A = srp.calculateAndSetA(a); + srp.identify(); + + expect(this.requests.length).toBe(1); + expect(this.requests[0].url).toBe("handshake/"); + expect(this.requests[0].requestBody).toBe("I=user&A=" + A); + specHelper.respondXML(this.requests[0], "<r s='"+salt+"' B='"+B+"' />"); + expect(this.requests.length).toBe(2); + expect(this.requests[1].url).toBe("authenticate/"); + expect(this.requests[1].requestBody).toBe("M=" + M); + specHelper.respondXML(this.requests[1], "<M>"+M2+"</M>"); + + expect(callback).toHaveBeenCalled(); + expect(window.location.hash).toBe("#logged_in") + }); + + +}); diff --git a/javascript/spec/signup.js b/javascript/spec/signup.js index fb5c014..8ead93b 100644 --- a/javascript/spec/signup.js +++ b/javascript/spec/signup.js @@ -1,5 +1,3 @@ - - describe("Signup", function() { beforeEach(function() { @@ -15,7 +13,7 @@ describe("Signup", function() { this.xhr.restore(); }); - it("instantiates SRP with a register function", function() { + it("has a register function", function() { expect(typeof this.srp.register).toBe('function'); }); @@ -25,7 +23,7 @@ describe("Signup", function() { this.srp.register(); expect(this.requests.length).toBe(1); - respondXML(this.requests[0], "<salt>5d3055e0acd3ddcfc15</salt>"); + specHelper.respondXML(this.requests[0], "<salt>5d3055e0acd3ddcfc15</salt>"); expect(callback.called).toBeTruthy(); }); @@ -35,7 +33,7 @@ describe("Signup", function() { this.srp.register(); expect(this.requests.length).toBe(1); - respondXML(this.requests[0], "<salt>5d3055e0acd3ddcfc15</salt>"); + specHelper.respondXML(this.requests[0], "<salt>5d3055e0acd3ddcfc15</salt>"); expect(callback).toHaveBeenCalledWith("adcd57b4a4a05c2e205b0b7b30014d9ff635d8d8db2f502f08e9b9c132800c44"); }); @@ -46,23 +44,15 @@ describe("Signup", function() { expect(this.requests.length).toBe(1); expect(this.requests[0].url).toBe("register/salt/"); expect(this.requests[0].requestBody).toBe("I=user"); - respondXML(this.requests[0], "<salt>5d3055e0acd3ddcfc15</salt>"); + specHelper.respondXML(this.requests[0], "<salt>5d3055e0acd3ddcfc15</salt>"); expect(this.requests.length).toBe(2); expect(this.requests[1].url).toBe("register/user/"); expect(this.requests[1].requestBody).toBe("v=adcd57b4a4a05c2e205b0b7b30014d9ff635d8d8db2f502f08e9b9c132800c44"); - respondXML(this.requests[1], "<ok/>"); + specHelper.respondXML(this.requests[1], "<ok/>"); expect(callback).toHaveBeenCalled(); }); - // HELPERS - - function respondXML(request, content) { - header = { "Content-Type": "application/xml;charset=utf-8" }; - body = '<?xml version="1.0" encoding="UTF-8"?>\n'; - body += content; - request.respond(200, header, body); - } }); diff --git a/javascript/spec/specHelper.js b/javascript/spec/specHelper.js new file mode 100644 index 0000000..e923310 --- /dev/null +++ b/javascript/spec/specHelper.js @@ -0,0 +1,17 @@ +var specHelper = (function() { + // HELPERS + + function respondXML(request, content) { + header = { "Content-Type": "application/xml;charset=utf-8" }; + body = '<?xml version="1.0" encoding="UTF-8"?>\n'; + body += content; + request.respond(200, header, body); + } + + var originalBigInteger = BigInteger; + + return { + respondXML: respondXML + } + +})(); |