From 6da081cc0667795cd7872582a8795cf0bbd56c17 Mon Sep 17 00:00:00 2001 From: Ruslan Kashapov Date: Thu, 22 Apr 2021 11:47:41 +0300 Subject: JSON data fragment into DataNode collection parsing support Issue-ID: CPS-358 Change-Id: I92f46504e5f3623131844616945069f70712ed61 Signed-off-by: Ruslan Kashapov --- .../org/onap/cps/model/DataNodeBuilderSpec.groovy | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'cps-service/src/test') diff --git a/cps-service/src/test/groovy/org/onap/cps/model/DataNodeBuilderSpec.groovy b/cps-service/src/test/groovy/org/onap/cps/model/DataNodeBuilderSpec.groovy index 901e0b60c..7f50f7f52 100644 --- a/cps-service/src/test/groovy/org/onap/cps/model/DataNodeBuilderSpec.groovy +++ b/cps-service/src/test/groovy/org/onap/cps/model/DataNodeBuilderSpec.groovy @@ -83,6 +83,7 @@ class DataNodeBuilderSpec extends Specification { mappedResult.keySet() .containsAll(['/test-tree/branch[@name=\'Branch\']', '/test-tree/branch[@name=\'Branch\']/nest']) } + def 'Converting NormalizedNode (tree) to a DataNode (tree) -- augmentation case.'() { given: 'a schema context for expected model' def yangResourceNameToContent = TestUtils.getYangResourcesAsMap(networkTopologyModelRfc8345) @@ -133,6 +134,27 @@ class DataNodeBuilderSpec extends Specification { assert result.leaves['source-tp'] == '1-2-1' } + def 'Converting NormalizedNode into DataNode collection: #scenario.'() { + given: 'a schema context for expected model' + def yangResourceNameToContent = TestUtils.getYangResourcesAsMap('test-tree.yang') + def schemaContext = YangTextSchemaSourceSetBuilder.of(yangResourceNameToContent) getSchemaContext() + and: 'parent node xpath referencing parent of list-node element' + def parentNodeXpath = "/test-tree" + and: 'the json data fragment (list-node element) parsed into normalized node object' + def normalizedNode = YangUtils.parseJsonData(jsonData, schemaContext, parentNodeXpath) + when: 'the normalized node is converted to a data node collection' + def result = new DataNodeBuilder().withNormalizedNodeTree(normalizedNode) + .withParentNodeXpath(parentNodeXpath).buildCollection() + def resultXpaths = result.collect { it.getXpath() } + then: 'the resulting collection contains data nodes for expected list elements' + assert resultXpaths.size() == expectedSize + assert resultXpaths.containsAll(expectedXpaths) + where: 'following parameters are used' + scenario | jsonData | expectedSize | expectedXpaths + 'single entry' | '{"branch": [{"name": "One"}]}' | 1 | ['/test-tree/branch[@name=\'One\']'] + 'multiple entries' | '{"branch": [{"name": "One"}, {"name": "Two"}]}' | 2 | ['/test-tree/branch[@name=\'One\']', '/test-tree/branch[@name=\'Two\']'] + } + def static assertLeavesMaps(actualLeavesMap, expectedLeavesMap) { expectedLeavesMap.each { key, value -> { -- cgit 1.2.3-korg