diff --git a/src/main/java/org/jenkins/plugins/lockableresources/LockableResourcesManager.java b/src/main/java/org/jenkins/plugins/lockableresources/LockableResourcesManager.java index 94dddd59e..02144d7c0 100644 --- a/src/main/java/org/jenkins/plugins/lockableresources/LockableResourcesManager.java +++ b/src/main/java/org/jenkins/plugins/lockableresources/LockableResourcesManager.java @@ -643,19 +643,20 @@ private void freeResources(List unlockResources, Run bui removeResources(toBeRemoved); } - public void unlockBuild(@Nullable Run build) { + @NonNull + public List unlockBuild(@Nullable Run build) { if (build == null) { - return; + return Collections.emptyList(); } - List resourcesInUse = - LockedResourcesBuildAction.findAndInitAction(build).getCurrentUsedResourceNames(); + List resourcesInUse = new ArrayList<>( + LockedResourcesBuildAction.findAndInitAction(build).getCurrentUsedResourceNames()); - if (resourcesInUse.size() == 0) { - return; + if (!resourcesInUse.isEmpty()) { + unlockNames(resourcesInUse, build); } - unlockNames(resourcesInUse, build); + return resourcesInUse; } // --------------------------------------------------------------------------- diff --git a/src/main/java/org/jenkins/plugins/lockableresources/queue/LockRunListener.java b/src/main/java/org/jenkins/plugins/lockableresources/queue/LockRunListener.java index caceece3e..09e8faaa7 100644 --- a/src/main/java/org/jenkins/plugins/lockableresources/queue/LockRunListener.java +++ b/src/main/java/org/jenkins/plugins/lockableresources/queue/LockRunListener.java @@ -97,8 +97,15 @@ public void onCompleted(Run build, @NonNull TaskListener listener) { // Skip unlocking for multiple configuration projects, // only the child jobs will actually unlock resources. if (build instanceof MatrixBuild) return; - LOGGER.info(build.getFullDisplayName()); - LockableResourcesManager.get().unlockBuild(build); + + List unlocked = LockableResourcesManager.get().unlockBuild(build); + if (!unlocked.isEmpty()) { + listener.getLogger().printf("%s released lock on %s%n", LOG_PREFIX, unlocked); + LOGGER.info(build.getFullDisplayName() + + " released lock on " + + unlocked + + ", because the build has finished."); + } } @Override @@ -106,7 +113,13 @@ public void onDeleted(Run build) { // Skip unlocking for multiple configuration projects, // only the child jobs will actually unlock resources. if (build instanceof MatrixBuild) return; - LOGGER.info(build.getFullDisplayName()); - LockableResourcesManager.get().unlockBuild(build); + + List unlocked = LockableResourcesManager.get().unlockBuild(build); + if (!unlocked.isEmpty()) { + LOGGER.warning(build.getFullDisplayName() + + " released lock on " + + unlocked + + ", because the build has been deleted."); + } } } diff --git a/src/test/java/org/jenkins/plugins/lockableresources/FreeStyleProjectTest.java b/src/test/java/org/jenkins/plugins/lockableresources/FreeStyleProjectTest.java index a23e9d62a..4d8fdeba0 100644 --- a/src/test/java/org/jenkins/plugins/lockableresources/FreeStyleProjectTest.java +++ b/src/test/java/org/jenkins/plugins/lockableresources/FreeStyleProjectTest.java @@ -260,6 +260,7 @@ public boolean perform(AbstractBuild build, Launcher launcher, BuildListen QueueTaskFuture fb2q = f2.scheduleBuild2(0); semaphore.release(); + j.waitForMessage("released lock on [shared]", fb0); j.waitForCompletion(fb0); // fb1 or fb2 might run first, it shouldn't matter as long as they both get the resource FreeStyleBuild fb1 = fb1q.waitForStart(); diff --git a/src/test/java/org/jenkins/plugins/lockableresources/NodesMirrorTest.java b/src/test/java/org/jenkins/plugins/lockableresources/NodesMirrorTest.java index 3a70d4eb3..f5fada397 100644 --- a/src/test/java/org/jenkins/plugins/lockableresources/NodesMirrorTest.java +++ b/src/test/java/org/jenkins/plugins/lockableresources/NodesMirrorTest.java @@ -16,7 +16,7 @@ public class NodesMirrorTest { - private static final Logger LOGGER = Logger.getLogger(NodesMirror.class.getName()); + private static final Logger LOGGER = Logger.getLogger(NodesMirrorTest.class.getName()); @Rule public final JenkinsRule j = new JenkinsRule();