Skip to content

Commit

Permalink
Fix fabric8io#1019: Custom Liveness/Readiness probes are not being cr…
Browse files Browse the repository at this point in the history
…eated

Added CustomProbeEnricher for adding probes via XML config
  • Loading branch information
rohanKanojia committed Dec 12, 2018
1 parent 9ba4144 commit 0b4af4a
Show file tree
Hide file tree
Showing 5 changed files with 36 additions and 10 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ After this we will switch probably to real [Semantic Versioning 2.0.0](http://se
* Fix 1412: mvn deploy fails when using a Dockerfile during S2I build
* Fix 796: Remove workaround to produce both .yaml and .json files
* Fix 1425: Added metadata visitors for imagestreams, build and buildconfig.
* Fix 1019: Custom liveness/readiness probes are not being created

### 3.5-SNAPSHOT
* Fix 1021: Avoids empty deployment selector value in generated yaml resource
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -189,6 +189,16 @@ public Builder withConfigMap(ConfigMap configMap) {
return this;
}

public Builder withLiveness(ProbeConfig liveness) {
config.liveness = liveness;
return this;
}

public Builder withReadiness(ProbeConfig readiness) {
config.readiness = readiness;
return this;
}

public ResourceConfig build() {
return config;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,11 +77,11 @@ private HTTPGetAction getHTTPGetAction(String getUrl) {
}
try {
URL url = new URL(getUrl);
return new HTTPGetAction(url.getHost(),
null /* headers */,
url.getPath(),
new IntOrString(url.getPort()),
url.getProtocol());
return new HTTPGetAction(url.getHost(),
null /* headers */,
url.getPath(),
new IntOrString(url.getPort()),
url.getProtocol().toUpperCase());
} catch (MalformedURLException e) {
throw new IllegalArgumentException("Invalid URL " + getUrl + " given for HTTP GET readiness check");
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ public void getHTTPProbeWithHTTPURLTest() {
assertEquals(null,probe.getHttpGet().getHttpHeaders());
assertEquals("/healthz",probe.getHttpGet().getPath());
assertEquals(8080,probe.getHttpGet().getPort().getIntVal().intValue());
assertEquals("http",probe.getHttpGet().getScheme());
assertEquals("HTTP",probe.getHttpGet().getScheme());
assertNull(probe.getExec());
assertNull(probe.getTcpSocket());
}
Expand Down Expand Up @@ -199,7 +199,7 @@ public void getTCPProbeWithHTTPURLAndPortTest() {
assertEquals(null,probe.getHttpGet().getHttpHeaders());
assertEquals("/healthz",probe.getHttpGet().getPath());
assertEquals(8080,probe.getHttpGet().getPort().getIntVal().intValue());
assertEquals("http",probe.getHttpGet().getScheme());
assertEquals("HTTP",probe.getHttpGet().getScheme());
}

@Test
Expand Down Expand Up @@ -265,7 +265,7 @@ public void getTCPWithHTTPURLAndWithoutPort() {
assertEquals(null,probe.getHttpGet().getHttpHeaders());
assertEquals("/healthz",probe.getHttpGet().getPath());
assertEquals(8080,probe.getHttpGet().getPort().getIntVal().intValue());
assertEquals("http",probe.getHttpGet().getScheme());
assertEquals("HTTP",probe.getHttpGet().getScheme());
}

@Test
Expand Down Expand Up @@ -293,4 +293,4 @@ public void getTCPProbeWithInvalidURLTest() {

probe = probeHandler.getProbe(probeConfig);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -97,11 +97,26 @@ public DefaultControllerEnricher(MavenEnricherContext buildContext) {
@Override
public void addMissingResources(KubernetesListBuilder builder) {
final String name = getConfig(Config.name, MavenUtil.createDefaultResourceName(getContext().getGav().getSanitizedArtifactId()));
final ResourceConfig config = new ResourceConfig.Builder()
ResourceConfig resourceConfig = getConfiguration().getResource().orElse(null);
ResourceConfig config = null;
if(resourceConfig != null) {
config = new ResourceConfig.Builder()
.controllerName(name)
.imagePullPolicy(getConfig(Config.pullPolicy))
.volumes(resourceConfig.getVolumes())
.withLiveness(resourceConfig.getLiveness())
.withReadiness(resourceConfig.getReadiness())
.withConfigMap(resourceConfig.getConfigMap())
.withServiceAccount(resourceConfig.getServiceAccount())
.withReplicas(Configs.asInt(getConfig(Config.replicaCount)))
.build();
} else {
config = new ResourceConfig.Builder()
.controllerName(name)
.imagePullPolicy(getConfig(Config.pullPolicy))
.withReplicas(Configs.asInt(getConfig(Config.replicaCount)))
.build();
}

final List<ImageConfiguration> images = getImages().orElse(Collections.emptyList());

Expand Down

0 comments on commit 0b4af4a

Please sign in to comment.