-
Notifications
You must be signed in to change notification settings - Fork 153
/
BuildInfoMavenBuilder.java
386 lines (343 loc) · 10.8 KB
/
BuildInfoMavenBuilder.java
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
package org.jfrog.build.extractor.builder;
import org.apache.commons.lang3.StringUtils;
import org.jfrog.build.api.release.PromotionStatus;
import org.jfrog.build.api.util.CommonUtils;
import org.jfrog.build.extractor.ci.*;
import org.jfrog.build.extractor.ci.Module;
import java.util.Date;
import java.util.List;
import java.util.Properties;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
/**
* A temporary builder for the build class specifically for Maven extractor.
* <P><B>NOTE!</B> This class should be merged to {@link BuildInfoBuilder} once fully tested.
*
* @author Noam Y. Tenne
*/
public class BuildInfoMavenBuilder extends BuildInfoBuilder {
public BuildInfoMavenBuilder(String name) {
super(name);
}
/**
* Assembles the build class
*
* @return Assembled build
*/
public BuildInfo build() {
return super.build();
}
/**
* Sets the version of the build
*
* @param version Build version
* @return Builder instance
*/
public BuildInfoMavenBuilder version(String version) {
super.version(version);
return this;
}
/**
* Sets the name of the build
*
* @param name Build name
* @return Builder instance
*/
public BuildInfoMavenBuilder name(String name) {
super.name(name);
return this;
}
/**
* Sets the number of the build
*
* @param number Build number
* @return Builder instance
*/
public BuildInfoMavenBuilder number(String number) {
super.number(number);
return this;
}
/**
* Sets the project of the build
*
* @param project Build project
* @return Builder instance
*/
public BuildInfoMavenBuilder project(String project) {
super.project(project);
return this;
}
/**
* Sets the agent of the build
*
* @param agent Build agent
* @return Builder instance
*/
public BuildInfoMavenBuilder agent(Agent agent) {
super.agent(agent);
return this;
}
/**
* Sets the build agent of the build
*
* @param buildAgent The build agent
* @return Builder instance
*/
public BuildInfoMavenBuilder buildAgent(BuildAgent buildAgent) {
super.buildAgent(buildAgent);
return this;
}
/**
* Sets the started time of the build
*
* @param started Build started time
* @return Builder instance
*/
public BuildInfoMavenBuilder started(String started) {
super.started(started);
return this;
}
/**
* Sets the started time of the build
*
* @param startedDate Build started date
* @return Builder instance
*/
public BuildInfoMavenBuilder startedDate(Date startedDate) {
super.startedDate(startedDate);
return this;
}
/**
* Sets the start time in millis of the build
*
* @param startedMillis Build started time in millis
* @return Builder instance
*/
public BuildInfoMavenBuilder startedMillis(long startedMillis) {
super.startedMillis(startedMillis);
return this;
}
/**
* Sets the duration milliseconds of the build
*
* @param durationMillis Build duration milliseconds
* @return Builder instance
*/
public BuildInfoMavenBuilder durationMillis(long durationMillis) {
super.durationMillis(durationMillis);
return this;
}
/**
* Sets the principal of the build
*
* @param principal Build principal
* @return Builder instance
*/
public BuildInfoMavenBuilder principal(String principal) {
super.principal(principal);
return this;
}
/**
* Sets the Artifactory principal of the build
*
* @param artifactoryPrincipal Build Artifactory principal
* @return Builder instance
*/
public BuildInfoMavenBuilder artifactoryPrincipal(String artifactoryPrincipal) {
super.artifactoryPrincipal(artifactoryPrincipal);
return this;
}
/**
* Sets the Artifactory plugin version of the build
*
* @param artifactoryPluginVersion Build Artifactory plugin version
* @return Builder instance
*/
public BuildInfoMavenBuilder artifactoryPluginVersion(String artifactoryPluginVersion) {
super.artifactoryPluginVersion(artifactoryPluginVersion);
return this;
}
/**
* Sets the URL of the build
*
* @param url Build URL
* @return Builder instance
*/
public BuildInfoMavenBuilder url(String url) {
super.url(url);
return this;
}
/**
* Sets the parent build name of the build
*
* @param parentName Build parent build name
* @return Builder instance
*/
public BuildInfoMavenBuilder parentName(String parentName) {
super.parentName(parentName);
return this;
}
/**
* Sets the parent build number of the build
*
* @param parentNumber Build parent build number
* @return Builder instance
*/
public BuildInfoMavenBuilder parentNumber(String parentNumber) {
super.parentNumber(parentNumber);
return this;
}
/**
* Sets the vcs revision (format is vcs specific)
*
* @param vcs The vcs data
* @return Builder instance
*/
public BuildInfoMavenBuilder vcs(List<Vcs> vcs) {
super.vcs(vcs);
return this;
}
/**
* Sets the vcs revision (format is vcs specific)
*
* @param vcsRevision The vcs revision
* @return Builder instance
*/
public BuildInfoMavenBuilder vcsRevision(String vcsRevision) {
super.vcsRevision(vcsRevision);
return this;
}
/**
* Sets the vcs URL (format is vcs specific)
*
* @param vcsUrl The vcs revision
* @return Builder instance
*/
public BuildInfoMavenBuilder vcsUrl(String vcsUrl) {
super.vcsUrl(vcsUrl);
return this;
}
/**
* Sets the modules of the build
*
* @param modules Build modules
* @return Builder instance
*/
public BuildInfoMavenBuilder modules(ConcurrentHashMap<String, Module> modules) {
super.modules(modules);
return this;
}
public BuildInfoMavenBuilder statuses(List<PromotionStatus> statuses) {
super.statuses(statuses);
return this;
}
public BuildInfoMavenBuilder addStatus(PromotionStatus promotionStatus) {
super.addStatus(promotionStatus);
return this;
}
/**
* Sets the post build retention period
*
* @return Builder instance
*/
public BuildInfoMavenBuilder buildRetention(BuildRetention buildRetention) {
super.buildRetention(buildRetention);
return this;
}
/**
* Adds the given module to the modules list
*
* @param module Module to add
* @return Builder instance
*/
@Override
public BuildInfoMavenBuilder addModule(Module module) {
super.addModule(module);
mergeModule(module);
return this;
}
/**
* Sets the properties of the build
*
* @param properties Build properties
* @return Builder instance
*/
public BuildInfoMavenBuilder properties(Properties properties) {
super.properties(properties);
return this;
}
/**
* Adds the given property to the properties object
*
* @param key Key of property to add
* @param value Value of property to add
* @return Builder instance
*/
public BuildInfoMavenBuilder addProperty(Object key, Object value) {
super.addProperty(key, value);
return this;
}
public BuildInfoMavenBuilder issues(Issues issues) {
super.issues(issues);
return this;
}
private void mergeModule(Module moduleToMerge) {
Module existingModule = modules.putIfAbsent(moduleToMerge.getId(), moduleToMerge);
if (existingModule == null) {
return;
}
mergeModuleArtifacts(existingModule, moduleToMerge);
mergeModuleDependencies(existingModule, moduleToMerge);
}
private void mergeModuleArtifacts(Module existingModule, Module moduleToMerge) {
List<Artifact> existingArtifacts = existingModule.getArtifacts();
List<Artifact> artifactsToMerge = moduleToMerge.getArtifacts();
if (existingArtifacts == null || existingArtifacts.isEmpty()) {
existingModule.setArtifacts(artifactsToMerge);
return;
}
if (artifactsToMerge == null || artifactsToMerge.isEmpty()) {
return;
}
for (Artifact artifactToMerge : artifactsToMerge) {
Artifact foundArtifact = findArtifact(existingArtifacts, artifactToMerge.getName());
if (foundArtifact == null) {
existingArtifacts.add(artifactToMerge);
} else {
if (StringUtils.isBlank(foundArtifact.getMd5()) && StringUtils.isBlank(foundArtifact.getSha1())) {
foundArtifact.setType(artifactToMerge.getType());
foundArtifact.setMd5(artifactToMerge.getMd5());
foundArtifact.setSha1(artifactToMerge.getSha1());
foundArtifact.setProperties(artifactToMerge.getProperties());
}
}
}
}
private Artifact findArtifact(List<Artifact> existingArtifacts, final String artifactKey) {
return CommonUtils.getFirstSatisfying(existingArtifacts, input -> input.getName().equals(artifactKey), null);
}
private void mergeModuleDependencies(Module existingModule, Module moduleToMerge) {
List<Dependency> existingDependencies = existingModule.getDependencies();
List<Dependency> dependenciesToMerge = moduleToMerge.getDependencies();
if (existingDependencies == null || existingDependencies.isEmpty()) {
existingModule.setDependencies(dependenciesToMerge);
return;
}
if (dependenciesToMerge == null || dependenciesToMerge.isEmpty()) {
return;
}
for (Dependency dependencyToMerge : dependenciesToMerge) {
Dependency foundDependency = findDependency(existingDependencies, dependencyToMerge.getId());
if (foundDependency == null) {
existingDependencies.add(dependencyToMerge);
} else {
Set<String> mergedDependencies = foundDependency.getScopes();
mergedDependencies.addAll(dependencyToMerge.getScopes());
foundDependency.setScopes(mergedDependencies);
}
}
}
private Dependency findDependency(List<Dependency> existingDependencies, final String dependencyId) {
return CommonUtils.getFirstSatisfying(existingDependencies, input -> input.getId().equals(dependencyId), null);
}
}