Path: blob/master/test/jdk/sun/security/provider/SeedGenerator/SeedGeneratorChoice.java
41154 views
/*1* Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/*24* @test25* @bug 6998583 814103926* @summary NativeSeedGenerator is making 8192 byte read requests from27* entropy pool on each init.28* @run main/othervm -Djava.security.egd=file:/dev/random SeedGeneratorChoice29* @run main/othervm -Djava.security.egd=file:filename SeedGeneratorChoice30*/3132/*33* Side testcase introduced to ensure changes for 6998583 will always34* succeed in falling back to ThreadedSeedGenerator if issues are found35* with the native OS generator request. We should never see an exception36* causing exit.37* We should always fall back to the ThreadedSeedGenerator if exceptions38* are encountered with user defined source of entropy.39*/40import java.security.SecureRandom;41import java.security.Security;4243public class SeedGeneratorChoice {4445public static void main(String... arguments) throws Exception {46for (String mech : new String[]{"SHA1PRNG", "Hash_DRBG", "HMAC_DRBG",47"CTR_DRBG"}) {4849SecureRandom prng = null;50if (!mech.contains("_DRBG")) {51prng = SecureRandom.getInstance(mech);52} else {53Security.setProperty("securerandom.drbg.config", mech);54prng = SecureRandom.getInstance("DRBG");55}56prng.generateSeed(1);57}58}5960}616263