/* * * Panbox - encryption for cloud storage * Copyright (C) 2014-2015 by Fraunhofer SIT and Sirrix AG * * This program 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 3 of the License, or * (at your option) any later version. * * This program 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 this program. If not, see <http://www.gnu.org/licenses/>. * * Additonally, third party code may be provided with notices and open source * licenses from communities and third parties that govern the use of those * portions, and any licenses granted hereunder do not alter any rights and * obligations you may have under such open source licenses, however, the * disclaimer of warranty and limitation of liability provisions of the GPLv3 * will apply to all the product. * */ package org.panbox.core.identitymgmt; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; import static org.junit.Assert.fail; import java.security.KeyPair; import java.security.Security; import java.security.UnrecoverableKeyException; import org.junit.After; import org.junit.AfterClass; import org.junit.Before; import org.junit.BeforeClass; import org.junit.Test; import org.panbox.core.crypto.CryptCore; import org.panbox.core.crypto.KeyConstants; import org.panbox.core.identitymgmt.exceptions.ContactExistsException; public class TestCreateIdentity extends IdentityHelper { @BeforeClass public static void setUpBeforeClass() throws Exception { } @AfterClass public static void tearDownAfterClass() throws Exception { } @Before public void setUp() throws Exception { Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider()); } @After public void tearDown() throws Exception { } @Test public void test() { SimpleAddressbook addressbook = new SimpleAddressbook(); Identity id = new Identity(addressbook, "testIdentity@example.org", "FirstName", "Lastname"); assertNotNull(id); KeyPair ownerKeySign = CryptCore.generateKeypair(); assertNotNull(ownerKeySign); KeyPair ownerKeyEnc = CryptCore.generateKeypair(); assertNotNull(ownerKeyEnc); KeyPair deviceKey = CryptCore.generateKeypair(); assertNotNull(deviceKey); id.setOwnerKeySign(ownerKeySign, "test".toCharArray()); id.setOwnerKeyEnc(ownerKeyEnc, "test".toCharArray()); id.addDeviceKey(deviceKey, "laptop"); // add some contacts for (int i = 0; i < 3; i++) { PanboxContact contact = createContact("Contact Name " + i, "contact" + i + "@example.org"); try { addressbook.addContact(contact); } catch (ContactExistsException e) { // TODO Auto-generated catch block e.printStackTrace(); } } // test if names match assertEquals("FirstName", id.getFirstName()); assertEquals("Lastname", id.getName()); // test if email matches assertEquals("testIdentity@example.org", id.getEmail()); assertNotNull(id.getAddressbook()); // test if there are 5 contacts in the addressbook assertEquals(id.getAddressbook().size(), 3); // test if device key matches try { assertEquals(deviceKey.getPublic(), id.getPublicKeyForDevice("laptop")); assertEquals(deviceKey.getPrivate(), id.getPrivateKeyForDevice(KeyConstants.OPEN_KEYSTORE_PASSWORD, "laptop")); } catch (Exception e) { e.printStackTrace(); fail(e.getMessage()); } // test if sign key matches assertEquals(ownerKeySign.getPublic(), id.getPublicKeySign()); try { assertEquals(ownerKeySign.getPrivate(), id.getPrivateKeySign("test".toCharArray())); } catch (UnrecoverableKeyException e1) { e1.printStackTrace(); } // test if enc key matches try { assertEquals(ownerKeyEnc.getPrivate(), id.getPrivateKeyEnc("test".toCharArray())); } catch (UnrecoverableKeyException e) { fail(); } assertEquals(ownerKeyEnc.getPublic(), id.getPublicKeyEnc()); } }