/* * Universal Password Manager * Copyright (C) 2005-2013 Adrian Smith * * This file is part of Universal Password Manager. * * Universal Password Manager is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * Universal Password Manager is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Universal Password Manager; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ package com._17od.upm.crypto; import java.util.Arrays; import junit.framework.TestCase; public class TestEncryptionService extends TestCase { public void testEncryptDecryptString() throws CryptoException { char[] password = "test password".toCharArray(); EncryptionService encryptionService = new EncryptionService(password); byte[] cleartext = "samplestring".getBytes(); byte[] cipherText = encryptionService.encrypt(cleartext); byte[] cleartext2 = encryptionService.decrypt(cipherText); assertEquals("Decrypted text is different to original cleartext", new String(cleartext), new String(cleartext2)); } public void testChangePassword() throws CryptoException { char[] password = "test password".toCharArray(); EncryptionService encryptionService = new EncryptionService(password); char[] password2 = "test password2".toCharArray(); EncryptionService encryptionService2 = new EncryptionService(password2, encryptionService.getSalt()); byte[] cleartext = "samplestring".getBytes(); byte[] cipherText = encryptionService.encrypt(cleartext); //When we decrypt the cipherText we should get a different result try { encryptionService2.decrypt(cipherText); fail("Should have got an InvalidPasswordException because we changed the password"); } catch (CryptoException e) { //should get here } } public void testSaltIsRandom() throws CryptoException, InterruptedException { char[] password = "test password".toCharArray(); EncryptionService encryptionService = new EncryptionService(password); byte[] salt1 = encryptionService.getSalt(); Thread.sleep(100); //Sleep to ensure the Random class will run in the future with a new seed encryptionService = new EncryptionService(password); byte[] salt2 = encryptionService.getSalt(); Thread.sleep(100); encryptionService = new EncryptionService(password); byte[] salt3 = encryptionService.getSalt(); Thread.sleep(100); encryptionService = new EncryptionService(password); byte[] salt4 = encryptionService.getSalt(); assertNotEquals(salt1, salt2, "Salt1 and Salt2 are the same"); assertNotEquals(salt1, salt3, "Salt1 and Salt3 are the same"); assertNotEquals(salt1, salt4, "Salt1 and Salt4 are the same"); assertNotEquals(salt2, salt3, "Salt2 and Salt3 are the same"); assertNotEquals(salt2, salt4, "Salt2 and Salt4 are the same"); assertNotEquals(salt3, salt4, "Salt3 and Salt4 are the same"); } private void assertNotEquals(byte[] b1, byte[] b2, String message) { if (Arrays.equals(b1, b2)) { fail(message); } } }