/****************************************************************************** * Copyright © 2013-2016 The Nxt Core Developers. * * * * See the AUTHORS.txt, DEVELOPER-AGREEMENT.txt and LICENSE.txt files at * * the top-level directory of this distribution for the individual copyright * * holder information and the developer policies on copyright and licensing. * * * * Unless otherwise agreed in a custom licensing agreement, no part of the * * Nxt software, including this file, may be copied, modified, propagated, * * or distributed except according to the terms contained in the LICENSE.txt * * file. * * * * Removal or modification of this copyright notice is prohibited. * * * ******************************************************************************/ package nxt.crypto; import org.junit.Assert; import org.junit.Test; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; public class SecureRandomTest { @Test public void simpleSecureRandom() { SecureRandom secureRandom = new SecureRandom(); byte[] iv = new byte[32]; for (int i=0; i<30; i++) { secureRandom.nextBytes(iv); } } @Test public void sha1prngSecureRandom() { try { SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG"); byte[] iv = new byte[32]; for (int i=0; i<30; i++) { secureRandom.nextBytes(iv); } } catch (NoSuchAlgorithmException e) { Assert.fail(e.getMessage()); } } @Test public void strongSecureRandom() { try { SecureRandom secureRandom = SecureRandom.getInstanceStrong(); byte[] iv = new byte[32]; for (int i=0; i<30; i++) { secureRandom.nextBytes(iv); } } catch (NoSuchAlgorithmException e) { Assert.fail(e.getMessage()); } } public static void main(String[] args) { long startTime = System.currentTimeMillis(); new SecureRandomTest().simpleSecureRandom(); System.out.println("simpleSecureRandom:" + (System.currentTimeMillis() - startTime)); startTime = System.currentTimeMillis(); new SecureRandomTest().sha1prngSecureRandom(); System.out.println("sha1prngSecureRandom:" + (System.currentTimeMillis() - startTime)); startTime = System.currentTimeMillis(); new SecureRandomTest().strongSecureRandom(); System.out.println("strongSecureRandom:" + (System.currentTimeMillis() - startTime)); } }