From 29f015cf61fb8dadb53176c7543062f29c0cd4f9 Mon Sep 17 00:00:00 2001 From: Andy Herrick Date: Thu, 7 May 2020 10:54:18 -0400 Subject: [PATCH] 8236518: There is no Native Packages WinUpgradeUUIDTest-2.0.exe after creating Native packages on win Reviewed-by: asemenyuk, almatvee --- .../jdk/jpackage/test/JPackageCommand.java | 2 +- .../jpackage/helpers/jdk/jpackage/test/TKit.java | 9 +++++++++ .../jpackage/windows/WinUpgradeUUIDTest.java | 15 ++++++++------- 3 files changed, 18 insertions(+), 8 deletions(-) diff --git a/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/JPackageCommand.java b/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/JPackageCommand.java index a4e7b2ae3a0..706757371ff 100644 --- a/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/JPackageCommand.java +++ b/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/JPackageCommand.java @@ -603,7 +603,7 @@ public final class JPackageCommand extends CommandArguments { if (isImagePackageType()) { TKit.deleteDirectoryContentsRecursive(outputDir()); - } else if (ThrowingSupplier.toSupplier(() -> Files.deleteIfExists( + } else if (ThrowingSupplier.toSupplier(() -> TKit.deleteIfExists( outputBundle())).get()) { TKit.trace( String.format("Deleted [%s] file before running jpackage", diff --git a/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/TKit.java b/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/TKit.java index ff96a3cd874..dd474e0be33 100644 --- a/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/TKit.java +++ b/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/TKit.java @@ -399,6 +399,15 @@ final public class TKit { private boolean contentsOnly; } + public static boolean deleteIfExists(Path path) throws IOException { + if (isWindows()) { + if (path.toFile().exists()) { + Files.setAttribute(path, "dos:readonly", false); + } + } + return Files.deleteIfExists(path); + } + /** * Deletes contents of the given directory recursively. Shortcut for * deleteDirectoryContentsRecursive(path, null) diff --git a/test/jdk/tools/jpackage/windows/WinUpgradeUUIDTest.java b/test/jdk/tools/jpackage/windows/WinUpgradeUUIDTest.java index 579b72f019d..fd0c3b9d5b1 100644 --- a/test/jdk/tools/jpackage/windows/WinUpgradeUUIDTest.java +++ b/test/jdk/tools/jpackage/windows/WinUpgradeUUIDTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2019, 2020, 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 @@ -65,7 +65,7 @@ import jdk.jpackage.test.TKit; * @requires (jpackage.test.SQETest == null) * @build jdk.jpackage.test.* * @requires (os.family == "windows") - * @modules jdk.jpackage/jdk.jpackage.internal + * @modules jdk.incubator.jpackage/jdk.incubator.jpackage.internal * @compile WinUpgradeUUIDTest.java * @run main/othervm/timeout=540 -Xmx512m jdk.jpackage.test.Main * --jpt-run=WinUpgradeUUIDTest @@ -79,10 +79,6 @@ public class WinUpgradeUUIDTest { final UUID upgradeCode = UUID.fromString( "F0B18E75-52AD-41A2-BC86-6BE4FCD50BEB"); return new PackageTest() - .forTypes(PackageType.WINDOWS) - .configureHelloApp() - .addInitializer(cmd -> cmd.addArguments("--win-upgrade-uuid", - upgradeCode.toString())) .forTypes(PackageType.WIN_MSI) .addBundlePropertyVerifier("UpgradeCode", value -> { if (value.startsWith("{")) { @@ -92,7 +88,12 @@ public class WinUpgradeUUIDTest { value = value.substring(0, value.length() - 1); } return UUID.fromString(value).equals(upgradeCode); - }, "is a match with"); + }, "is a match with") + .forTypes(PackageType.WINDOWS) + .configureHelloApp() + .addInitializer(cmd -> cmd.addArguments("--win-upgrade-uuid", + upgradeCode.toString())) ; + }; // Replace real uninstall command for the first package with nop action.