1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
package org.bouncycastle.crypto.test;
import org.bouncycastle.crypto.BlockCipher;
import org.bouncycastle.crypto.DataLengthException;
import org.bouncycastle.crypto.engines.NullEngine;
import org.bouncycastle.crypto.params.KeyParameter;
import org.bouncycastle.util.encoders.Hex;
import org.bouncycastle.util.test.SimpleTest;
public class NullTest
extends CipherTest
{
static SimpleTest[] tests =
{
new BlockCipherVectorTest(0, new NullEngine(),
new KeyParameter(Hex.decode("00")), "00", "00")
};
NullTest()
{
super(tests, new NullEngine(), new KeyParameter(new byte[2]));
}
public String getName()
{
return "Null";
}
public void performTest()
throws Exception
{
super.performTest();
BlockCipher engine = new NullEngine();
engine.init(true, null);
byte[] buf = new byte[1];
engine.processBlock(buf, 0, buf, 0);
if (buf[0] != 0)
{
fail("NullCipher changed data!");
}
byte[] shortBuf = new byte[0];
try
{
engine.processBlock(shortBuf, 0, buf, 0);
fail("failed short input check");
}
catch (DataLengthException e)
{
// expected
}
try
{
engine.processBlock(buf, 0, shortBuf, 0);
fail("failed short output check");
}
catch (DataLengthException e)
{
// expected
}
}
public static void main(
String[] args)
{
runTest(new NullTest());
}
}
|