blob: 527dee549c40563283dfb6096c2cc41748e02523 [file] [log] [blame]
/*
* Copyright (C) 2019 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License
*/
package android.keystore.cts;
import android.security.keystore.KeyProperties;
import java.security.AlgorithmParameters;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
public class DesCipherPerformanceTest extends PerformanceTestBase {
final int[] SUPPORTED_DES_KEY_SIZES = {168};
final int[] TEST_MESSAGE_SIZES = {1 << 6, 1 << 10, 1 << 17};
public void testDESede_CBC_NoPadding() throws Exception {
if (!TestUtils.supports3DES()) {
return;
}
testDesCipher("DESede/CBC/NoPadding", SUPPORTED_DES_KEY_SIZES, TEST_MESSAGE_SIZES);
}
public void testDESede_CBC_PKCS7Padding() throws Exception {
if (!TestUtils.supports3DES()) {
return;
}
testDesCipher("DESede/CBC/PKCS7Padding", SUPPORTED_DES_KEY_SIZES, TEST_MESSAGE_SIZES);
}
public void testDESede_ECB_NoPadding() throws Exception {
if (!TestUtils.supports3DES()) {
return;
}
testDesCipher("DESede/ECB/NoPadding", SUPPORTED_DES_KEY_SIZES, TEST_MESSAGE_SIZES);
}
public void testDESede_ECB_PKCS7Padding() throws Exception {
if (!TestUtils.supports3DES()) {
return;
}
testDesCipher("DESede/ECB/PKCS7Padding", SUPPORTED_DES_KEY_SIZES, TEST_MESSAGE_SIZES);
}
private void testDesCipher(String algorithm, int[] keySizes, int[] messageSizes)
throws Exception {
for (int keySize : keySizes) {
KeystoreKeyGenerator androidKeystoreDesGenerator =
new AndroidKeystoreDesKeyGenerator(algorithm, keySize);
KeystoreKeyGenerator defaultKeystoreDesGenerator =
new DefaultKeystoreSecretKeyGenerator(algorithm, keySize);
for (int messageSize : messageSizes) {
measure(
new KeystoreDesEncryptMeasurable(
androidKeystoreDesGenerator, keySize, messageSize),
new KeystoreDesEncryptMeasurable(
defaultKeystoreDesGenerator, keySize, messageSize),
new KeystoreDesDecryptMeasurable(
androidKeystoreDesGenerator, keySize, messageSize),
new KeystoreDesDecryptMeasurable(
defaultKeystoreDesGenerator, keySize, messageSize));
}
}
}
private class AndroidKeystoreDesKeyGenerator extends AndroidKeystoreKeyGenerator {
AndroidKeystoreDesKeyGenerator(String algorithm, int keySize) throws Exception {
super(algorithm);
getSecretKeyGenerator()
.init(
getKeyGenParameterSpecBuilder(
KeyProperties.PURPOSE_ENCRYPT
| KeyProperties.PURPOSE_DECRYPT)
.setBlockModes(TestUtils.getCipherBlockMode(algorithm))
.setEncryptionPaddings(
TestUtils.getCipherEncryptionPadding(algorithm))
.setRandomizedEncryptionRequired(false)
.setKeySize(keySize)
.build());
}
}
private class KeystoreDesEncryptMeasurable extends KeystoreMeasurable {
private final Cipher mCipher;
private SecretKey mKey;
KeystoreDesEncryptMeasurable(
KeystoreKeyGenerator keyGenerator, int keySize, int messageSize) throws Exception {
super(keyGenerator, "encrypt", keySize, messageSize);
mCipher = Cipher.getInstance(getAlgorithm());
}
@Override
public void initialSetUp() throws Exception {
mKey = generateSecretKey();
}
@Override
public void setUp() throws Exception {
mCipher.init(Cipher.ENCRYPT_MODE, mKey);
}
@Override
public void measure() throws Exception {
mCipher.doFinal(getMessage());
}
}
private class KeystoreDesDecryptMeasurable extends KeystoreMeasurable {
private final Cipher mCipher;
private byte[] mEncryptedMessage;
private SecretKey mKey;
private AlgorithmParameters mParameters;
KeystoreDesDecryptMeasurable(
KeystoreKeyGenerator keyGenerator, int keySize, int messageSize) throws Exception {
super(keyGenerator, "decrypt", keySize, messageSize);
mCipher = Cipher.getInstance(getAlgorithm());
}
@Override
public void initialSetUp() throws Exception {
mKey = generateSecretKey();
mCipher.init(Cipher.ENCRYPT_MODE, mKey);
mEncryptedMessage = mCipher.doFinal(getMessage());
mParameters = mCipher.getParameters();
}
@Override
public void setUp() throws Exception {
mCipher.init(Cipher.DECRYPT_MODE, mKey, mParameters);
}
@Override
public void measure() throws Exception {
mCipher.doFinal(mEncryptedMessage);
}
}
}