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.base
23 import org.onap.cps.spi.FetchDescendantsOption
25 import java.time.OffsetDateTime
26 import org.onap.cps.integration.base.CpsIntegrationSpecBase
27 import org.onap.cps.rest.utils.MultipartFileUtil
28 import org.springframework.web.multipart.MultipartFile
30 class CpsPerfTestBase extends PerfTestBase {
32 static def CPS_PERFORMANCE_TEST_DATASPACE = 'cpsPerformanceDataspace'
35 println('## C P S P E R F O R M A N C E T E S T R E S U L T S ##')
39 return dataspaceExists(CPS_PERFORMANCE_TEST_DATASPACE)
42 def setupPerformanceInfraStructure() {
43 cpsAdminService.createDataspace(CPS_PERFORMANCE_TEST_DATASPACE)
44 def modelAsString = CpsIntegrationSpecBase.readResourceDataFile('bookstore/bookstore.yang')
45 cpsModuleService.createSchemaSet(CPS_PERFORMANCE_TEST_DATASPACE, CpsIntegrationSpecBase.BOOKSTORE_SCHEMA_SET, [bookstore: modelAsString])
48 def createInitialData() {
50 createLargeBookstoresData()
55 def createWarmupData() {
56 def data = "{\"bookstore\":{}}"
58 addAnchorsWithData(1, CpsIntegrationSpecBase.BOOKSTORE_SCHEMA_SET, 'warmup', data)
60 def durationInMillis = stopWatch.getTotalTimeMillis()
61 recordAndAssertPerformance('Creating warmup anchor with tiny data tree', 250, durationInMillis)
64 def createLargeBookstoresData() {
65 def data = CpsIntegrationSpecBase.readResourceDataFile('bookstore/largeModelData.json')
67 addAnchorsWithData(5, CpsIntegrationSpecBase.BOOKSTORE_SCHEMA_SET, 'bookstore', data)
69 def durationInMillis = stopWatch.getTotalTimeMillis()
70 recordAndAssertPerformance('Creating bookstore anchors with large data tree', 3_000, durationInMillis)
73 def addOpenRoadModel() {
74 def file = new File('src/test/resources/data/openroadm/correctedModel.zip')
75 def multipartFile = Mock(MultipartFile)
76 multipartFile.getOriginalFilename() >> file.getName()
77 multipartFile.getInputStream() >> new FileInputStream(file)
78 cpsModuleService.createSchemaSet(CPS_PERFORMANCE_TEST_DATASPACE, PerfTestBase.LARGE_SCHEMA_SET, MultipartFileUtil.extractYangResourcesMap(multipartFile))
81 def addOpenRoadData() {
82 def data = CpsIntegrationSpecBase.readResourceDataFile('openroadm/innerNode.json')
84 addAnchorsWithData(5, PerfTestBase.LARGE_SCHEMA_SET, 'openroadm', data)
86 def durationInMillis = stopWatch.getTotalTimeMillis()
87 recordAndAssertPerformance('Creating openroadm anchors with large data tree', 25_000, durationInMillis)
90 def addAnchorsWithData(numberOfAnchors, schemaSetName, anchorNamePrefix, data) {
91 (1..numberOfAnchors).each {
92 cpsAdminService.createAnchor(CPS_PERFORMANCE_TEST_DATASPACE, schemaSetName, anchorNamePrefix + it)
93 cpsDataService.saveData(CPS_PERFORMANCE_TEST_DATASPACE, anchorNamePrefix + it, data, OffsetDateTime.now())
97 def 'Warm the database'() {
98 when: 'get data nodes for warmup anchor'
100 def result = cpsDataService.getDataNodes(CPS_PERFORMANCE_TEST_DATASPACE, 'warmup1', '/', FetchDescendantsOption.OMIT_DESCENDANTS)
101 assert countDataNodesInTree(result) == 1
103 def durationInMillis = stopWatch.getTotalTimeMillis()
104 then: 'all data is read within 15 seconds (warm up not critical)'
105 recordAndAssertPerformance("Warming database", 15_000, durationInMillis)