From e800cc2d2dd3c1290754c6e2c305976afec095ff Mon Sep 17 00:00:00 2001 From: Andy Herrick Date: Fri, 7 Aug 2020 11:42:42 -0400 Subject: [PATCH] 8251184: File association without description causes exception Reviewed-by: asemenyuk, almatvee --- .../incubator/jpackage/internal/FileAssociation.java | 10 +++++++--- .../jpackage/internal/StandardBundlerParam.java | 4 ++-- .../helpers/jdk/jpackage/test/FileAssociations.java | 6 ++++-- .../tools/jpackage/share/FileAssociationsTest.java | 11 +++++++++-- 4 files changed, 22 insertions(+), 9 deletions(-) diff --git a/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/FileAssociation.java b/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/FileAssociation.java index 20d9ed9c121..b4b9be9f150 100644 --- a/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/FileAssociation.java +++ b/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/FileAssociation.java @@ -79,11 +79,15 @@ final class FileAssociation { FileAssociation assoc = new FileAssociation(); assoc.launcherPath = Path.of(launcherName); - assoc.description = FA_DESCRIPTION.fetchFrom(fa); + assoc.description = Optional.ofNullable( + FA_DESCRIPTION.fetchFrom(fa)) + .orElse(launcherName + " association"); assoc.extensions = Optional.ofNullable( - FA_EXTENSIONS.fetchFrom(fa)).orElse(Collections.emptyList()); + FA_EXTENSIONS.fetchFrom(fa)) + .orElse(Collections.emptyList()); assoc.mimeTypes = Optional.ofNullable( - FA_CONTENT_TYPE.fetchFrom(fa)).orElse(Collections.emptyList()); + FA_CONTENT_TYPE.fetchFrom(fa)) + .orElse(Collections.emptyList()); Path icon = FA_ICON.fetchFrom(fa); if (icon != null) { diff --git a/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/StandardBundlerParam.java b/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/StandardBundlerParam.java index d36b08baafa..173e5183f94 100644 --- a/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/StandardBundlerParam.java +++ b/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/StandardBundlerParam.java @@ -338,8 +338,8 @@ class StandardBundlerParam extends BundlerParamInfo { new StandardBundlerParam<>( "fileAssociation.description", String.class, - params -> APP_NAME.fetchFrom(params) + " Path", - null + p -> null, + (s, p) -> s ); static final StandardBundlerParam FA_ICON = diff --git a/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/FileAssociations.java b/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/FileAssociations.java index 91fefc91c06..732cbb9240f 100644 --- a/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/FileAssociations.java +++ b/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/FileAssociations.java @@ -38,9 +38,11 @@ final public class FileAssociations { private void createFile() { Map entries = new HashMap<>(Map.of( "extension", suffixName, - "mime-type", getMime(), - "description", description + "mime-type", getMime() )); + if (description != null) { + entries.put("description", description); + } if (icon != null) { if (TKit.isWindows()) { entries.put("icon", icon.toString().replace("\\", "/")); diff --git a/test/jdk/tools/jpackage/share/FileAssociationsTest.java b/test/jdk/tools/jpackage/share/FileAssociationsTest.java index 0b0a97c057b..fcad5e7d15d 100644 --- a/test/jdk/tools/jpackage/share/FileAssociationsTest.java +++ b/test/jdk/tools/jpackage/share/FileAssociationsTest.java @@ -29,6 +29,7 @@ import jdk.jpackage.test.PackageTest; import jdk.jpackage.test.PackageType; import jdk.jpackage.test.FileAssociations; import jdk.jpackage.test.Annotations.Test; +import jdk.jpackage.test.Annotations.Parameter; /** * Test --file-associations parameter. Output of the test should be @@ -81,13 +82,19 @@ import jdk.jpackage.test.Annotations.Test; public class FileAssociationsTest { @Test - public static void test() { + @Parameter("true") + @Parameter("false") + public static void test(boolean includeDescription) { PackageTest packageTest = new PackageTest(); // Not supported packageTest.excludeTypes(PackageType.MAC_DMG); - new FileAssociations("jptest1").applyTo(packageTest); + FileAssociations fa = new FileAssociations("jptest1"); + if (!includeDescription) { + fa.setDescription(null); + } + fa.applyTo(packageTest); Path icon = TKit.TEST_SRC_ROOT.resolve(Path.of("resources", "icon" + TKit.ICON_SUFFIX));