# HG changeset patch # User weijun # Date 1477903231 -28800 # Node ID 9398d77cc4bb54c227372204de6f09dade406246 # Parent ca3b0be067ee19e13814fd2ce3a501b9c967f5c3 8168127: FilePermissionCollection merges incorrectly Reviewed-by: rriggs diff -r ca3b0be067ee -r 9398d77cc4bb jdk/src/java.base/share/classes/java/io/FilePermission.java --- a/jdk/src/java.base/share/classes/java/io/FilePermission.java Mon Oct 31 13:45:36 2016 +0800 +++ b/jdk/src/java.base/share/classes/java/io/FilePermission.java Mon Oct 31 16:40:31 2016 +0800 @@ -218,8 +218,8 @@ * A private constructor like a clone, only npath2 is not touched. * @param input */ - private FilePermission(FilePermission input) { - super(input.getName()); + private FilePermission(String name, FilePermission input) { + super(name); this.npath = input.npath; this.actions = input.actions; this.allFiles = input.allFiles; @@ -255,7 +255,12 @@ if (input.npath2 == null && !input.allFiles) { Path npath2 = altPath(input.npath); if (npath2 != null) { - FilePermission np = new FilePermission(input); + // Please note the name of the new permission is + // different than the original so that when one is + // added to a FilePermissionCollection it will not + // be merged with the original one. + FilePermission np = new FilePermission( + input.getName()+"#plus", input); np.npath2 = npath2; return np; } @@ -266,7 +271,9 @@ if (!input.allFiles) { Path npath2 = altPath(input.npath); if (npath2 != null) { - FilePermission np = new FilePermission(input); + // New name, see above. + FilePermission np = new FilePermission( + input.getName()+"#using", input); np.npath = npath2; return np; } @@ -690,6 +697,7 @@ return (this.mask == that.mask) && (this.allFiles == that.allFiles) && this.npath.equals(that.npath) && + Objects.equals(npath2, that.npath2) && (this.directory == that.directory) && (this.recursive == that.recursive); } else { @@ -708,7 +716,8 @@ @Override public int hashCode() { if (FilePermCompat.nb) { - return Objects.hash(mask, allFiles, directory, recursive, npath); + return Objects.hash( + mask, allFiles, directory, recursive, npath, npath2); } else { return 0; } diff -r ca3b0be067ee -r 9398d77cc4bb jdk/test/java/io/FilePermission/FilePermissionCollectionMerge.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/jdk/test/java/io/FilePermission/FilePermissionCollectionMerge.java Mon Oct 31 16:40:31 2016 +0800 @@ -0,0 +1,102 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * 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. + */ + +/** + * + * @test + * @bug 8168127 + * @summary FilePermissionCollection merges incorrectly + * @modules java.base/sun.security.util + * @library /test/lib + */ + +import sun.security.util.FilePermCompat; +import java.io.FilePermission; +import java.security.Permissions; +import jdk.test.lib.Asserts; + +public class FilePermissionCollectionMerge { + + public static void main(String[] args) throws Exception { + test("x"); + test("x/*"); + test("x/-"); + test("*"); + test("-"); + test("/x"); + test("/x/*"); + test("/x/-"); + } + + static void test(String arg) { + + FilePermission fp1 = new FilePermission(arg, "read"); + FilePermission fp2 = (FilePermission) + FilePermCompat.newPermUsingAltPath(fp1); + FilePermission fp3 = (FilePermission) + FilePermCompat.newPermPlusAltPath(fp1); + + // All 3 are different + Asserts.assertNE(fp1, fp2); + Asserts.assertNE(fp1.hashCode(), fp2.hashCode()); + + Asserts.assertNE(fp1, fp3); + Asserts.assertNE(fp1.hashCode(), fp3.hashCode()); + + Asserts.assertNE(fp2, fp3); + Asserts.assertNE(fp2.hashCode(), fp3.hashCode()); + + // The plus one implies the other 2 + Asserts.assertTrue(fp3.implies(fp1)); + Asserts.assertTrue(fp3.implies(fp2)); + + // The using one different from original + Asserts.assertFalse(fp2.implies(fp1)); + Asserts.assertFalse(fp1.implies(fp2)); + + // FilePermssionCollection::implies always works + testMerge(fp1); + testMerge(fp2); + testMerge(fp3); + testMerge(fp1, fp2); + testMerge(fp1, fp3); + testMerge(fp2, fp1); + testMerge(fp2, fp3); + testMerge(fp3, fp1); + testMerge(fp3, fp2); + testMerge(fp1, fp2, fp3); + testMerge(fp2, fp3, fp1); + testMerge(fp3, fp1, fp2); + } + + // Add all into a collection, and check if it implies the last one. + static void testMerge(FilePermission... fps) { + java.security.Permissions perms = new Permissions(); + FilePermission last = null; + for (FilePermission fp : fps) { + perms.add(fp); + last = fp; + } + Asserts.assertTrue(perms.implies(last)); + } +}