diff --git a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/META-INF/MANIFEST.MF b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/META-INF/MANIFEST.MF
index dc12051bb..3cb671102 100644
--- a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/META-INF/MANIFEST.MF
+++ b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/META-INF/MANIFEST.MF
@@ -2,7 +2,7 @@ Manifest-Version: 1.0
Bundle-ManifestVersion: 2
Bundle-Name: %Bundle-Name
Bundle-Vendor: %Bundle-Vendor
-Bundle-SymbolicName: org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests
+Bundle-SymbolicName: org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests;singleton:=true
Bundle-Version: 0.1.9.qualifier
Bundle-Localization: plugin
Bundle-ActivationPolicy: lazy
@@ -29,6 +29,7 @@ Export-Package: org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core
org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests.stubs.webapp,
org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests.utils
Import-Package: com.fasterxml.jackson.annotation,
+ com.fasterxml.jackson.core,
com.fasterxml.jackson.jaxrs.base,
com.fasterxml.jackson.jaxrs.json,
com.google.common.base,
diff --git a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/build.properties b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/build.properties
index cf0366079..e3b4e8580 100644
--- a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/build.properties
+++ b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/build.properties
@@ -14,4 +14,6 @@ output.. = bin/
bin.includes = META-INF/,\
.,\
about.html,\
- plugin.properties
+ plugin.properties,\
+ plugin.xml,\
+ schema/
diff --git a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/plugin.xml b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/plugin.xml
new file mode 100644
index 000000000..d740c328b
--- /dev/null
+++ b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/plugin.xml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+
diff --git a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/schema/custom-execution-analysis.json b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/schema/custom-execution-analysis.json
new file mode 100644
index 000000000..6b0ea73cd
--- /dev/null
+++ b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/schema/custom-execution-analysis.json
@@ -0,0 +1,30 @@
+{
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
+ "$id": "https://org.eclipse.tracecompass/custom-execution-analysis.json",
+ "title": "Custom Execution Analysis",
+ "description": "Custom Execution Analysis schema",
+ "type": "object",
+ "properties": {
+ "cpus": {
+ "description": "array of integer",
+ "type": "array",
+ "items": {
+ "type": "number"
+ }
+ },
+ "thread": {
+ "description": "Thread regular expression pattern",
+ "type": "string"
+ },
+ "phone": {
+ "description": "Phone number",
+ "type": "string",
+ "pattern": "^(\\([0-9]{3}\\))?[0-9]{3}-[0-9]{4}$"
+ },
+ "label": {
+ "description": "Optional label text",
+ "type": "string"
+ }
+ },
+ "required": ["thread"]
+}
diff --git a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/services/ConfigurationManagerServiceTest.java b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/services/ConfigurationManagerServiceTest.java
index 8aaee3132..d082b12a6 100644
--- a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/services/ConfigurationManagerServiceTest.java
+++ b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/services/ConfigurationManagerServiceTest.java
@@ -50,6 +50,8 @@
import org.junit.Test;
import org.osgi.framework.Bundle;
+import com.fasterxml.jackson.databind.JsonNode;
+
/**
* Basic test for the {@link ConfigurationManagerService}.
*
@@ -142,6 +144,14 @@ public void testSourceType() {
assertEquals(EXPECTED_DATA_TYPE, desc.getDataType());
assertEquals(EXPECTED_PARAM_DESCRIPTION, desc.getDescription());
assertTrue(desc.isRequired());
+
+ // Verify configuration source type with schema
+ Optional optional2 = configurations.stream().filter(config -> config.getId().equals("org.eclipse.tracecompass.tmf.core.config.testschemasourcetype")).findAny();
+ assertTrue(optional2.isPresent());
+ TmfConfigurationSourceTypeStub type2 = optional2.get();
+ JsonNode schema = type2.getSchema();
+ // Verify that schema exists
+ assertNotNull(schema);
}
/**
diff --git a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/stubs/TmfConfigurationSourceTypeStub.java b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/stubs/TmfConfigurationSourceTypeStub.java
index 0eab6972a..3055edbd2 100644
--- a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/stubs/TmfConfigurationSourceTypeStub.java
+++ b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/stubs/TmfConfigurationSourceTypeStub.java
@@ -23,6 +23,7 @@
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
+import com.fasterxml.jackson.databind.JsonNode;
/**
* Basic Implementation of the serialized {@link ITmfConfigurationSourceType} model used by clients.
@@ -36,6 +37,7 @@ public class TmfConfigurationSourceTypeStub implements Serializable, ITmfConfigu
*/
private static final long serialVersionUID = 6934234848155424428L;
private final ITmfConfigurationSourceType fConfig;
+ private final JsonNode fSchema;
/**
* {@link JsonCreator} Constructor for final fields
@@ -46,7 +48,9 @@ public class TmfConfigurationSourceTypeStub implements Serializable, ITmfConfigu
* the name
* @param description
* the help text
- * @param queryParamKeys
+ * @param schema
+ * the JSON schema JsonNode
+ * @param parameterDescriptors
* the list of keys
*
*/
@@ -55,7 +59,8 @@ public class TmfConfigurationSourceTypeStub implements Serializable, ITmfConfigu
public TmfConfigurationSourceTypeStub(@JsonProperty("id") String id,
@JsonProperty("name") String name,
@JsonProperty("description") String description,
- @JsonProperty("parameterDescriptors") List parameterDescriptors) {
+ @JsonProperty("parameterDescriptors") List parameterDescriptors,
+ @JsonProperty("schema") JsonNode schema) {
super();
TmfConfigurationSourceType.Builder builder = new TmfConfigurationSourceType.Builder()
@@ -66,8 +71,15 @@ public TmfConfigurationSourceTypeStub(@JsonProperty("id") String id,
builder.setConfigParamDescriptors(parameterDescriptors.stream().map(stub -> stub.getConfig()).collect(Collectors.toList()));
}
fConfig = builder.build();
+ fSchema = schema;
}
+ /**
+ * @return the JSON schema string
+ */
+ public JsonNode getSchema() {
+ return fSchema;
+ }
ITmfConfigurationSourceType getConfig() {
return fConfig;
@@ -75,24 +87,16 @@ ITmfConfigurationSourceType getConfig() {
@Override
public int hashCode() {
- return fConfig.hashCode();
+ return Objects.hash(fConfig, fSchema == null ? "null" : fSchema);
}
@Override
public boolean equals(Object obj) {
- if (this == obj) {
- return true;
- }
- if (obj == null) {
+ if (!(obj instanceof TmfConfigurationSourceTypeStub)) {
return false;
}
- if (obj instanceof TmfConfigurationSourceTypeStub) {
- return Objects.equals(this.getConfig(), ((TmfConfigurationSourceTypeStub) obj).getConfig());
- }
- if (obj instanceof TmfConfigurationSourceType) {
- return Objects.equals(this.getConfig(), obj);
- }
- return false;
+ TmfConfigurationSourceTypeStub other = (TmfConfigurationSourceTypeStub) obj;
+ return Objects.equals(fConfig, other.fConfig) && Objects.equals(fSchema, other.fSchema);
}
@Override
diff --git a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/stubs/config/TestSchemaConfigurationSource.java b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/stubs/config/TestSchemaConfigurationSource.java
new file mode 100644
index 000000000..c7f6d438e
--- /dev/null
+++ b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests/src/org/eclipse/tracecompass/incubator/trace/server/jersey/rest/core/tests/stubs/config/TestSchemaConfigurationSource.java
@@ -0,0 +1,108 @@
+/*******************************************************************************
+ * Copyright (c) 2023 Ericsson
+ *
+ * All rights reserved. This program and the accompanying materials are
+ * made available under the terms of the Eclipse Public License 2.0 which
+ * accompanies this distribution, and is available at
+ * https://www.eclipse.org/legal/epl-2.0/
+ *
+ * SPDX-License-Identifier: EPL-2.0
+ *******************************************************************************/
+package org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests.stubs.config;
+
+import static org.eclipse.tracecompass.common.core.NonNullUtils.nullToEmptyString;
+
+import java.io.File;
+import java.io.IOException;
+import java.net.URISyntaxException;
+import java.net.URL;
+import java.util.Collections;
+import java.util.List;
+import java.util.Map;
+
+import org.eclipse.core.runtime.FileLocator;
+import org.eclipse.core.runtime.IPath;
+import org.eclipse.core.runtime.Platform;
+import org.eclipse.jdt.annotation.NonNull;
+import org.eclipse.jdt.annotation.Nullable;
+import org.eclipse.tracecompass.tmf.core.config.ITmfConfiguration;
+import org.eclipse.tracecompass.tmf.core.config.ITmfConfigurationSource;
+import org.eclipse.tracecompass.tmf.core.config.ITmfConfigurationSourceType;
+import org.eclipse.tracecompass.tmf.core.config.TmfConfigurationSourceType;
+import org.eclipse.tracecompass.tmf.core.exceptions.TmfConfigurationException;
+import org.osgi.framework.Bundle;
+
+/**
+ * Test class
+ */
+public class TestSchemaConfigurationSource implements ITmfConfigurationSource {
+
+ private static final @NonNull ITmfConfigurationSourceType fType;
+
+ private static final @NonNull String TEST_ANALYSIS_TYPE_ID = "org.eclipse.tracecompass.tmf.core.config.testschemasourcetype"; //$NON-NLS-1$
+ private static final @NonNull String NAME = nullToEmptyString("Test Schema Type"); //$NON-NLS-1$
+ private static final @NonNull String DESCRIPTION = nullToEmptyString("Test Type with schema"); //$NON-NLS-1$
+
+ static {
+ Bundle bundle = Platform.getBundle("org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core.tests");
+ IPath defaultPath = new org.eclipse.core.runtime.Path("schema/custom-execution-analysis.json"); //$NON-NLS-1$
+ URL url = FileLocator.find(bundle, defaultPath, null);
+ File schemaFile = null;
+ try {
+ schemaFile = new File(FileLocator.toFileURL(url).toURI());
+ } catch (URISyntaxException | IOException e) {
+ e.printStackTrace();
+ }
+ fType = new TmfConfigurationSourceType.Builder()
+ .setId(TEST_ANALYSIS_TYPE_ID)
+ .setDescription(DESCRIPTION)
+ .setName(NAME)
+ .setSchemaFile(schemaFile)
+ .setConfigParamDescriptors(Collections.emptyList()).build();
+ }
+
+ /**
+ * Constructor
+ */
+ public TestSchemaConfigurationSource() {
+ }
+
+ @Override
+ public @NonNull ITmfConfigurationSourceType getConfigurationSourceType() {
+ return fType;
+ }
+
+ @Override
+ public @NonNull ITmfConfiguration create(@NonNull Map<@NonNull String, @NonNull Object> parameters) throws TmfConfigurationException {
+ throw new TmfConfigurationException("Not implemented yet"); //$NON-NLS-1$
+ }
+
+ @Override
+ public @NonNull ITmfConfiguration update(@NonNull String id, @NonNull Map<@NonNull String, @NonNull Object> parameters) throws TmfConfigurationException {
+ throw new TmfConfigurationException("Not implemented yet"); //$NON-NLS-1$
+ }
+
+ @Override
+ public @Nullable ITmfConfiguration get(@NonNull String id) {
+ return null;
+ }
+
+ @Override
+ public @Nullable ITmfConfiguration remove(@NonNull String id) {
+ return null;
+ }
+
+ @Override
+ public boolean contains(@NonNull String id) {
+ return false;
+ }
+
+ @Override
+ public @NonNull List<@NonNull ITmfConfiguration> getConfigurations() {
+ return Collections.emptyList();
+ }
+
+ @Override
+ public void dispose() {
+ }
+}
diff --git a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core/src/org/eclipse/tracecompass/incubator/internal/trace/server/jersey/rest/core/webapp/TmfConfigurationSourceTypeSerializer.java b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core/src/org/eclipse/tracecompass/incubator/internal/trace/server/jersey/rest/core/webapp/TmfConfigurationSourceTypeSerializer.java
index a8c331014..35bcbd5a4 100644
--- a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core/src/org/eclipse/tracecompass/incubator/internal/trace/server/jersey/rest/core/webapp/TmfConfigurationSourceTypeSerializer.java
+++ b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core/src/org/eclipse/tracecompass/incubator/internal/trace/server/jersey/rest/core/webapp/TmfConfigurationSourceTypeSerializer.java
@@ -11,11 +11,16 @@
package org.eclipse.tracecompass.incubator.internal.trace.server.jersey.rest.core.webapp;
+import java.io.File;
+import java.io.FileInputStream;
import java.io.IOException;
+import java.io.InputStream;
import org.eclipse.tracecompass.tmf.core.config.ITmfConfigurationSourceType;
import com.fasterxml.jackson.core.JsonGenerator;
+import com.fasterxml.jackson.databind.JsonNode;
+import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializerProvider;
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
@@ -48,6 +53,15 @@ public void serialize(ITmfConfigurationSourceType value, JsonGenerator gen, Seri
if (!value.getConfigParamDescriptors().isEmpty()) {
gen.writeObjectField("parameterDescriptors", value.getConfigParamDescriptors()); //$NON-NLS-1$
}
+ File schemaFile = value.getSchemaFile();
+ if (schemaFile != null) {
+ try (InputStream inputStream = new FileInputStream(schemaFile)) {
+ ObjectMapper mapper = new ObjectMapper();
+ JsonNode schema = mapper.readTree(inputStream);
+ gen.writeFieldName("schema"); //$NON-NLS-1$
+ gen.writeTree(schema);
+ }
+ }
gen.writeEndObject();
}
}