blob: 0b8c58a8ca095d76293a1112698ec5fee073c096 [file] [log] [blame]
danielhanrahanc0b6f3a2024-04-29 16:16:42 +01001/*
2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2024 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
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
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.
16 *
17 * SPDX-License-Identifier: Apache-2.0
18 * ============LICENSE_END=========================================================
19 */
20
21import http from 'k6/http';
22import { check } from 'k6';
23import { Trend } from "k6/metrics";
halil.cakal0613fbd2024-05-27 16:06:59 +010024import { NCMP_BASE_URL, getRandomCmHandleId, makeCustomSummaryReport } from './utils.js'
danielhanrahanc0b6f3a2024-04-29 16:16:42 +010025
26let ncmpOverheadTrend = new Trend("ncmp_overhead");
27
28export const options = {
halil.cakal0613fbd2024-05-27 16:06:59 +010029 vus: 12,
30 duration: '30s',
31 thresholds: {
32 http_req_failed: ['rate == 0'],
33 ncmp_overhead: ['avg <= 40'],
34 },
danielhanrahanc0b6f3a2024-04-29 16:16:42 +010035};
36
37// The function that defines VU logic.
halil.cakal0613fbd2024-05-27 16:06:59 +010038export default function () {
danielhanrahanc0b6f3a2024-04-29 16:16:42 +010039 const cmHandleId = getRandomCmHandleId();
40 const datastoreName = 'ncmp-datastore%3Apassthrough-operational';
41 const url = `${NCMP_BASE_URL}/ncmp/v1/ch/${cmHandleId}/data/ds/${datastoreName}?resourceIdentifier=x&include-descendants=true`
42 const response = http.get(url);
43 check(response, {
44 'status equals 200': (r) => r.status === 200,
45 });
46
47 // Calculate overhead assuming DMI data delay is 2500ms.
48 const dmiDelay = 2500; // This should be same as value DATA_FOR_CM_HANDLE_DELAY_MS in docker-compose.yml
49 const overhead = response.timings.duration - dmiDelay;
50 ncmpOverheadTrend.add(overhead);
51}
halil.cakal0613fbd2024-05-27 16:06:59 +010052
53export function handleSummary(data) {
54 return {
55 stdout: makeCustomSummaryReport(data, options),
56 };
57}