Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

test: add more performance tests #1373

Merged
merged 43 commits into from
Nov 6, 2024
Merged
Changes from 1 commit
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
37a83d6
Added more tests
dagfinno Oct 31, 2024
0c2acae
add graphql endpoints
dagfinno Oct 31, 2024
d124a54
add POST request for graphql
dagfinno Oct 31, 2024
3f060c8
add POST request for graphql
dagfinno Oct 31, 2024
da0e851
add get for all enduser dialog paths
dagfinno Oct 31, 2024
2010d94
change performance to yt01
dagfinno Oct 31, 2024
fa65063
Use different create dialog mal
dagfinno Oct 31, 2024
3a94b76
simple search trough graphQL
dagfinno Oct 31, 2024
3f4753b
graphql post sample
dagfinno Oct 31, 2024
7a7b63d
endusers for yt01
dagfinno Oct 31, 2024
8200dc0
graphql post sample
dagfinno Oct 31, 2024
e213d25
serviceowner for yt01
dagfinno Oct 31, 2024
968eef3
test that runs create dialog and search in parallell
dagfinno Oct 31, 2024
401127d
test that first create and then delete a dialog
dagfinno Oct 31, 2024
cdcff0e
fixed filepath for graphql
dagfinno Oct 31, 2024
c677bd4
using dynamic name of workflow run
dagfinno Nov 1, 2024
2b9264d
using dynamic name of workflow run
dagfinno Nov 1, 2024
155fb44
using dynamic name of workflow run
dagfinno Nov 1, 2024
828851d
add http_req_failed rate to thresholds
dagfinno Nov 1, 2024
f4e5f0e
Merge branch 'main' into performance/create-tests
dagfinno Nov 1, 2024
fb08882
Merge branch 'main' into performance/create-tests
dagfinno Nov 1, 2024
cb037e4
chore: perf test url config refactor suggestion (#1375)
oskogstad Nov 1, 2024
80abedf
refactored to lower duplicated code rate
dagfinno Nov 1, 2024
2037132
Merge branch 'main' into performance/create-tests
dagfinno Nov 1, 2024
3af3e1e
Merge branch 'performance/create-tests' of github.com:digdir/dialogpo…
dagfinno Nov 1, 2024
28679dc
implements coderabbitai suggestions
dagfinno Nov 4, 2024
7e02e63
gets duplicated code rate down
dagfinno Nov 4, 2024
e7cf0da
gets duplicated code rate down
dagfinno Nov 4, 2024
74d678c
gets duplicated code rate down
dagfinno Nov 4, 2024
88b4b2b
gets duplicated code rate down
dagfinno Nov 4, 2024
8ff74c2
Merge branch 'main' into performance/create-tests
dagfinno Nov 4, 2024
6546395
implements suggestions from coderabbitai
dagfinno Nov 4, 2024
cc01bc5
implements suggestions from coderabbitai
dagfinno Nov 4, 2024
423962d
Merge branch 'performance/create-tests' of github.com:digdir/dialogpo…
dagfinno Nov 4, 2024
bd5bc8d
Merge branch 'main' into performance/create-tests
arealmaas Nov 5, 2024
d92b9ff
ci: ensure we use secrets from github secrets from env
arealmaas Nov 5, 2024
cbadc0b
Add traceparent header for otel
dagfinno Nov 5, 2024
bd0be61
refactoring; mainly moving tests and methods to new directories and f…
dagfinno Nov 5, 2024
088fc3c
refactoring, directory and file missed the previous commit
dagfinno Nov 5, 2024
5d13c27
documentation performed by github copilot
dagfinno Nov 5, 2024
87faf62
use newer version of k6-utils
dagfinno Nov 5, 2024
d19010b
Merge branch 'main' into performance/create-tests
dagfinno Nov 5, 2024
a864d86
Merge branch 'main' into performance/create-tests
dagfinno Nov 5, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
refactored to lower duplicated code rate
dagfinno committed Nov 1, 2024
commit 80abedfc31f408fa3484c65310d85caa70c27abd
26 changes: 3 additions & 23 deletions tests/k6/tests/enduser/performance/graphql-search.js
Original file line number Diff line number Diff line change
@@ -1,36 +1,16 @@
import { postGQ, expect, expectStatusFor, describe } from "../../../common/testimports.js";
import { SharedArray } from 'k6/data';
import papaparse from 'https://jslib.k6.io/papaparse/5.1.1/index.js';
import { randomItem } from 'https://jslib.k6.io/k6-utils/1.2.0/index.js';
import { getGraphqlParty } from '../../performancetest_data/graphql-search.js';
import { getEndusers, getDefaultThresholds } from '../../performancetest_common/common.js'


const filenameEndusers = '../../performancetest_data/.endusers-with-tokens.csv';

const endUsers = new SharedArray('endUsers', function () {
try {
const csvData = papaparse.parse(open(filenameEndusers), { header: true, skipEmptyLines: true }).data;
if (!csvData.length) {
throw new Error('No data found in CSV file');
}
csvData.forEach((user, index) => {
if (!user.token || !user.ssn) {
throw new Error(`Missing required fields at row ${index + 1}`);
}
});
return csvData;
} catch (error) {
throw new Error(`Failed to load end users: ${error.message}`);
}
});
const endUsers = getEndusers(filenameEndusers);

export let options = {
summaryTrendStats: ['avg', 'min', 'med', 'max', 'p(95)', 'p(99)', 'p(99.5)', 'p(99.9)', 'count'],
thresholds: {
http_req_failed: ['rate<0.01'],
'http_req_duration{name:graph search}': [],
'http_reqs{name:graph search}': [],
},
thresholds: getDefaultThresholds(['http_req_duration', 'http_reqs'],['graphql search'])
};

export default function() {
106 changes: 27 additions & 79 deletions tests/k6/tests/enduser/performance/simple-search.js
Original file line number Diff line number Diff line change
@@ -1,50 +1,23 @@
import { getEU, expect, expectStatusFor, describe } from "../../../common/testimports.js";
import { SharedArray } from 'k6/data';
import papaparse from 'https://jslib.k6.io/papaparse/5.1.1/index.js';
import { randomItem } from 'https://jslib.k6.io/k6-utils/1.2.0/index.js';
import { getEndusers, getDefaultThresholds } from '../../performancetest_common/common.js'

const filenameEndusers = '../../performancetest_data/.endusers-with-tokens.csv';

const endUsers = new SharedArray('endUsers', function () {
try {
const csvData = papaparse.parse(open(filenameEndusers), { header: true, skipEmptyLines: true }).data;
if (!csvData.length) {
throw new Error('No data found in CSV file');
}
csvData.forEach((user, index) => {
if (!user.token || !user.ssn) {
throw new Error(`Missing required fields at row ${index + 1}`);
}
});
return csvData;
} catch (error) {
throw new Error(`Failed to load end users: ${error.message}`);
}
});
const endUsers = getEndusers(filenameEndusers);

export let options = {
summaryTrendStats: ['avg', 'min', 'med', 'max', 'p(95)', 'p(99)', 'p(99.5)', 'p(99.9)', 'count'],
thresholds: {
http_req_failed: ['rate<0.01'],
'http_req_duration{name:simple search}': [],
'http_reqs{name:simple search}': [],
'http_req_duration{name:get dialog}': [],
'http_reqs{name:get dialog}': [],
'http_req_duration{name:get dialog activities}': [],
'http_reqs{name:get dialog activities}': [],
'http_req_duration{name:get dialog activity}': [],
'http_reqs{name:get dialog activity}': [],
'http_req_duration{name:get seenlogs}': [],
'http_reqs{name:get seenlogs}': [],
'http_req_duration{name:get seenlog}': [],
'http_reqs{name:get seenlog}': [],
'http_req_duration{name:get transmissions}': [],
'http_reqs{name:get transmissions}': [],
'http_req_duration{name:get transmission}': [],
'http_reqs{name:get transmission}': [],
'http_req_duration{name:get labellog}': [],
'http_reqs{name:get labellog}': [],
},
thresholds: getDefaultThresholds(['http_req_duration', 'http_reqs'],['simple search',
'get dialog',
'get dialog activities',
'get dialog activity',
'get seenlogs',
'get seenlog',
'get transmissions',
'get transmission',
'get labellog'
])
dagfinno marked this conversation as resolved.
Show resolved Hide resolved
};

export default function() {
@@ -72,53 +45,28 @@ export function simpleSearch(enduser) {
if (r.json().items && r.json().items.length > 0) {
let dialogId = r.json().items[0].id;
if (dialogId) {
getDialog(dialogId, paramsWithToken);
getDialogActivities(dialogId, paramsWithToken);
getSeenLog(dialogId, paramsWithToken);
getLabelLog(dialogId, paramsWithToken);
getDialogTransmissions(dialogId, paramsWithToken);
getContent(dialogId, paramsWithToken, 'get dialog');
getContentChain(dialogId, paramsWithToken, 'get dialog activities', 'get dialog activity', '/activities/')
getContentChain(dialogId, paramsWithToken, 'get seenlogs', 'get seenlog', '/seenlog/')
getContent(dialogId, paramsWithToken, 'get labellog', '/labellog');
getContentChain(dialogId, paramsWithToken, 'get transmissions', 'get transmission', '/transmissions/')
}
}
});
}

export function getDialog(dialogId, paramsWithToken) {
paramsWithToken.tags.name = 'get dialog'
getUrl('dialogs/' + dialogId, paramsWithToken);
}

export function getDialogActivities(dialogId, paramsWithToken) {
paramsWithToken.tags.name = 'get dialog activities'
let d = getUrl('dialogs/' + dialogId + '/activities', paramsWithToken);
let dialog_activites = d.json();
if (dialog_activites.length > 0) {
paramsWithToken.tags.name = 'get dialog activity'
getUrl('dialogs/' + dialogId + '/activities/' + randomItem(dialog_activites).id, paramsWithToken);
}
}

export function getSeenLog(dialogId, paramsWithToken) {
paramsWithToken.tags.name = 'get seenlogs'
let s = getEU('dialogs/' + dialogId + '/seenlog', paramsWithToken);
let seen_logs = s.json();
if (seen_logs.length > 0) {
paramsWithToken.tags.name = 'get seenlog'
getUrl('dialogs/' + dialogId + '/seenlog/' + randomItem(seen_logs).id, paramsWithToken);
}
}

export function getLabelLog(dialogId, paramsWithToken) {
paramsWithToken.tags.name = 'get labellog'
getEU('dialogs/' + dialogId + '/labellog', paramsWithToken);
export function getContent(dialogId, paramsWithToken, tag, path = '') {
paramsWithToken.tags.name = tag
getUrl('dialogs/' + dialogId + path, paramsWithToken);
}

export function getDialogTransmissions(dialogId, paramsWithToken) {
paramsWithToken.tags.name = 'get transmissions'
let d = getUrl('dialogs/' + dialogId + '/transmissions', paramsWithToken);
let dialog_transmissions = d.json();
if (dialog_transmissions.length > 0) {
paramsWithToken.tags.name = 'get transmission'
getUrl('dialogs/' + dialogId + '/transmissions/' + randomItem(dialog_transmissions).id, paramsWithToken);
export function getContentChain(dialogId, paramsWithToken, tag, subtag, endpoint) {
paramsWithToken.tags.name = tag;
let d = getUrl('dialogs/' + dialogId + endpoint, paramsWithToken);
let json = d.json();
if (json.length > 0) {
paramsWithToken.tags.name = subtag;
getUrl('dialogs/' + dialogId + endpoint + randomItem(json).id, paramsWithToken);
}
}

31 changes: 31 additions & 0 deletions tests/k6/tests/performancetest_common/common.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import { SharedArray } from 'k6/data';
import papaparse from 'https://jslib.k6.io/papaparse/5.1.1/index.js';

export function getEndusers(filenameEndusers) {

const endUsers = new SharedArray('endUsers', function () {
try {
const csvData = papaparse.parse(open(filenameEndusers), { header: true, skipEmptyLines: true }).data;
if (!csvData.length) {
throw new Error('No data found in CSV file');
}
csvData.forEach((user, index) => {
if (!user.token || !user.ssn) {
throw new Error(`Missing required fields at row ${index + 1}`);
}
});
return csvData;
} catch (error) {
throw new Error(`Failed to load end users: ${error.message}`);
}
});
return endUsers;
}
dagfinno marked this conversation as resolved.
Show resolved Hide resolved

export function getDefaultThresholds(counters, labels) {
let thresholds = {
http_req_failed: ['rate<0.01']
}
counters.flatMap(t => labels.map(l => thresholds[`${t}{name:${l}}`] = []));
return thresholds;
}
dagfinno marked this conversation as resolved.
Show resolved Hide resolved