com.fitbur.bouncycastle.crypto.test.VMPCMacTest Maven / Gradle / Ivy
package com.fitbur.bouncycastle.crypto.test;
import com.fitbur.bouncycastle.crypto.CipherParameters;
import com.fitbur.bouncycastle.crypto.macs.VMPCMac;
import com.fitbur.bouncycastle.crypto.params.KeyParameter;
import com.fitbur.bouncycastle.crypto.params.ParametersWithIV;
import com.fitbur.bouncycastle.util.Arrays;
import com.fitbur.bouncycastle.util.encoders.Hex;
import com.fitbur.bouncycastle.util.test.SimpleTest;
public class VMPCMacTest extends SimpleTest
{
public String getName()
{
return "VMPC-MAC";
}
public static void main(String[] args)
{
runTest(new VMPCMacTest());
}
static byte[] output1 = Hex.com.fitburcode("9BDA16E2AD0E284774A3ACBC8835A8326C11FAAD");
public void performTest() throws Exception
{
CipherParameters kp = new KeyParameter(
Hex.com.fitburcode("9661410AB797D8A9EB767C21172DF6C7"));
CipherParameters kpwiv = new ParametersWithIV(kp,
Hex.com.fitburcode("4B5C2F003E67F39557A8D26F3DA2B155"));
byte[] m = new byte[256];
for (int i = 0; i < 256; i++)
{
m[i] = (byte) i;
}
VMPCMac mac = new VMPCMac();
mac.init(kpwiv);
mac.update(m, 0, m.length);
byte[] out = new byte[20];
mac.doFinal(out, 0);
if (!Arrays.areEqual(out, output1))
{
fail("Fail", new String(Hex.encode(output1)), new String(Hex.encode(out)));
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy