2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2023 Nordix Foundation
4 * ================================================================================
5 * Licensed under the Apache License, Version 2.0 (the 'License');
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
9 * http://www.apache.org/licenses/LICENSE-2.0
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an 'AS IS' BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
17 * SPDX-License-Identifier: Apache-2.0
18 * ============LICENSE_END=========================================================
21 package org.onap.cps.integration.performance.ncmp
23 import java.util.stream.Collectors
25 import static org.onap.cps.spi.FetchDescendantsOption.OMIT_DESCENDANTS
26 import static org.onap.cps.spi.FetchDescendantsOption.INCLUDE_ALL_DESCENDANTS
28 import org.onap.cps.integration.performance.base.NcmpRegistryPerfTestBase
30 class CmHandleQueryPerfTest extends NcmpRegistryPerfTestBase {
34 def setup() { objectUnderTest = cpsQueryService }
36 def 'Query CM Handle IDs by a property name and value.'() {
37 when: 'a cps-path query on name-value pair is performed (without getting descendants)'
39 def cpsPath = '//additional-properties[@name="neType" and @value="RadioNode"]/ancestor::cm-handles'
40 def dataNodes = cpsQueryService.queryDataNodes(NCMP_PERFORMANCE_TEST_DATASPACE, REGISTRY_ANCHOR, cpsPath, OMIT_DESCENDANTS)
41 and: 'the ids of the result are extracted and converted to xpath'
42 def xpaths = dataNodes.stream().map(dataNode -> "/dmi-registry/cm-handles[@id='${dataNode.leaves.id}']".toString() ).collect(Collectors.toSet())
43 and: 'a single get is executed to get all the parent objects and their descendants'
44 def result = cpsDataService.getDataNodesForMultipleXpaths(NCMP_PERFORMANCE_TEST_DATASPACE, REGISTRY_ANCHOR, xpaths, INCLUDE_ALL_DESCENDANTS)
46 def durationInMillis = stopWatch.getTotalTimeMillis()
47 then: 'the required operations are performed within 3 seconds'
48 recordAndAssertPerformance("CpsPath Registry attributes Query", 3_000, durationInMillis)
49 and: 'all but 1 (other node) are returned'
51 and: 'the tree contains all the expected descendants too'
52 assert countDataNodesInTree(result) == 5 * 999
55 def 'Multiple get limitation: 32,764 (~ 2^15) xpaths.'() {
56 given: 'more than 32,764 xpaths)'
58 (0..32_765).each { xpaths.add("/size/of/this/path/does/not/matter/for/limit[@id='" + it + "']") }
59 when: 'get single get is executed to get all the parent objects and their descendants'
60 cpsDataService.getDataNodesForMultipleXpaths(NCMP_PERFORMANCE_TEST_DATASPACE, REGISTRY_ANCHOR, xpaths, INCLUDE_ALL_DESCENDANTS)
61 then: 'no exception is thrown (limit is not present in current implementation)'