test srp x and v

This commit is contained in:
Quinn Slack 2011-04-19 05:14:28 -07:00
parent 2bbda850b1
commit 44ddce8d5f

View File

@ -5,15 +5,18 @@ new sjcl.test.TestCase("SRP known-answer (RFC 5054) tests", function (cb) {
return; return;
} }
var i, kat = sjcl.test.vector.srp, tv, N, g, v; var i, kat = sjcl.test.vector.srp, tv, N, g, v, x;
for (i=0; i<kat.length; i++) { for (i=0; i<kat.length; i++) {
tv = kat[i]; tv = kat[i];
N = sjcl.keyexchange.srp.knownGroups[tv.known_group_size].N; N = sjcl.keyexchange.srp.knownGroup(tv.known_group_size).N;
g = sjcl.keyexchange.srp.knownGroups[tv.known_group_size].g; g = sjcl.keyexchange.srp.knownGroup(tv.known_group_size).g;
v = sjcl.keyexchange.srp.makeVerifier(tv.I, tv.P, tv.s, N, g) tv.s = sjcl.codec.hex.toBits(tv.s);
print("-> v = " + v); x = sjcl.keyexchange.srp.makeX(tv.I, tv.P, tv.s);
this.require(sjcl.bitArray.equal(v, tv.v), "srpv #"+i); this.require(sjcl.codec.hex.fromBits(x).toUpperCase() === tv.x, "srpx #"+i);
v = sjcl.keyexchange.srp.makeVerifier(tv.I, tv.P, tv.s, N, g);
this.require(v.equals(new sjcl.bn(tv.v)), "srpv #"+i);
} }
cb && cb(); cb && cb();
}); });