-
Notifications
You must be signed in to change notification settings - Fork 331
Expand file tree
/
Copy pathPullRequestInfo.java
More file actions
117 lines (102 loc) · 3.43 KB
/
PullRequestInfo.java
File metadata and controls
117 lines (102 loc) · 3.43 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package datadog.trace.civisibility.ci;
import datadog.trace.util.Strings;
import java.util.Objects;
public class PullRequestInfo {
public static final PullRequestInfo EMPTY = new PullRequestInfo(null, null, null, null);
private final String pullRequestBaseBranch;
private final String pullRequestBaseBranchSha;
private final String gitCommitHeadSha;
private final String pullRequestNumber;
public PullRequestInfo(
String pullRequestBaseBranch,
String pullRequestBaseBranchSha,
String gitCommitHeadSha,
String pullRequestNumber) {
this.pullRequestBaseBranch = pullRequestBaseBranch;
this.pullRequestBaseBranchSha = pullRequestBaseBranchSha;
this.gitCommitHeadSha = gitCommitHeadSha;
this.pullRequestNumber = pullRequestNumber;
}
public String getPullRequestBaseBranch() {
return pullRequestBaseBranch;
}
public String getPullRequestBaseBranchSha() {
return pullRequestBaseBranchSha;
}
public String getGitCommitHeadSha() {
return gitCommitHeadSha;
}
public String getPullRequestNumber() {
return pullRequestNumber;
}
public boolean isNotEmpty() {
return Strings.isNotBlank(pullRequestBaseBranch)
|| Strings.isNotBlank(pullRequestBaseBranchSha)
|| Strings.isNotBlank(gitCommitHeadSha)
|| Strings.isNotBlank(pullRequestNumber);
}
public boolean isComplete() {
return Strings.isNotBlank(pullRequestBaseBranch)
&& Strings.isNotBlank(pullRequestBaseBranchSha)
&& Strings.isNotBlank(gitCommitHeadSha)
&& Strings.isNotBlank(pullRequestNumber);
}
/**
* Merges info by completing the empty information fields with the fallback's
*
* @param info Base PR info
* @param fallback Fallback PR info
* @return Completed PR info
*/
public static PullRequestInfo merge(PullRequestInfo info, PullRequestInfo fallback) {
return new PullRequestInfo(
Strings.isNotBlank(info.pullRequestBaseBranch)
? info.pullRequestBaseBranch
: fallback.pullRequestBaseBranch,
Strings.isNotBlank(info.pullRequestBaseBranchSha)
? info.pullRequestBaseBranchSha
: fallback.pullRequestBaseBranchSha,
Strings.isNotBlank(info.gitCommitHeadSha)
? info.gitCommitHeadSha
: fallback.gitCommitHeadSha,
Strings.isNotBlank(info.pullRequestNumber)
? info.pullRequestNumber
: fallback.pullRequestNumber);
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
PullRequestInfo that = (PullRequestInfo) o;
return Objects.equals(pullRequestBaseBranch, that.pullRequestBaseBranch)
&& Objects.equals(pullRequestBaseBranchSha, that.pullRequestBaseBranchSha)
&& Objects.equals(gitCommitHeadSha, that.gitCommitHeadSha)
&& Objects.equals(pullRequestNumber, that.pullRequestNumber);
}
@Override
public int hashCode() {
return Objects.hash(
pullRequestBaseBranch, pullRequestBaseBranchSha, gitCommitHeadSha, pullRequestNumber);
}
@Override
public String toString() {
return "PR{"
+ "baseBranch='"
+ pullRequestBaseBranch
+ '\''
+ ", baseSHA='"
+ pullRequestBaseBranchSha
+ '\''
+ ", commitSHA='"
+ gitCommitHeadSha
+ '\''
+ ", prNumber='"
+ pullRequestNumber
+ '\''
+ '}';
}
}