2015-01-26 18:13:42 +08:00
|
|
|
/*
|
2019-10-22 17:25:34 -04:00
|
|
|
* Copyright (c) 2013, 2019, Oracle and/or its affiliates. All rights reserved.
|
2015-01-26 18:13:42 +08:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code 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
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*/
|
|
|
|
|
2018-09-07 14:01:52 -07:00
|
|
|
import jdk.test.lib.process.OutputAnalyzer;
|
2017-05-30 21:07:08 -07:00
|
|
|
import jdk.test.lib.util.JarUtils;
|
2015-01-26 18:13:42 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
2017-03-08 15:35:56 +08:00
|
|
|
* @bug 8024302 8026037 8176320
|
2015-01-26 18:13:42 +08:00
|
|
|
* @summary The test signs and verifies a jar file with -tsacert option
|
2016-08-11 13:10:54 +08:00
|
|
|
* @library /lib/testlibrary warnings
|
2017-03-08 15:35:56 +08:00
|
|
|
* @library /test/lib
|
2016-04-09 20:12:13 +01:00
|
|
|
* @modules java.base/sun.security.pkcs
|
2015-05-28 10:54:48 -07:00
|
|
|
* java.base/sun.security.timestamp
|
2016-10-20 14:11:26 +08:00
|
|
|
* java.base/sun.security.tools.keytool
|
2015-05-28 10:54:48 -07:00
|
|
|
* java.base/sun.security.util
|
|
|
|
* java.base/sun.security.x509
|
|
|
|
* java.management
|
2017-06-12 12:43:26 -07:00
|
|
|
* @build jdk.test.lib.util.JarUtils
|
2015-01-26 18:13:42 +08:00
|
|
|
* @run main TsacertOptionTest
|
|
|
|
*/
|
2016-08-11 13:10:54 +08:00
|
|
|
public class TsacertOptionTest extends Test {
|
|
|
|
|
2015-01-26 18:13:42 +08:00
|
|
|
private static final String FILENAME = TsacertOptionTest.class.getName()
|
|
|
|
+ ".txt";
|
|
|
|
private static final String SIGNING_KEY_ALIAS = "sign_alias";
|
|
|
|
private static final String TSA_KEY_ALIAS = "ts";
|
2016-08-11 13:10:54 +08:00
|
|
|
|
|
|
|
private static final String PASSWORD = "changeit";
|
2015-01-26 18:13:42 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The test signs and verifies a jar file with -tsacert option,
|
|
|
|
* and checks that no warning was shown.
|
|
|
|
* A certificate that is addressed in -tsacert option contains URL to TSA
|
|
|
|
* in Subject Information Access extension.
|
|
|
|
*/
|
|
|
|
public static void main(String[] args) throws Throwable {
|
|
|
|
TsacertOptionTest test = new TsacertOptionTest();
|
|
|
|
test.start();
|
|
|
|
}
|
|
|
|
|
|
|
|
void start() throws Throwable {
|
|
|
|
// create a jar file that contains one file
|
|
|
|
Utils.createFiles(FILENAME);
|
|
|
|
JarUtils.createJar(UNSIGNED_JARFILE, FILENAME);
|
|
|
|
|
|
|
|
// create key pair for jar signing
|
2016-08-11 13:10:54 +08:00
|
|
|
keytool(
|
2015-01-26 18:13:42 +08:00
|
|
|
"-genkey",
|
2015-12-02 16:44:57 +08:00
|
|
|
"-alias", CA_KEY_ALIAS,
|
2015-01-26 18:13:42 +08:00
|
|
|
"-keyalg", KEY_ALG,
|
|
|
|
"-keysize", Integer.toString(KEY_SIZE),
|
|
|
|
"-keystore", KEYSTORE,
|
|
|
|
"-storepass", PASSWORD,
|
|
|
|
"-keypass", PASSWORD,
|
2015-12-02 16:44:57 +08:00
|
|
|
"-dname", "CN=CA",
|
2019-10-22 17:25:34 -04:00
|
|
|
"-ext", "bc:c",
|
2015-01-26 18:13:42 +08:00
|
|
|
"-validity", Integer.toString(VALIDITY)).shouldHaveExitValue(0);
|
2016-08-11 13:10:54 +08:00
|
|
|
keytool(
|
2015-12-02 16:44:57 +08:00
|
|
|
"-genkey",
|
|
|
|
"-alias", SIGNING_KEY_ALIAS,
|
|
|
|
"-keyalg", KEY_ALG,
|
|
|
|
"-keysize", Integer.toString(KEY_SIZE),
|
|
|
|
"-keystore", KEYSTORE,
|
|
|
|
"-storepass", PASSWORD,
|
|
|
|
"-keypass", PASSWORD,
|
|
|
|
"-dname", "CN=Test").shouldHaveExitValue(0);
|
2016-08-11 13:10:54 +08:00
|
|
|
keytool(
|
2015-12-02 16:44:57 +08:00
|
|
|
"-certreq",
|
|
|
|
"-alias", SIGNING_KEY_ALIAS,
|
|
|
|
"-keystore", KEYSTORE,
|
|
|
|
"-storepass", PASSWORD,
|
|
|
|
"-keypass", PASSWORD,
|
|
|
|
"-file", "certreq").shouldHaveExitValue(0);
|
2016-08-11 13:10:54 +08:00
|
|
|
keytool(
|
2015-12-02 16:44:57 +08:00
|
|
|
"-gencert",
|
|
|
|
"-alias", CA_KEY_ALIAS,
|
|
|
|
"-keystore", KEYSTORE,
|
|
|
|
"-storepass", PASSWORD,
|
|
|
|
"-keypass", PASSWORD,
|
|
|
|
"-validity", Integer.toString(VALIDITY),
|
|
|
|
"-infile", "certreq",
|
|
|
|
"-outfile", "cert").shouldHaveExitValue(0);
|
2016-08-11 13:10:54 +08:00
|
|
|
keytool(
|
2015-12-02 16:44:57 +08:00
|
|
|
"-importcert",
|
|
|
|
"-alias", SIGNING_KEY_ALIAS,
|
|
|
|
"-keystore", KEYSTORE,
|
|
|
|
"-storepass", PASSWORD,
|
|
|
|
"-keypass", PASSWORD,
|
|
|
|
"-file", "cert").shouldHaveExitValue(0);
|
2015-01-26 18:13:42 +08:00
|
|
|
|
|
|
|
|
2016-08-10 11:21:01 +08:00
|
|
|
try (TimestampCheck.Handler tsa = TimestampCheck.Handler.init(0,
|
|
|
|
KEYSTORE)) {
|
|
|
|
|
|
|
|
// look for free network port for TSA service
|
|
|
|
int port = tsa.getPort();
|
|
|
|
String host = "127.0.0.1";
|
|
|
|
String tsaUrl = "http://" + host + ":" + port;
|
|
|
|
|
|
|
|
// create key pair for TSA service
|
|
|
|
// SubjectInfoAccess extension contains URL to TSA service
|
2016-08-11 13:10:54 +08:00
|
|
|
keytool(
|
2016-08-10 11:21:01 +08:00
|
|
|
"-genkey",
|
|
|
|
"-v",
|
|
|
|
"-alias", TSA_KEY_ALIAS,
|
|
|
|
"-keyalg", KEY_ALG,
|
|
|
|
"-keysize", Integer.toString(KEY_SIZE),
|
|
|
|
"-keystore", KEYSTORE,
|
|
|
|
"-storepass", PASSWORD,
|
|
|
|
"-keypass", PASSWORD,
|
|
|
|
"-dname", "CN=TSA",
|
|
|
|
"-ext", "ExtendedkeyUsage:critical=timeStamping",
|
|
|
|
"-ext", "SubjectInfoAccess=timeStamping:URI:" + tsaUrl,
|
|
|
|
"-validity", Integer.toString(VALIDITY)).shouldHaveExitValue(0);
|
2015-01-26 18:13:42 +08:00
|
|
|
|
|
|
|
// start TSA
|
|
|
|
tsa.start();
|
|
|
|
|
|
|
|
// sign jar file
|
|
|
|
// specify -tsadigestalg option because
|
|
|
|
// TSA server uses SHA-1 digest algorithm
|
2016-08-11 13:10:54 +08:00
|
|
|
OutputAnalyzer analyzer = jarsigner(
|
2015-07-14 16:46:28 +01:00
|
|
|
"-J-Dhttp.proxyHost=",
|
|
|
|
"-J-Dhttp.proxyPort=",
|
|
|
|
"-J-Djava.net.useSystemProxies=",
|
2015-01-26 18:13:42 +08:00
|
|
|
"-verbose",
|
|
|
|
"-keystore", KEYSTORE,
|
|
|
|
"-storepass", PASSWORD,
|
|
|
|
"-keypass", PASSWORD,
|
|
|
|
"-signedjar", SIGNED_JARFILE,
|
|
|
|
"-tsacert", TSA_KEY_ALIAS,
|
|
|
|
"-tsadigestalg", "SHA-1",
|
|
|
|
UNSIGNED_JARFILE,
|
|
|
|
SIGNING_KEY_ALIAS);
|
|
|
|
|
|
|
|
analyzer.shouldHaveExitValue(0);
|
|
|
|
analyzer.stdoutShouldNotContain(WARNING);
|
|
|
|
analyzer.shouldContain(JAR_SIGNED);
|
|
|
|
|
|
|
|
// verify signed jar
|
2016-08-11 13:10:54 +08:00
|
|
|
analyzer = jarsigner(
|
2015-01-26 18:13:42 +08:00
|
|
|
"-verbose",
|
|
|
|
"-verify",
|
|
|
|
"-keystore", KEYSTORE,
|
|
|
|
"-storepass", PASSWORD,
|
|
|
|
SIGNED_JARFILE);
|
|
|
|
|
|
|
|
analyzer.shouldHaveExitValue(0);
|
|
|
|
analyzer.stdoutShouldNotContain(WARNING);
|
|
|
|
analyzer.shouldContain(JAR_VERIFIED);
|
|
|
|
}
|
|
|
|
|
|
|
|
System.out.println("Test passed");
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|