aboutsummaryrefslogtreecommitdiff
path: root/src/cz/crcs/ectester/reader/test/CardTestSuite.java
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/cz/crcs/ectester/reader/test/CardTestSuite.java48
1 files changed, 42 insertions, 6 deletions
diff --git a/src/cz/crcs/ectester/reader/test/CardTestSuite.java b/src/cz/crcs/ectester/reader/test/CardTestSuite.java
index ed3dc3b..fc60ae5 100644
--- a/src/cz/crcs/ectester/reader/test/CardTestSuite.java
+++ b/src/cz/crcs/ectester/reader/test/CardTestSuite.java
@@ -5,6 +5,7 @@ import cz.crcs.ectester.applet.EC_Consts;
import cz.crcs.ectester.common.ec.EC_Curve;
import cz.crcs.ectester.common.ec.EC_Params;
import cz.crcs.ectester.common.output.TestWriter;
+import cz.crcs.ectester.common.test.CompoundTest;
import cz.crcs.ectester.common.test.Result;
import cz.crcs.ectester.common.test.Test;
import cz.crcs.ectester.common.test.TestSuite;
@@ -46,13 +47,48 @@ public abstract class CardTestSuite extends TestSuite {
}
}
- public Test genOrPreset(EC_Curve curve, Result.ExpectedValue expected) {
- if (Arrays.asList(options).contains("preset") && cfg.testOptions.contains("preset")) {
- byte[] presetPriv = ECUtil.semiRandomKey(curve);
- EC_Params privParms = new EC_Params(EC_Consts.PARAMETER_S, new byte[][]{presetPriv});
- return CommandTest.expect(new Command.Set(this.card, ECTesterApplet.KEYPAIR_LOCAL, EC_Consts.CURVE_external, privParms.getParams(), privParms.flatten()), expected);
+ public Test setupKeypairs(EC_Curve curve, Result.ExpectedValue expected, byte keyPair) {
+ if ((Arrays.asList(options).contains("preset") && cfg.testOptions.contains("preset")) || (Arrays.asList(options).contains("random") && cfg.testOptions.contains("random"))) {
+ Test setLocal = null;
+ if ((keyPair & ECTesterApplet.KEYPAIR_LOCAL) != 0) {
+ EC_Params priv;
+ if (cfg.testOptions.contains("preset")) {
+ priv = ECUtil.fixedRandomKey(curve);
+ } else {
+ priv = ECUtil.fullRandomKey(curve);
+ }
+ setLocal = CommandTest.expect(new Command.Set(this.card, ECTesterApplet.KEYPAIR_LOCAL, EC_Consts.CURVE_external, priv.getParams(), priv.flatten()), expected);
+ }
+ Test setRemote = null;
+ if ((keyPair & ECTesterApplet.KEYPAIR_REMOTE) != 0) {
+ EC_Params pub;
+ if (cfg.testOptions.contains("preset")) {
+ pub = ECUtil.fixedRandomPoint(curve);
+ } else {
+ pub = ECUtil.fullRandomPoint(curve);
+ }
+ if (pub == null) {
+ setRemote = CommandTest.expect(new Command.Generate(this.card, ECTesterApplet.KEYPAIR_REMOTE), expected);
+ } else {
+ setRemote = CommandTest.expect(new Command.Set(this.card, ECTesterApplet.KEYPAIR_REMOTE, EC_Consts.CURVE_external, pub.getParams(), pub.flatten()), expected);
+ }
+ }
+
+ if (keyPair == ECTesterApplet.KEYPAIR_LOCAL) {
+ return setLocal;
+ } else if (keyPair == ECTesterApplet.KEYPAIR_REMOTE) {
+ return setRemote;
+ } else {
+ String desc;
+ if (cfg.testOptions.contains("preset")) {
+ desc = "Set semi-random parameters.";
+ } else {
+ desc = "Set fully-random parameters.";
+ }
+ return CompoundTest.all(expected, desc, setLocal, setRemote);
+ }
} else {
- return CommandTest.expect(new Command.Generate(this.card, ECTesterApplet.KEYPAIR_LOCAL), expected);
+ return CommandTest.expect(new Command.Generate(this.card, keyPair), expected);
}
}
}