test/jdk/sun/security/tools/jarsigner/warnings/NoTimestampTest.java
author jjiang
Thu, 13 Dec 2018 12:34:35 +0800
changeset 52999 8b585e1b2805
parent 51675 b487c1e914d0
child 54183 7418b266e1c7
permissions -rw-r--r--
8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date Reviewed-by: xuelei
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
     1
/*
48893
454518b338b0 8191438: jarsigner should print when a timestamp will expire
weijun
parents: 47216
diff changeset
     2
 * Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved.
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
     4
 *
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
     7
 * published by the Free Software Foundation.
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
     8
 *
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    13
 * accompanied this code).
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    14
 *
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    18
 *
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    21
 * questions.
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    22
 */
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    23
52999
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
    24
import java.io.FileInputStream;
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
    25
import java.io.InputStream;
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
    26
import java.security.KeyStore;
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
    27
import java.security.cert.X509Certificate;
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    28
import java.util.Date;
50779
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    29
import java.util.Locale;
52999
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
    30
51675
b487c1e914d0 8210112: remove jdk.testlibrary.ProcessTools
iignatyev
parents: 50779
diff changeset
    31
import jdk.test.lib.process.OutputAnalyzer;
45287
e0bb5f83e17a 8180888: move jdk.testlibrary.JarUtils to the top level testlibrary
iignatyev
parents: 40262
diff changeset
    32
import jdk.test.lib.util.JarUtils;
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    33
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    34
/**
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    35
 * @test
50779
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    36
 * @bug 8024302 8026037 8196213
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    37
 * @summary Checks warnings if -tsa and -tsacert options are not specified
51675
b487c1e914d0 8210112: remove jdk.testlibrary.ProcessTools
iignatyev
parents: 50779
diff changeset
    38
 * @library /test/lib ../
45467
99c87a16a8e4 8181761: add explicit @build actions for jdk.test.lib classes in all :tier2 tests
iignatyev
parents: 45287
diff changeset
    39
 * @build jdk.test.lib.util.JarUtils
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    40
 * @run main NoTimestampTest
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    41
 */
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    42
public class NoTimestampTest extends Test {
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    43
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    44
    /**
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    45
     * The test signs and verifies a jar file without -tsa and -tsacert options,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    46
     * and checks that proper warnings are shown.
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    47
     */
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    48
    public static void main(String[] args) throws Throwable {
50779
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    49
        Locale reservedLocale = Locale.getDefault();
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    50
        Locale.setDefault(Locale.US);
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    51
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    52
        try {
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    53
            NoTimestampTest test = new NoTimestampTest();
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    54
            test.start();
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    55
        } finally {
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    56
            // Restore the reserved locale
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    57
            Locale.setDefault(reservedLocale);
7284ce754713 8196213: sun/security/tools/jarsigner/warnings/NoTimestampTest.java test fails on ar_SA locale.
xiaofeya
parents: 48893
diff changeset
    58
        }
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    59
    }
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    60
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    61
    private void start() throws Throwable {
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    62
        String timezone = System.getProperty("user.timezone");
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    63
        System.out.println(String.format("Timezone = %s", timezone));
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    64
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    65
        // create a jar file that contains one class file
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    66
        Utils.createFiles(FIRST_FILE);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    67
        JarUtils.createJar(UNSIGNED_JARFILE, FIRST_FILE);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    68
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    69
        // create key pair
48893
454518b338b0 8191438: jarsigner should print when a timestamp will expire
weijun
parents: 47216
diff changeset
    70
        createAlias(CA_KEY_ALIAS);
454518b338b0 8191438: jarsigner should print when a timestamp will expire
weijun
parents: 47216
diff changeset
    71
        createAlias(KEY_ALIAS);
454518b338b0 8191438: jarsigner should print when a timestamp will expire
weijun
parents: 47216
diff changeset
    72
        issueCert(KEY_ALIAS,
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    73
                "-validity", Integer.toString(VALIDITY));
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    74
52999
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
    75
        Date expirationDate = getCertExpirationDate();
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
    76
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    77
        // sign jar file
40262
1b3dd37cb96d 8133910: Some sun/security/tools tests failed.
weijun
parents: 28662
diff changeset
    78
        OutputAnalyzer analyzer = jarsigner(
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    79
                "-J-Duser.timezone=" + timezone,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    80
                "-keystore", KEYSTORE,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    81
                "-storepass", PASSWORD,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    82
                "-keypass", PASSWORD,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    83
                "-signedjar", SIGNED_JARFILE,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    84
                UNSIGNED_JARFILE,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    85
                KEY_ALIAS);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    86
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    87
        String warning = String.format(NO_TIMESTAMP_SIGNING_WARN_TEMPLATE,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    88
                expirationDate);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    89
        checkSigning(analyzer, warning);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    90
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    91
        // verify signed jar
40262
1b3dd37cb96d 8133910: Some sun/security/tools tests failed.
weijun
parents: 28662
diff changeset
    92
        analyzer = jarsigner(
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    93
                "-J-Duser.timezone=" + timezone,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    94
                "-verify",
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    95
                "-keystore", KEYSTORE,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    96
                "-storepass", PASSWORD,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    97
                "-keypass", PASSWORD,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    98
                SIGNED_JARFILE,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
    99
                KEY_ALIAS);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   100
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   101
        warning = String.format(NO_TIMESTAMP_VERIFYING_WARN_TEMPLATE, expirationDate);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   102
        checkVerifying(analyzer, 0, warning);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   103
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   104
        // verify signed jar in strict mode
40262
1b3dd37cb96d 8133910: Some sun/security/tools tests failed.
weijun
parents: 28662
diff changeset
   105
        analyzer = jarsigner(
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   106
                "-J-Duser.timezone=" + timezone,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   107
                "-verify",
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   108
                "-strict",
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   109
                "-keystore", KEYSTORE,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   110
                "-storepass", PASSWORD,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   111
                "-keypass", PASSWORD,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   112
                SIGNED_JARFILE,
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   113
                KEY_ALIAS);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   114
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   115
        checkVerifying(analyzer, 0, warning);
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   116
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   117
        System.out.println("Test passed");
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   118
    }
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   119
52999
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
   120
    private static Date getCertExpirationDate() throws Exception {
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
   121
        KeyStore ks = KeyStore.getInstance("JKS");
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
   122
        try (InputStream in = new FileInputStream(KEYSTORE)) {
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
   123
            ks.load(in, PASSWORD.toCharArray());
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
   124
        }
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
   125
        X509Certificate cert = (X509Certificate) ks.getCertificate(KEY_ALIAS);
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
   126
        return cert.getNotAfter();
8b585e1b2805 8214937: sun/security/tools/jarsigner/warnings/NoTimestampTest.java failed due to unexpected expiration date
jjiang
parents: 51675
diff changeset
   127
    }
28662
efd0203db371 8049171: Additional tests for jarsigner's warnings
asmotrak
parents:
diff changeset
   128
}