summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAzul <azul@leap.se>2012-07-02 12:09:30 +0200
committerAzul <azul@leap.se>2012-07-02 12:09:30 +0200
commitd743601c17a650e189f9c4bf1cab926b94363e45 (patch)
tree9f905a6226d9fb802c7357665c48b34d95df2610
parent3c141bd046c7f36f4b2636302eff7cd0445c546d (diff)
added integration test for login
* added a small hook in srp to set a, A and Astr for testing * moved generic functions for tests to SpecHelper
-rw-r--r--javascript/spec/DjangoSpecRunner.html3
-rw-r--r--javascript/spec/login.js46
-rw-r--r--javascript/spec/signup.js20
-rw-r--r--javascript/spec/specHelper.js17
-rw-r--r--javascript/srp.js10
5 files changed, 80 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
+ }
+
+})();
diff --git a/javascript/srp.js b/javascript/srp.js
index 7021bfa..9aa47b9 100644
--- a/javascript/srp.js
+++ b/javascript/srp.js
@@ -28,6 +28,16 @@ function SRP()
// *** Accessor methods ***
+ // allows setting the random number A for testing
+
+ this.calculateAndSetA = function(_a)
+ {
+ a = new BigInteger(_a, 16);
+ A = g.modPow(a, N);
+ Astr = A.toString(16);
+ return Astr;
+ };
+
// Returns the user's identity
this.getI = function()
{