From 6c1711b1a1cede414d92560fd89f145860f3c7d6 Mon Sep 17 00:00:00 2001 From: Christopher Moussa Date: Thu, 15 Jul 2021 12:48:30 -0700 Subject: [PATCH] t: add tests for max-jobs limit enforcement --- t/t1005-max-jobs-limits.t | 86 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100755 t/t1005-max-jobs-limits.t diff --git a/t/t1005-max-jobs-limits.t b/t/t1005-max-jobs-limits.t new file mode 100755 index 000000000..8e2f6c782 --- /dev/null +++ b/t/t1005-max-jobs-limits.t @@ -0,0 +1,86 @@ +#!/bin/bash + +test_description='Test per-user max jobs limits' + +. `dirname $0`/sharness.sh +MULTI_FACTOR_PRIORITY=${FLUX_BUILD_DIR}/src/plugins/.libs/mf_priority.so +SUBMIT_AS=${FLUX_BUILD_DIR}/t/scripts/submit_as.py +SEND_PAYLOAD=${FLUX_BUILD_DIR}/t/scripts/send_payload.py + +export TEST_UNDER_FLUX_NO_JOB_EXEC=y +export TEST_UNDER_FLUX_SCHED_SIMPLE_MODE="limited=1" +test_under_flux 1 job + +flux setattr log-stderr-level 1 + +test_expect_success 'load multi-factor priority plugin' ' + flux jobtap load -r .priority-default ${MULTI_FACTOR_PRIORITY} +' + +test_expect_success 'check that mf_priority plugin is loaded' ' + flux jobtap list | grep mf_priority +' + +test_expect_success 'create fake_user.json' ' + cat <<-EOF >fake_user.json + { + "users" : [ + {"userid": "5011", "bank": "account3", "default_bank": "account3", "fairshare": "0.45321", "max_jobs": "3"}, + {"userid": "5011", "bank": "account2", "default_bank": "account3", "fairshare": "0.11345", "max_jobs": "2"} + ] + } + EOF +' + +test_expect_success 'update plugin with sample test data' ' + flux python ${SEND_PAYLOAD} fake_user.json +' + +test_expect_success 'stop the queue' ' + flux queue stop +' + +test_expect_success 'submit max number of jobs' ' + jobid1=$(flux python ${SUBMIT_AS} 5011 sleep 60) && + jobid2=$(flux python ${SUBMIT_AS} 5011 sleep 60) && + jobid3=$(flux python ${SUBMIT_AS} 5011 sleep 60) +' + +test_expect_success 'submit a job while already having max number of active jobs' ' + test_must_fail flux python ${SUBMIT_AS} 5011 sleep 60 > max_jobs.out 2>&1 && + test_debug "cat max_jobs.out" && + grep "user has max number of jobs submitted" max_jobs.out && + flux job cancel $jobid1 && + flux job cancel $jobid2 && + flux job cancel $jobid3 +' + +test_expect_success 'submit max number of jobs with other bank' ' + jobid1=$(flux python ${SUBMIT_AS} 5011 --setattr=system.bank=account2 sleep 60) && + jobid2=$(flux python ${SUBMIT_AS} 5011 --setattr=system.bank=account2 sleep 60) +' + +test_expect_success 'submit a job while already having max number of active jobs' ' + test_must_fail flux python ${SUBMIT_AS} 5011 --setattr=system.bank=account2 sleep 60 > max_jobs.out 2>&1 && + test_debug "cat max_jobs.out" && + grep "user has max number of jobs submitted" max_jobs.out && + flux job cancel $jobid1 && + flux job cancel $jobid2 +' + +test_expect_success 'submit max number of jobs with a mix of default bank and explicity set bank' ' + jobid1=$(flux python ${SUBMIT_AS} 5011 sleep 60) && + jobid2=$(flux python ${SUBMIT_AS} 5011 --setattr=system.bank=account3 sleep 60) && + jobid3=$(flux python ${SUBMIT_AS} 5011 sleep 60) +' + +test_expect_success 'submit a job while already having max number of active jobs' ' + test_must_fail flux python ${SUBMIT_AS} 5011 sleep 60 > max_jobs.out 2>&1 && + test_debug "cat max_jobs.out" && + grep "user has max number of jobs submitted" max_jobs.out && + flux job cancel $jobid1 && + flux job cancel $jobid2 && + flux job cancel $jobid3 +' + +test_done