From 1361435f0df2bb71897dd61d4e9b865b4773d04c Mon Sep 17 00:00:00 2001 From: Andrew Azores Date: Fri, 25 Jun 2021 13:02:28 -0400 Subject: [PATCH] Add Cryostat template to image (#541) * Rename file * Copy cryostat.jfc into built image Copy .jfr event configuration template into base image's JDK jfr/lib directory, allowing Cryostat to report the cryostat.jfc as an available TARGET template * Add itest for cryostat.jfc availability --- pom.xml | 13 ++- .../extras/{app/Cryostat.xml => cryostat.jfc} | 0 src/test/java/itest/CryostatTemplateIT.java | 93 +++++++++++++++++++ .../java/itest/bases/StandardSelfTest.java | 6 ++ 4 files changed, 111 insertions(+), 1 deletion(-) rename src/main/extras/{app/Cryostat.xml => cryostat.jfc} (100%) create mode 100644 src/test/java/itest/CryostatTemplateIT.java diff --git a/pom.xml b/pom.xml index 03bcece33b..5a57c34b3b 100644 --- a/pom.xml +++ b/pom.xml @@ -19,6 +19,7 @@ /usr/bin/podman quay.io/cryostat/cryostat-base @sha256:233cb0897086bdb4ac74bd1d736c719ebebf660e2e7a6b5f25fc0b7e972d0a77 + java-11-openjdk-11.0.11.0.9-0.el8_3.x86_64 v12.5.0 v1.22.10 @@ -513,7 +514,17 @@ ${project.build.directory}/assets - src/main/extras + src/main/extras + / + + cryostat.jfc + + + + + src/main/extras + /usr/lib/jvm/${baseImageJdkVersion}/lib/jfr + cryostat.jfc diff --git a/src/main/extras/app/Cryostat.xml b/src/main/extras/cryostat.jfc similarity index 100% rename from src/main/extras/app/Cryostat.xml rename to src/main/extras/cryostat.jfc diff --git a/src/test/java/itest/CryostatTemplateIT.java b/src/test/java/itest/CryostatTemplateIT.java new file mode 100644 index 0000000000..943eaffdf7 --- /dev/null +++ b/src/test/java/itest/CryostatTemplateIT.java @@ -0,0 +1,93 @@ +/* + * Copyright The Cryostat Authors + * + * The Universal Permissive License (UPL), Version 1.0 + * + * Subject to the condition set forth below, permission is hereby granted to any + * person obtaining a copy of this software, associated documentation and/or data + * (collectively the "Software"), free of charge and under any and all copyright + * rights in the Software, and any and all patent rights owned or freely + * licensable by each licensor hereunder covering either (i) the unmodified + * Software as contributed to or provided by such licensor, or (ii) the Larger + * Works (as defined below), to deal in both + * + * (a) the Software, and + * (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if + * one is included with the Software (each a "Larger Work" to which the Software + * is contributed by such licensors), + * + * without restriction, including without limitation the rights to copy, create + * derivative works of, display, perform, and distribute the Software and make, + * use, sell, offer for sale, import, export, have made, and have sold the + * Software and the Larger Work(s), and to sublicense the foregoing rights on + * either these or other terms. + * + * This license is subject to the following condition: + * The above copyright notice and either this complete permission notice or at + * a minimum a reference to the UPL must be included in all copies or + * substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ +package itest; + +import java.io.File; +import java.util.concurrent.TimeUnit; + +import org.openjdk.jmc.flightrecorder.controlpanel.ui.configuration.model.xml.XMLAttributeInstance; +import org.openjdk.jmc.flightrecorder.controlpanel.ui.configuration.model.xml.XMLModel; +import org.openjdk.jmc.flightrecorder.controlpanel.ui.configuration.model.xml.XMLTagInstance; +import org.openjdk.jmc.flightrecorder.controlpanel.ui.model.EventConfiguration; + +import itest.bases.StandardSelfTest; +import org.hamcrest.MatcherAssert; +import org.hamcrest.Matchers; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.BeforeAll; +import org.junit.jupiter.api.Test; + +public class CryostatTemplateIT extends StandardSelfTest { + + static File file; + + @BeforeAll + static void setup() throws Exception { + String url = + String.format( + "/api/v1/targets/%s/templates/Cryostat/type/TARGET", + SELF_REFERENCE_TARGET_ID); + file = + downloadFile(url, "cryostat", "jfc") + .get(REQUEST_TIMEOUT_SECONDS, TimeUnit.SECONDS) + .toFile(); + } + + @Test + /** If this fails, check the baseImageJdkVersion in pom.xml. */ + public void shouldHaveCryostatTemplate() throws Exception { + XMLModel model = EventConfiguration.createModel(file); + model.checkErrors(); + + Assertions.assertFalse(model.hasErrors()); + + XMLTagInstance configuration = model.getRoot(); + XMLAttributeInstance labelAttr = null; + for (XMLAttributeInstance attr : configuration.getAttributeInstances()) { + if (attr.getAttribute().getName().equals("label")) { + labelAttr = attr; + break; + } + } + + MatcherAssert.assertThat(labelAttr, Matchers.notNullValue()); + + String templateName = labelAttr.getExplicitValue(); + MatcherAssert.assertThat(templateName, Matchers.equalTo("Cryostat")); + } +} diff --git a/src/test/java/itest/bases/StandardSelfTest.java b/src/test/java/itest/bases/StandardSelfTest.java index 8b2cab7848..7584ebf1df 100644 --- a/src/test/java/itest/bases/StandardSelfTest.java +++ b/src/test/java/itest/bases/StandardSelfTest.java @@ -58,12 +58,18 @@ import io.vertx.ext.web.client.HttpRequest; import io.vertx.ext.web.client.HttpResponse; import io.vertx.ext.web.client.WebClient; +import itest.util.Podman; import itest.util.Utils; +import org.apache.http.client.utils.URLEncodedUtils; import org.hamcrest.MatcherAssert; import org.hamcrest.Matchers; public abstract class StandardSelfTest { + public static final String SELF_REFERENCE_TARGET_ID = + URLEncodedUtils.formatSegments( + String.format("service:jmx:rmi:///jndi/rmi://%s:9091/jmxrmi", Podman.POD_NAME)); + public static final int REQUEST_TIMEOUT_SECONDS = 30; public static final WebClient webClient = Utils.getWebClient();