mirror of
https://gitlab.com/qemu-project/qemu
synced 2024-10-15 15:32:51 +00:00
e46354a8ae
These tests use bdrv_write_threshold_exceeded() API, which is used only
for test (since pre-previous commit). Better is testing real API, which
is used in block.c as well.
So, let's call bdrv_write_threshold_check_write(), and check is
bs->write_threshold_offset cleared or not (it's cleared iff threshold
triggered).
Also we get rid of BdrvTrackedRequest use here. Note, that paranoiac
bdrv_check_request() calls were added in 8b1170012b
to protect
BdrvTrackedRequest. Drop them now.
Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
Reviewed-by: Max Reitz <mreitz@redhat.com>
Message-Id: <20210506090621.11848-4-vsementsov@virtuozzo.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Max Reitz <mreitz@redhat.com>
110 lines
2.6 KiB
C
110 lines
2.6 KiB
C
/*
|
|
* Test block device write threshold
|
|
*
|
|
* This work is licensed under the terms of the GNU LGPL, version 2 or later.
|
|
* See the COPYING.LIB file in the top-level directory.
|
|
*
|
|
*/
|
|
|
|
#include "qemu/osdep.h"
|
|
#include "qapi/error.h"
|
|
#include "block/block_int.h"
|
|
#include "block/write-threshold.h"
|
|
|
|
|
|
static void test_threshold_not_set_on_init(void)
|
|
{
|
|
uint64_t res;
|
|
BlockDriverState bs;
|
|
memset(&bs, 0, sizeof(bs));
|
|
|
|
g_assert(!bdrv_write_threshold_is_set(&bs));
|
|
|
|
res = bdrv_write_threshold_get(&bs);
|
|
g_assert_cmpint(res, ==, 0);
|
|
}
|
|
|
|
static void test_threshold_set_get(void)
|
|
{
|
|
uint64_t threshold = 4 * 1024 * 1024;
|
|
uint64_t res;
|
|
BlockDriverState bs;
|
|
memset(&bs, 0, sizeof(bs));
|
|
|
|
bdrv_write_threshold_set(&bs, threshold);
|
|
|
|
g_assert(bdrv_write_threshold_is_set(&bs));
|
|
|
|
res = bdrv_write_threshold_get(&bs);
|
|
g_assert_cmpint(res, ==, threshold);
|
|
}
|
|
|
|
static void test_threshold_multi_set_get(void)
|
|
{
|
|
uint64_t threshold1 = 4 * 1024 * 1024;
|
|
uint64_t threshold2 = 15 * 1024 * 1024;
|
|
uint64_t res;
|
|
BlockDriverState bs;
|
|
memset(&bs, 0, sizeof(bs));
|
|
|
|
bdrv_write_threshold_set(&bs, threshold1);
|
|
bdrv_write_threshold_set(&bs, threshold2);
|
|
res = bdrv_write_threshold_get(&bs);
|
|
g_assert_cmpint(res, ==, threshold2);
|
|
}
|
|
|
|
static void test_threshold_not_trigger(void)
|
|
{
|
|
uint64_t threshold = 4 * 1024 * 1024;
|
|
BlockDriverState bs;
|
|
|
|
memset(&bs, 0, sizeof(bs));
|
|
|
|
bdrv_write_threshold_set(&bs, threshold);
|
|
bdrv_write_threshold_check_write(&bs, 1024, 1024);
|
|
g_assert_cmpuint(bdrv_write_threshold_get(&bs), ==, threshold);
|
|
}
|
|
|
|
|
|
static void test_threshold_trigger(void)
|
|
{
|
|
uint64_t threshold = 4 * 1024 * 1024;
|
|
BlockDriverState bs;
|
|
|
|
memset(&bs, 0, sizeof(bs));
|
|
|
|
bdrv_write_threshold_set(&bs, threshold);
|
|
bdrv_write_threshold_check_write(&bs, threshold - 1024, 2 * 1024);
|
|
g_assert_cmpuint(bdrv_write_threshold_get(&bs), ==, 0);
|
|
}
|
|
|
|
typedef struct TestStruct {
|
|
const char *name;
|
|
void (*func)(void);
|
|
} TestStruct;
|
|
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
size_t i;
|
|
TestStruct tests[] = {
|
|
{ "/write-threshold/not-set-on-init",
|
|
test_threshold_not_set_on_init },
|
|
{ "/write-threshold/set-get",
|
|
test_threshold_set_get },
|
|
{ "/write-threshold/multi-set-get",
|
|
test_threshold_multi_set_get },
|
|
{ "/write-threshold/not-trigger",
|
|
test_threshold_not_trigger },
|
|
{ "/write-threshold/trigger",
|
|
test_threshold_trigger },
|
|
{ NULL, NULL }
|
|
};
|
|
|
|
g_test_init(&argc, &argv, NULL);
|
|
for (i = 0; tests[i].name != NULL; i++) {
|
|
g_test_add_func(tests[i].name, tests[i].func);
|
|
}
|
|
return g_test_run();
|
|
}
|