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/TraceManagerServiceTest.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/TraceManagerServiceTest.java index e91f26c92..59f3dedc7 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/TraceManagerServiceTest.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/TraceManagerServiceTest.java @@ -19,6 +19,7 @@ import java.util.Collections; import javax.ws.rs.client.WebTarget; +import javax.ws.rs.core.MediaType; import javax.ws.rs.core.Response; import org.eclipse.core.resources.IFolder; @@ -64,12 +65,17 @@ public void testWithOneTrace() { assertEquals("Expected set of traces to contain trace2 stub", Collections.singleton(CONTEXT_SWITCHES_KERNEL_STUB), getTraces(traces)); - Response deleteResponse = traces.path(kernelStub.getUUID().toString()).request().delete(); - int deleteCode = deleteResponse.getStatus(); - assertEquals("Failed to DELETE trace2, error code=" + deleteCode, 200, deleteCode); - assertEquals(CONTEXT_SWITCHES_KERNEL_STUB, deleteResponse.readEntity(TraceModelStub.class)); - - assertEquals("Trace should have been deleted", Collections.emptySet(), getTraces(traces)); + String kernelStubUUUID = kernelStub.getUUID().toString(); + + try (Response deleteResponse = traces.path(kernelStubUUUID).request().delete()) { + int deleteCode = deleteResponse.getStatus(); + assertEquals("Failed to DELETE trace2, error code=" + deleteCode, 200, deleteCode); + assertEquals(CONTEXT_SWITCHES_KERNEL_STUB, deleteResponse.readEntity(TraceModelStub.class)); + } + try (Response response = traces.path(kernelStubUUUID).request(MediaType.APPLICATION_JSON).get()) { + assertEquals("Trace should have been deleted", 404, response.getStatus()); + } + assertEquals("Trace should have been deleted and trace set should be empty", Collections.emptySet(), getTraces(traces)); } /** 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/services/TraceManagerService.java b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core/src/org/eclipse/tracecompass/incubator/internal/trace/server/jersey/rest/core/services/TraceManagerService.java index 7c8d4e097..99258ca97 100644 --- a/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core/src/org/eclipse/tracecompass/incubator/internal/trace/server/jersey/rest/core/services/TraceManagerService.java +++ b/trace-server/org.eclipse.tracecompass.incubator.trace.server.jersey.rest.core/src/org/eclipse/tracecompass/incubator/internal/trace/server/jersey/rest/core/services/TraceManagerService.java @@ -260,7 +260,9 @@ public static UUID getTraceUUID(IResource resource) { return TRACE_INSTANCES.get(uuid); } ITmfTrace trace = createTraceInstance(uuid); - TRACE_INSTANCES.put(uuid, trace); + if (trace != null) { + TRACE_INSTANCES.put(uuid, trace); + } return trace; } @@ -300,8 +302,11 @@ public static UUID getTraceUUID(IResource resource) { } } - private static Trace createTraceModel(UUID uuid) { + private static @Nullable Trace createTraceModel(UUID uuid) { ITmfTrace trace = getOrCreateTraceInstance(uuid); + if (trace == null) { + return null; + } return Trace.from(trace, uuid); }