From ad7e99e9d6d00069d9f328b65405daf1e9159f11 Mon Sep 17 00:00:00 2001 From: Mark Waite Date: Sat, 11 Jan 2025 07:43:50 -0700 Subject: [PATCH 1/2] Use existing view in the job group test Restore a loss that I caused in the original test created by @yashpal2104. Thanks very much to @yashpal2104 for detecting the loss! --- .../priority/strategy/PriorityJobPropertyTest.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/test/java/jenkins/advancedqueue/priority/strategy/PriorityJobPropertyTest.java b/src/test/java/jenkins/advancedqueue/priority/strategy/PriorityJobPropertyTest.java index 5e1efff9..6242bdd0 100644 --- a/src/test/java/jenkins/advancedqueue/priority/strategy/PriorityJobPropertyTest.java +++ b/src/test/java/jenkins/advancedqueue/priority/strategy/PriorityJobPropertyTest.java @@ -75,13 +75,13 @@ public void descriptorImpl_getPrioritiesReturnsNonEmptyList() { private final Random random = new Random(); - private JobGroup createJobGroup() { + private JobGroup createJobGroup(String viewName) { JobGroup jobGroup = new JobGroup(); jobGroup.setDescription("testGroup-" + testName.getMethodName()); jobGroup.setRunExclusive(random.nextBoolean()); jobGroup.setUsePriorityStrategies(random.nextBoolean()); jobGroup.setId(random.nextInt()); - jobGroup.setJobGroupStrategy(new ViewBasedJobInclusionStrategy("existingView")); // Use the newly created view + jobGroup.setJobGroupStrategy(new ViewBasedJobInclusionStrategy(viewName)); return jobGroup; } @@ -103,7 +103,7 @@ public void descriptorImpl_isUsedReturnsTrueWhenJobGroupUsesPriorityStrategies() // Set up the PriorityJobProperty.DescriptorImpl PriorityConfiguration configuration = PriorityConfiguration.get(); List jobGroups = configuration.getJobGroups(); - JobGroup jobGroup = createJobGroup(); + JobGroup jobGroup = createJobGroup(view.getViewName()); jobGroup.setUsePriorityStrategies(true); // Add a PriorityStrategyHolder with a JobPropertyStrategy to the JobGroup @@ -124,7 +124,7 @@ public void descriptorImpl_isUsedReturnsFalseWhenJobGroupDoesNotUsePriorityStrat FreeStyleProject project = j.createFreeStyleProject(); PriorityConfiguration configuration = PriorityConfiguration.get(); List jobGroups = configuration.getJobGroups(); - JobGroup jobGroup = createJobGroup(); + JobGroup jobGroup = createJobGroup("defaultView"); jobGroups.add(jobGroup); configuration.setJobGroups(jobGroups); assertFalse(descriptor.isUsed(project)); From 557d268647ea3674dd7ba869eaed5283e3f7a3e2 Mon Sep 17 00:00:00 2001 From: Mark Waite Date: Sat, 11 Jan 2025 08:17:43 -0700 Subject: [PATCH 2/2] Broaden tests for existing and non-existing views --- .../strategy/PriorityJobPropertyTest.java | 29 +++++++++++++++---- 1 file changed, 24 insertions(+), 5 deletions(-) diff --git a/src/test/java/jenkins/advancedqueue/priority/strategy/PriorityJobPropertyTest.java b/src/test/java/jenkins/advancedqueue/priority/strategy/PriorityJobPropertyTest.java index 6242bdd0..5adc6c4c 100644 --- a/src/test/java/jenkins/advancedqueue/priority/strategy/PriorityJobPropertyTest.java +++ b/src/test/java/jenkins/advancedqueue/priority/strategy/PriorityJobPropertyTest.java @@ -79,14 +79,13 @@ private JobGroup createJobGroup(String viewName) { JobGroup jobGroup = new JobGroup(); jobGroup.setDescription("testGroup-" + testName.getMethodName()); jobGroup.setRunExclusive(random.nextBoolean()); - jobGroup.setUsePriorityStrategies(random.nextBoolean()); jobGroup.setId(random.nextInt()); jobGroup.setJobGroupStrategy(new ViewBasedJobInclusionStrategy(viewName)); return jobGroup; } @Test - public void descriptorImpl_isUsedReturnsTrueWhenJobGroupUsesPriorityStrategies() throws IOException { + public void isUsedWhenViewExists() throws IOException { // Create a new FreeStyleProject FreeStyleProject project = j.createFreeStyleProject(); @@ -115,16 +114,36 @@ public void descriptorImpl_isUsedReturnsTrueWhenJobGroupUsesPriorityStrategies() jobGroups.add(jobGroup); configuration.setJobGroups(jobGroups); - // Assert the descriptor is used + // Assert the strategy is used when priority strategies are used and view exists assertTrue(descriptor.isUsed(project)); + + // Replace the jobGroup with one that does not use priority strategies + jobGroups.remove(jobGroup); + jobGroup.setUsePriorityStrategies(false); + jobGroups.add(jobGroup); + configuration.setJobGroups(jobGroups); + + // Assert the strategy is not used when priority strategies are not used even if view exists + assertFalse(descriptor.isUsed(project)); } @Test - public void descriptorImpl_isUsedReturnsFalseWhenJobGroupDoesNotUsePriorityStrategies() throws IOException { + public void isUsedWhenViewDoesNotExist() throws IOException { FreeStyleProject project = j.createFreeStyleProject(); PriorityConfiguration configuration = PriorityConfiguration.get(); List jobGroups = configuration.getJobGroups(); - JobGroup jobGroup = createJobGroup("defaultView"); + JobGroup jobGroup = createJobGroup("intentionally-non-existent-view"); + + // Use priority strategies does not make a non-existing view used + jobGroup.setUsePriorityStrategies(true); + jobGroups.add(jobGroup); + configuration.setJobGroups(jobGroups); + assertFalse(descriptor.isUsed(project)); + + // Not using priority strategies does not make a non-existing view used + // Replace the jobGroup with one that does not use priority strategies + jobGroups.remove(jobGroup); + jobGroup.setUsePriorityStrategies(false); jobGroups.add(jobGroup); configuration.setJobGroups(jobGroups); assertFalse(descriptor.isUsed(project));