mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-06 17:23:56 -06:00
-----BEGIN PGP SIGNATURE-----
iQEcBAABAgAGBQJZp8cdAAoJEJykq7OBq3PIyeQIALXlHMTJM+I2dfUZfkIYFrEk Euf0z1URMJ9k5hKy1kIhAVlmGWs2fB1snTCm9tZjCtPqMjH5EDWb8z+zrqmorpcQ LyIccYdT/XrFeU1x+n4PlhaubQKXiAfZbUbgZpbkZwGgX0k51gx3V9z1smHme6AX CIODhgotqbJ0Hy2kuAP8TM2OPgx1tcyel34GuT5e3Rrb8nL0QfHfG4nxcpWBB0q8 iipoJfBvKWpRV0azSg+s51x1FFcB3iDKr81uBVABOyLtVW13nF6EMRIP76rqy5qp relNDo6kdmh0W19motNPjOa4BhnPQakEfF+bdARBOJPbXsFzd5X193yQBKW+nq4= =5ltA -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/stefanha/tags/block-pull-request' into staging # gpg: Signature made Thu 31 Aug 2017 09:21:49 BST # gpg: using RSA key 0x9CA4ABB381AB73C8 # gpg: Good signature from "Stefan Hajnoczi <stefanha@redhat.com>" # gpg: aka "Stefan Hajnoczi <stefanha@gmail.com>" # Primary key fingerprint: 8695 A8BF D3F9 7CDA AC35 775A 9CA4 ABB3 81AB 73C8 * remotes/stefanha/tags/block-pull-request: qcow2: allocate cluster_cache/cluster_data on demand qemu-doc: Add UUID support in initiator name tests: migration/guestperf Python 2.6 argparse compatibility docker.py: Python 2.6 argparse compatibility scripts: add argparse module for Python 2.6 compatibility misc: Remove unused Error variables oslib-posix: Print errors before aborting on qemu_alloc_stack() throttle: Test the valid range of config values throttle: Make burst_length 64bit and add range checks throttle: Make LeakyBucket.avg and LeakyBucket.max integer types throttle: Remove throttle_fix_bucket() / throttle_unfix_bucket() throttle: Make throttle_is_valid() a bit less verbose throttle: Update the throttle_fix_bucket() documentation throttle: Fix wrong variable name in the header documentation nvme: Fix get/set number of queues feature, again Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
1d2a8e0690
14 changed files with 2831 additions and 95 deletions
|
@ -13,12 +13,14 @@
|
|||
|
||||
import os
|
||||
import sys
|
||||
sys.path.append(os.path.join(os.path.dirname(__file__),
|
||||
'..', '..', 'scripts'))
|
||||
import argparse
|
||||
import subprocess
|
||||
import json
|
||||
import hashlib
|
||||
import atexit
|
||||
import uuid
|
||||
import argparse
|
||||
import tempfile
|
||||
import re
|
||||
import signal
|
||||
|
|
|
@ -18,12 +18,14 @@
|
|||
#
|
||||
|
||||
|
||||
import argparse
|
||||
import fnmatch
|
||||
import os
|
||||
import os.path
|
||||
import platform
|
||||
import sys
|
||||
sys.path.append(os.path.join(os.path.dirname(__file__),
|
||||
'..', '..', '..', 'scripts'))
|
||||
import argparse
|
||||
import fnmatch
|
||||
import platform
|
||||
|
||||
from guestperf.hardware import Hardware
|
||||
from guestperf.engine import Engine
|
||||
|
|
|
@ -284,13 +284,14 @@ static void test_enabled(void)
|
|||
for (i = 0; i < BUCKETS_COUNT; i++) {
|
||||
throttle_config_init(&cfg);
|
||||
set_cfg_value(false, i, 150);
|
||||
g_assert(throttle_is_valid(&cfg, NULL));
|
||||
g_assert(throttle_enabled(&cfg));
|
||||
}
|
||||
|
||||
for (i = 0; i < BUCKETS_COUNT; i++) {
|
||||
throttle_config_init(&cfg);
|
||||
set_cfg_value(false, i, -150);
|
||||
g_assert(!throttle_enabled(&cfg));
|
||||
g_assert(!throttle_is_valid(&cfg, NULL));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -377,6 +378,82 @@ static void test_is_valid(void)
|
|||
test_is_valid_for_value(1, true);
|
||||
}
|
||||
|
||||
static void test_ranges(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < BUCKETS_COUNT; i++) {
|
||||
LeakyBucket *b = &cfg.buckets[i];
|
||||
throttle_config_init(&cfg);
|
||||
|
||||
/* avg = 0 means throttling is disabled, but the config is valid */
|
||||
b->avg = 0;
|
||||
g_assert(throttle_is_valid(&cfg, NULL));
|
||||
g_assert(!throttle_enabled(&cfg));
|
||||
|
||||
/* These are valid configurations (values <= THROTTLE_VALUE_MAX) */
|
||||
b->avg = 1;
|
||||
g_assert(throttle_is_valid(&cfg, NULL));
|
||||
|
||||
b->avg = THROTTLE_VALUE_MAX;
|
||||
g_assert(throttle_is_valid(&cfg, NULL));
|
||||
|
||||
b->avg = THROTTLE_VALUE_MAX;
|
||||
b->max = THROTTLE_VALUE_MAX;
|
||||
g_assert(throttle_is_valid(&cfg, NULL));
|
||||
|
||||
/* Values over THROTTLE_VALUE_MAX are not allowed */
|
||||
b->avg = THROTTLE_VALUE_MAX + 1;
|
||||
g_assert(!throttle_is_valid(&cfg, NULL));
|
||||
|
||||
b->avg = THROTTLE_VALUE_MAX;
|
||||
b->max = THROTTLE_VALUE_MAX + 1;
|
||||
g_assert(!throttle_is_valid(&cfg, NULL));
|
||||
|
||||
/* burst_length must be between 1 and THROTTLE_VALUE_MAX */
|
||||
b->avg = 1;
|
||||
b->max = 1;
|
||||
b->burst_length = 0;
|
||||
g_assert(!throttle_is_valid(&cfg, NULL));
|
||||
|
||||
b->avg = 1;
|
||||
b->max = 1;
|
||||
b->burst_length = 1;
|
||||
g_assert(throttle_is_valid(&cfg, NULL));
|
||||
|
||||
b->avg = 1;
|
||||
b->max = 1;
|
||||
b->burst_length = THROTTLE_VALUE_MAX;
|
||||
g_assert(throttle_is_valid(&cfg, NULL));
|
||||
|
||||
b->avg = 1;
|
||||
b->max = 1;
|
||||
b->burst_length = THROTTLE_VALUE_MAX + 1;
|
||||
g_assert(!throttle_is_valid(&cfg, NULL));
|
||||
|
||||
/* burst_length * max cannot exceed THROTTLE_VALUE_MAX */
|
||||
b->avg = 1;
|
||||
b->max = 2;
|
||||
b->burst_length = THROTTLE_VALUE_MAX / 2;
|
||||
g_assert(throttle_is_valid(&cfg, NULL));
|
||||
|
||||
b->avg = 1;
|
||||
b->max = 3;
|
||||
b->burst_length = THROTTLE_VALUE_MAX / 2;
|
||||
g_assert(!throttle_is_valid(&cfg, NULL));
|
||||
|
||||
b->avg = 1;
|
||||
b->max = THROTTLE_VALUE_MAX;
|
||||
b->burst_length = 1;
|
||||
g_assert(throttle_is_valid(&cfg, NULL));
|
||||
|
||||
b->avg = 1;
|
||||
b->max = THROTTLE_VALUE_MAX;
|
||||
b->burst_length = 2;
|
||||
g_assert(!throttle_is_valid(&cfg, NULL));
|
||||
}
|
||||
}
|
||||
|
||||
static void test_max_is_missing_limit(void)
|
||||
{
|
||||
int i;
|
||||
|
@ -668,6 +745,7 @@ int main(int argc, char **argv)
|
|||
g_test_add_func("/throttle/config/enabled", test_enabled);
|
||||
g_test_add_func("/throttle/config/conflicting", test_conflicting_config);
|
||||
g_test_add_func("/throttle/config/is_valid", test_is_valid);
|
||||
g_test_add_func("/throttle/config/ranges", test_ranges);
|
||||
g_test_add_func("/throttle/config/max", test_max_is_missing_limit);
|
||||
g_test_add_func("/throttle/config/iops_size",
|
||||
test_iops_size_is_missing_limit);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue