X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=enrichment-coordinator-service%2Fsrc%2Ftest%2Fjava%2Forg%2Foransc%2Fenrichment%2Fcontroller%2FConsumerSimulatorController.java;h=27160f13c89e199f558f8f3552d8ba11b01920b8;hb=366bc97828bf62e39a41318c1407a2c7c8cb5b74;hp=a9702b29eec75d00b176e12423e4a58cdfd0877c;hpb=a893ee0669b7820fdb30af24b213ea69956377e1;p=nonrtric.git diff --git a/enrichment-coordinator-service/src/test/java/org/oransc/enrichment/controller/ConsumerSimulatorController.java b/enrichment-coordinator-service/src/test/java/org/oransc/enrichment/controller/ConsumerSimulatorController.java index a9702b29..27160f13 100644 --- a/enrichment-coordinator-service/src/test/java/org/oransc/enrichment/controller/ConsumerSimulatorController.java +++ b/enrichment-coordinator-service/src/test/java/org/oransc/enrichment/controller/ConsumerSimulatorController.java @@ -37,6 +37,8 @@ import lombok.Getter; import org.oransc.enrichment.controllers.VoidResponse; import org.oransc.enrichment.controllers.a1e.A1eConsts; import org.oransc.enrichment.controllers.a1e.A1eEiJobStatus; +import org.oransc.enrichment.controllers.r1consumer.ConsumerConsts; +import org.oransc.enrichment.controllers.r1consumer.ConsumerTypeRegistrationInfo; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.http.HttpStatus; @@ -48,17 +50,20 @@ import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RestController; @RestController("ConsumerSimulatorController") -@Tag(name = A1eConsts.CONSUMER_API_CALLBACKS_NAME) public class ConsumerSimulatorController { private final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass()); public static class TestResults { - public List status = Collections.synchronizedList(new ArrayList()); + public List eiJobStatusCallbacks = + Collections.synchronizedList(new ArrayList()); + public List typeRegistrationInfoCallbacks = + Collections.synchronizedList(new ArrayList()); public void reset() { - status.clear(); + eiJobStatusCallbacks.clear(); + typeRegistrationInfoCallbacks.clear(); } } @@ -69,6 +74,7 @@ public class ConsumerSimulatorController { return "/example_dataconsumer/info_jobs/" + infoJobId + "/status"; } + @Tag(name = A1eConsts.CONSUMER_API_CALLBACKS_NAME) @PostMapping( path = "/example_dataconsumer/info_jobs/{infoJobId}/status", produces = MediaType.APPLICATION_JSON_VALUE) @@ -86,7 +92,33 @@ public class ConsumerSimulatorController { @PathVariable("infoJobId") String infoJobId, // @RequestBody A1eEiJobStatus status) { logger.info("Job status callback status: {} infoJobId: {}", status.state, infoJobId); - this.testResults.status.add(status); + this.testResults.eiJobStatusCallbacks.add(status); + return new ResponseEntity<>(HttpStatus.OK); + } + + private static final String TYPE_STATUS_CALLBACK_URL = "/example_dataconsumer/info_type_status"; + + public static String getTypeStatusCallbackUrl() { + return TYPE_STATUS_CALLBACK_URL; + } + + @Tag(name = ConsumerConsts.CONSUMER_API_CALLBACKS_NAME) + @PostMapping(path = TYPE_STATUS_CALLBACK_URL, produces = MediaType.APPLICATION_JSON_VALUE) + @Operation( + summary = "Callback for changed Information type registration status", + description = "The primitive is implemented by the data consumer and is invoked when a Information type status has been changed.
" + + "Subscription are managed by primitives in '" + ConsumerConsts.CONSUMER_API_NAME + "'") + @ApiResponses( + value = { // + @ApiResponse( + responseCode = "200", + description = "OK", // + content = @Content(schema = @Schema(implementation = VoidResponse.class))) // + }) + public ResponseEntity typeStatusCallback( // + @RequestBody ConsumerTypeRegistrationInfo status) { + logger.info("Job type registration status callback status: {}", status); + this.testResults.typeRegistrationInfoCallbacks.add(status); return new ResponseEntity<>(HttpStatus.OK); }