aboutsummaryrefslogtreecommitdiffstats
path: root/src/test
diff options
context:
space:
mode:
authoraditya puthuparambil <aditya.puthuparambil@bell.ca>2021-07-26 15:40:09 +0000
committerGerrit Code Review <gerrit@onap.org>2021-07-26 15:40:09 +0000
commit082f738ad38057c2b010a3830d4c2b2d0d7b3d37 (patch)
tree70196314fd23bef0f84719ac60ebe575bb5b17ab /src/test
parentbc5644f4b972f4f000043dd6c99ec828bde39730 (diff)
parent22fe2165bed771fdd4c452891646076aecb22ac3 (diff)
Merge "generating swagger-ui and controller interface using openapi.yml"
Diffstat (limited to 'src/test')
-rw-r--r--src/test/groovy/org/onap/cps/temporal/controller/rest/QueryControllerSpec.groovy78
-rw-r--r--src/test/groovy/org/onap/cps/temporal/controller/web/QueryControllerSpec.groovy37
-rw-r--r--src/test/resources/application.yml6
3 files changed, 84 insertions, 37 deletions
diff --git a/src/test/groovy/org/onap/cps/temporal/controller/rest/QueryControllerSpec.groovy b/src/test/groovy/org/onap/cps/temporal/controller/rest/QueryControllerSpec.groovy
new file mode 100644
index 0000000..771a3fc
--- /dev/null
+++ b/src/test/groovy/org/onap/cps/temporal/controller/rest/QueryControllerSpec.groovy
@@ -0,0 +1,78 @@
+/*
+ * ============LICENSE_START=======================================================
+ * Copyright (c) 2021 Bell Canada.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ * ============LICENSE_END=========================================================
+ */
+
+package org.onap.cps.temporal.controller.rest
+
+import org.springframework.beans.factory.annotation.Autowired
+import org.springframework.beans.factory.annotation.Value
+import org.springframework.boot.test.autoconfigure.web.servlet.WebMvcTest
+import org.springframework.http.HttpStatus
+import org.springframework.http.MediaType
+import org.springframework.test.web.servlet.MockMvc
+
+import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get
+
+import spock.lang.Specification
+
+/**
+ * Specification for Query Controller.
+ */
+@WebMvcTest(QueryController)
+class QueryControllerSpec extends Specification {
+
+ @Autowired
+ MockMvc mvc
+
+ @Value('${rest.api.base-path}')
+ def basePath
+
+ def myDataspace = 'my-dataspace'
+ def myAnchor = 'my-anchor'
+ def mySchemaset = 'my-schemaset'
+
+ def 'Get anchors by name is not implemented.'(){
+ given: 'an endpoint'
+ def getAnchorsByNameEndpoint = "${basePath}/v1/dataspaces/{dataspace-name}/anchors/{anchor-name}/history"
+
+ when: 'get anchors by name endpoint is called'
+ def response = mvc.perform( get(getAnchorsByNameEndpoint, myDataspace, myAnchor)
+ .contentType(MediaType.APPLICATION_JSON))
+ .andReturn().response
+
+ then: 'received unsupported operation response'
+ response.getStatus() == HttpStatus.NOT_IMPLEMENTED.value()
+
+ }
+
+ def 'Get anchors by dataspace name is not implemented.'(){
+ given: 'an endpoint'
+ def getAnchorsByDataspaceEndpoint = "${basePath}/v1/dataspaces/{dataspace-name}/anchors/history"
+
+ when: 'get anchors by dataspace name endpoint is called'
+ def response = mvc.perform( get(getAnchorsByDataspaceEndpoint, myDataspace).queryParam('schema-set-name', mySchemaset)
+ .contentType(MediaType.APPLICATION_JSON))
+ .andReturn().response
+
+ then: 'received unsupported operation response'
+ response.getStatus() == HttpStatus.NOT_IMPLEMENTED.value()
+
+ }
+
+}
diff --git a/src/test/groovy/org/onap/cps/temporal/controller/web/QueryControllerSpec.groovy b/src/test/groovy/org/onap/cps/temporal/controller/web/QueryControllerSpec.groovy
deleted file mode 100644
index c834f38..0000000
--- a/src/test/groovy/org/onap/cps/temporal/controller/web/QueryControllerSpec.groovy
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * ============LICENSE_START=======================================================
- * Copyright (c) 2021 Bell Canada.
- * ================================================================================
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ============LICENSE_END=========================================================
- */
-
-package org.onap.cps.temporal.controller.web
-
-import spock.lang.Specification
-
-/**
- * Specification for Query Controller.
- */
-class QueryControllerSpec extends Specification {
-
- def objectUnderTest = new QueryController()
-
- def 'Get home returns some data'() {
- when: 'get home is invoked'
- def response = objectUnderTest.home()
- then: 'a response is returned'
- ! response.empty
- }
-
-}
diff --git a/src/test/resources/application.yml b/src/test/resources/application.yml
index 3ac13a9..fb38742 100644
--- a/src/test/resources/application.yml
+++ b/src/test/resources/application.yml
@@ -12,11 +12,17 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
+#
+# SPDX-License-Identifier: Apache-2.0
# ============LICENSE_END=========================================================
server:
port: 8080
+rest:
+ api:
+ base-path: /cps-temporal/api
+
spring:
datasource:
url: ${DB_URL}