Skip to content

Commit

Permalink
Adds condition based on build description
Browse files Browse the repository at this point in the history
Request #128
  • Loading branch information
damianszczepanik committed Jun 17, 2024
1 parent 032ec92 commit 2789eff
Show file tree
Hide file tree
Showing 5 changed files with 134 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
package pl.damianszczepanik.jenkins.buildhistorymanager.descriptors.conditions;

import hudson.Extension;
import hudson.model.Descriptor;
import hudson.util.ListBoxModel;
import org.jenkinsci.Symbol;
import pl.damianszczepanik.jenkins.buildhistorymanager.Messages;
import pl.damianszczepanik.jenkins.buildhistorymanager.model.conditions.BuildDescriptionCondition;
import pl.damianszczepanik.jenkins.buildhistorymanager.model.conditions.BuildDescriptionCondition.MatchingMethodType;
import pl.damianszczepanik.jenkins.buildhistorymanager.model.conditions.Condition;

/**
* Descriptor implementation needed to render UI for {@link BuildDescriptionCondition}.
*
* @author Damian Szczepanik (damianszczepanik@github)
*/
@Extension
@Symbol("BuildDescription")
public class BuildDescriptionDescriptor extends Descriptor<Condition> {

public BuildDescriptionDescriptor() {
super(BuildDescriptionCondition.class);
}

// names must refer to the field name
public ListBoxModel doFillMatchingMethodItems() {
return new ListBoxModel(
// default option should be listed first
new ListBoxModel.Option(Messages.matchingMethodType_EQUALS(), MatchingMethodType.EQUALS.name()),
new ListBoxModel.Option(Messages.matchingMethodType_CONTAINS(), MatchingMethodType.CONTAINS.name()),
new ListBoxModel.Option(Messages.matchingMethodType_MATCHES(), MatchingMethodType.MATCHES.name())

Check warning on line 31 in src/main/java/pl/damianszczepanik/jenkins/buildhistorymanager/descriptors/conditions/BuildDescriptionDescriptor.java

View check run for this annotation

ci.jenkins.io / Code Coverage

Not covered lines

Lines 27-31 are not covered by tests
);
}

@Override
public String getDisplayName() {
return "Build description";
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
package pl.damianszczepanik.jenkins.buildhistorymanager.model.conditions;

import hudson.Util;
import hudson.model.Run;
import org.kohsuke.stapler.DataBoundConstructor;
import org.kohsuke.stapler.DataBoundSetter;
import pl.damianszczepanik.jenkins.buildhistorymanager.model.RuleConfiguration;

/**
* Matches builds that description is equal, contains or matches given pattern.
*
* @author Damian Szczepanik (damianszczepanik@github)
*/
public class BuildDescriptionCondition extends Condition {

/**
* Matches method for the pattern
*/
public enum MatchingMethodType {
EQUALS,
CONTAINS,
MATCHES;
}

private String pattern;
private MatchingMethodType matchingMethod;

@DataBoundConstructor
public BuildDescriptionCondition() {
// Jenkins stapler requires to have public constructor with @DataBoundConstructor
}

public String getPattern() {
return pattern;
}

@DataBoundSetter
public void setPattern(String pattern) {
this.pattern = Util.fixNull(pattern);
}

public String getMatchingMethod() {
return matchingMethod.name();

Check warning on line 43 in src/main/java/pl/damianszczepanik/jenkins/buildhistorymanager/model/conditions/BuildDescriptionCondition.java

View check run for this annotation

ci.jenkins.io / SpotBugs

UWF_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR

LOW: BuildDescriptionCondition.matchingMethod not initialized in constructor and dereferenced in pl.damianszczepanik.jenkins.buildhistorymanager.model.conditions.BuildDescriptionCondition.getMatchingMethod()
Raw output
<p> This field is never initialized within any constructor, and is therefore could be null after the object is constructed. Elsewhere, it is loaded and dereferenced without a null check. This could be a either an error or a questionable design, since it means a null pointer exception will be generated if that field is dereferenced before being initialized. </p>
}

@DataBoundSetter
public void setMatchingMethod(String matchingMethod) {
this.matchingMethod = MatchingMethodType.valueOf(matchingMethod);
}

@Override
public boolean matches(Run<?, ?> run, RuleConfiguration configuration) {
// by default build description is null
String buildDescription = Util.fixNull(run.getDescription());

switch (matchingMethod) {

Check warning on line 56 in src/main/java/pl/damianszczepanik/jenkins/buildhistorymanager/model/conditions/BuildDescriptionCondition.java

View check run for this annotation

ci.jenkins.io / SpotBugs

UWF_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR

LOW: BuildDescriptionCondition.matchingMethod not initialized in constructor and dereferenced in pl.damianszczepanik.jenkins.buildhistorymanager.model.conditions.BuildDescriptionCondition.matches(Run, RuleConfiguration)
Raw output
<p> This field is never initialized within any constructor, and is therefore could be null after the object is constructed. Elsewhere, it is loaded and dereferenced without a null check. This could be a either an error or a questionable design, since it means a null pointer exception will be generated if that field is dereferenced before being initialized. </p>
case CONTAINS:
return buildDescription.contains(pattern);
case MATCHES:
return buildDescription.matches(pattern);
case EQUALS:
default: // any unspecified value should be fallback to default one -> equals
return buildDescription.equals(pattern);

Check warning on line 63 in src/main/java/pl/damianszczepanik/jenkins/buildhistorymanager/model/conditions/BuildDescriptionCondition.java

View check run for this annotation

ci.jenkins.io / Code Coverage

Not covered lines

Lines 19-63 are not covered by tests
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,7 @@
notInteger=Provided value is not an integer
# === RULE
role.notValidMatchAtMost=Provide integer value or -1 if the rule execution should not be limited
# === FIELDS
matchingMethodType.EQUALS=Equals pattern
matchingMethodType.CONTAINS=Contains pattern
matchingMethodType.MATCHES=Matches pattern (regular expression)
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<?jelly escape-by-default='true'?>
<j:jelly xmlns:j="jelly:core" xmlns:f="/lib/form">

<f:entry
title="Description matching method"
field="matchingMethod">
<f:select/>
</f:entry>
<f:entry title="Pattern" field="pattern">
<f:textbox/>
</f:entry>

</j:jelly>
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
<p><b>Description</b></p>
<p>Matches builds that description is equal, contains or matches given pattern.</p>

<p><b>Use cases</b></p>
<p>Helpful when build description contains text that can be used for decision what to do with the build.</p>

<p><b>Warning!</b></p>
<p>Leaving <i>pattern</i> field empty makes this condition valid for all builds that have undefined or empty build what
is default value for new created builds.</p>
<p>Methods <i>equals</i> and <i>contains</i> expect to have plain text pattern. To define proper regular expression
pattern for matching type follow <a href="https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html">the
guideline</a>.</p>

0 comments on commit 2789eff

Please sign in to comment.