From 20983922daff86e3282bc5e2da900a8ab1cc82ed Mon Sep 17 00:00:00 2001 From: Ruslan Kashapov Date: Mon, 1 Feb 2021 10:47:25 +0200 Subject: Fetching data node by xpath - rest and service layers IssueID: CPS-71 Change-Id: I54801fc12a8aa700d85e774780c9990b7f19c747 Signed-off-by: Ruslan Kashapov --- .../cps/api/impl/CpsDataServiceImplSpec.groovy | 27 ++++++-- .../org/onap/cps/utils/DataMapUtilsSpec.groovy | 74 ++++++++++++++++++++++ 2 files changed, 95 insertions(+), 6 deletions(-) create mode 100644 cps-service/src/test/groovy/org/onap/cps/utils/DataMapUtilsSpec.groovy (limited to 'cps-service/src/test/groovy/org/onap') diff --git a/cps-service/src/test/groovy/org/onap/cps/api/impl/CpsDataServiceImplSpec.groovy b/cps-service/src/test/groovy/org/onap/cps/api/impl/CpsDataServiceImplSpec.groovy index 5874e27ece..65a0d54f40 100644 --- a/cps-service/src/test/groovy/org/onap/cps/api/impl/CpsDataServiceImplSpec.groovy +++ b/cps-service/src/test/groovy/org/onap/cps/api/impl/CpsDataServiceImplSpec.groovy @@ -23,10 +23,13 @@ import org.onap.cps.TestUtils import org.onap.cps.api.CpsAdminService import org.onap.cps.api.CpsModuleService import org.onap.cps.spi.CpsDataPersistenceService +import org.onap.cps.spi.FetchDescendantsOption import org.onap.cps.spi.model.Anchor +import org.onap.cps.spi.model.DataNodeBuilder import org.onap.cps.yang.YangTextSchemaSourceSet import org.onap.cps.yang.YangTextSchemaSourceSetBuilder import spock.lang.Specification +import spock.lang.Unroll class CpsDataServiceImplSpec extends Specification { def mockCpsDataPersistenceService = Mock(CpsDataPersistenceService) @@ -37,10 +40,10 @@ class CpsDataServiceImplSpec extends Specification { def objectUnderTest = new CpsDataServiceImpl() def setup() { - objectUnderTest.cpsDataPersistenceService = mockCpsDataPersistenceService; - objectUnderTest.cpsAdminService = mockCpsAdminService; - objectUnderTest.cpsModuleService = mockCpsModuleService; - objectUnderTest.yangTextSchemaSourceSetCache = mockYangTextSchemaSourceSetCache; + objectUnderTest.cpsDataPersistenceService = mockCpsDataPersistenceService + objectUnderTest.cpsAdminService = mockCpsAdminService + objectUnderTest.cpsModuleService = mockCpsModuleService + objectUnderTest.yangTextSchemaSourceSetCache = mockYangTextSchemaSourceSetCache } def dataspaceName = 'some dataspace' @@ -55,16 +58,28 @@ class CpsDataServiceImplSpec extends Specification { mockCpsAdminService.getAnchor(dataspaceName, anchorName) >> anchor and: 'the schema source set cache returns a schema source set' def mockYangTextSchemaSourceSet = Mock(YangTextSchemaSourceSet) - mockYangTextSchemaSourceSetCache.get(dataspaceName,schemaSetName) >> mockYangTextSchemaSourceSet + mockYangTextSchemaSourceSetCache.get(dataspaceName, schemaSetName) >> mockYangTextSchemaSourceSet and: 'the schema source sets returns the test-tree schema context' def yangResourceNameToContent = TestUtils.getYangResourcesAsMap('test-tree.yang') def schemaContext = YangTextSchemaSourceSetBuilder.of(yangResourceNameToContent).getSchemaContext() mockYangTextSchemaSourceSet.getSchemaContext() >> schemaContext when: 'save data method is invoked with test-tree json data' - def jsonData = org.onap.cps.TestUtils.getResourceFileContent('test-tree.json') + def jsonData = TestUtils.getResourceFileContent('test-tree.json') objectUnderTest.saveData(dataspaceName, anchorName, jsonData) then: 'the persistence service method is invoked with correct parameters' 1 * mockCpsDataPersistenceService.storeDataNode(dataspaceName, anchorName, { dataNode -> dataNode.xpath == '/test-tree' }) } + + @Unroll + def 'Get data node with option #fetchChildrenOption'() { + def xpath = '/xpath' + def dataNode = new DataNodeBuilder().withXpath(xpath).build() + given: 'persistence service returns data for get data request' + mockCpsDataPersistenceService.getDataNode(dataspaceName, anchorName, xpath, fetchDescendantsOption) >> dataNode + expect: 'service returns same data if uses same parameters' + objectUnderTest.getDataNode(dataspaceName, anchorName, xpath, fetchDescendantsOption) == dataNode + where: 'all fetch options are supported' + fetchDescendantsOption << FetchDescendantsOption.values() + } } \ No newline at end of file diff --git a/cps-service/src/test/groovy/org/onap/cps/utils/DataMapUtilsSpec.groovy b/cps-service/src/test/groovy/org/onap/cps/utils/DataMapUtilsSpec.groovy new file mode 100644 index 0000000000..61cfc37aa1 --- /dev/null +++ b/cps-service/src/test/groovy/org/onap/cps/utils/DataMapUtilsSpec.groovy @@ -0,0 +1,74 @@ +/* + * ============LICENSE_START======================================================= + * Copyright (C) 2021 Pantheon.tech + * ================================================================================ + * 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.utils + +import com.google.common.collect.ImmutableMap +import org.onap.cps.spi.model.DataNode +import org.onap.cps.spi.model.DataNodeBuilder +import spock.lang.Specification + +import static java.util.Arrays.asList + +class DataMapUtilsSpec extends Specification { + + DataNode dataNode = buildDataNode( + "/parent", + ImmutableMap. of("a", "b", "c", asList("d", "e")), + asList( + buildDataNode( + "/parent/child-list[@name='x']", + ImmutableMap. of("name", "x"), + Collections.emptyList()), + buildDataNode( + "/parent/child-list[@name='y']", + ImmutableMap. of("name", "y"), + Collections.emptyList()), + buildDataNode( + "/parent/child-object", + ImmutableMap. of("m", "n"), + asList( + buildDataNode( + "/parent/child-object/grand-child", + ImmutableMap. of("o", "p"), + Collections.emptyList() + ) + ) + ), + )) + + static DataNode buildDataNode(String xpath, Map leaves, List children) { + return new DataNodeBuilder().withXpath(xpath).withLeaves(leaves).withChildDataNodes(children).build() + } + + def 'Data node structure conversion to map.'() { + when: 'data node structure converted to map' + def result = DataMapUtils.toDataMap(dataNode) + then: 'root node leaves are top level elements' + assert result["a"] == "b" + assert ((Collection) result["c"]).containsAll("d", "e") + and: 'leaves of child list element are listed as structures under common identifier' + assert ((Collection) result["child-list"]).size() == 2 + assert ((Collection) result["child-list"]).containsAll(["name": "x"], ["name": "y"]) + and: 'leaves for child and grand-child elements are populated under their node identifiers' + assert result["child-object"]["m"] == "n" + assert result["child-object"]["grand-child"]["o"] == "p" + } + +} -- cgit 1.2.3-korg