summaryrefslogtreecommitdiffstats
path: root/unit
diff options
context:
space:
mode:
Diffstat (limited to 'unit')
-rw-r--r--unit/meson.build18
-rw-r--r--unit/test-argconfig-parse.c164
-rw-r--r--unit/test-suffix-binary-parse.c68
-rw-r--r--unit/test-suffix-si-parse.c53
4 files changed, 20 insertions, 283 deletions
diff --git a/unit/meson.build b/unit/meson.build
index 7e0e878..d4ff925 100644
--- a/unit/meson.build
+++ b/unit/meson.build
@@ -18,15 +18,6 @@ test_suffix_si_parse = executable(
test('suffix_si_parse', test_suffix_si_parse)
-test_suffix_binary_parse = executable(
- 'test-suffix-binary-parse',
- ['test-suffix-binary-parse.c', '../util/suffix.c'],
- include_directories: [incdir, '..'],
- dependencies: [libnvme_dep],
-)
-
-test('suffix_binary_parse', test_suffix_binary_parse)
-
test_uint128_si = executable(
'test-uint128-si',
['test-uint128-si.c', '../util/types.c', '../util/suffix.c'],
@@ -35,12 +26,3 @@ test_uint128_si = executable(
)
test('uint128-si', test_uint128_si)
-
-test_argconfig_parse = executable(
- 'test-argconfig-parse',
- ['test-argconfig-parse.c', '../util/argconfig.c', '../util/suffix.c'],
- include_directories: [incdir, '..'],
- dependencies: [libnvme_dep],
-)
-
-test('argconfig_parse', test_argconfig_parse)
diff --git a/unit/test-argconfig-parse.c b/unit/test-argconfig-parse.c
deleted file mode 100644
index 23c8d4f..0000000
--- a/unit/test-argconfig-parse.c
+++ /dev/null
@@ -1,164 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-or-later
-
-#include <string.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <errno.h>
-#include <locale.h>
-
-#include "../util/argconfig.h"
-#include "nvme/types.h"
-
-#define ARRAY_SIZE(a) (sizeof(a) / sizeof(a[0]))
-
-static int test_rc;
-
-union val {
- bool flag;
- __u64 suffix;
- __u32 uint;
- int int_val;
- __u64 long_val;
- double double_val;
- __u8 byte;
- __u16 shrt;
- int incr;
- char *string;
- char *fmt;
- char *file;
- char *list;
- char *str;
-};
-
-struct toval_test {
- char *arg;
- void *val;
- union val exp;
- int size;
- int ret;
-};
-
-static void check_val(const char *arg, void *exp, void *val, int size)
-{
- if ((size && !memcmp(exp, val, size)) ||
- (!size && !strcmp(*(char **)exp, *(char **)val)))
- return;
-
- switch (size) {
- case 0:
- printf("ERROR: printing {%s}, got '%s', expected '%s'\n",
- arg, *(char **)val, *(char **)exp);
- break;
- default:
- printf("ERROR: printing {%s}, got '%llu', expected '%llu'\n",
- arg, *(unsigned long long *)val, *(unsigned long long *)exp);
- break;
- }
-
- test_rc = 1;
-}
-
-struct cfg {
- bool flag;
- __u64 suffix;
- __u32 uint;
- int int_val;
- __u64 long_val;
- double double_val;
- __u8 byte;
- __u16 shrt;
- int incr;
- char *string;
- char *fmt;
- char *file;
- char *list;
- char *str;
-};
-
-static struct cfg cfg;
-
-#define VAL_TEST(a, c, v, l, r) \
- { a, &cfg.c, { .c = v }, l ? sizeof(cfg.c) : 0, r }
-
-static struct toval_test toval_tests[] = {
- VAL_TEST("--flag", flag, true, true, 0),
- VAL_TEST("--flag=1", flag, false, true, -EINVAL),
- VAL_TEST("--suffix=0", suffix, 0, true, 0),
- VAL_TEST("--suffix=1", suffix, 1, true, 0),
- VAL_TEST("--suffix=1234", suffix, 1234, true, 0),
- VAL_TEST("--suffix=4096", suffix, 4096, true, 0),
- VAL_TEST("--suffix=1Ki", suffix, 1024, true, 0),
- VAL_TEST("--suffix=34Gi", suffix, 36507222016, true, 0),
- VAL_TEST("--suffix=34.9Ki", suffix, 0, true, -EINVAL),
- VAL_TEST("--suffix=32Gii", suffix, 0, true, -EINVAL),
- VAL_TEST("--uint=1", uint, 1, true, 0),
- VAL_TEST("--int=1", int_val, 1, true, 0),
- VAL_TEST("--long=1", long_val, 1, true, 0),
- VAL_TEST("--double=1", double_val, 1, true, 0),
- VAL_TEST("--byte=1", byte, 1, true, 0),
- VAL_TEST("--byte=256", byte, 0, true, -EINVAL),
- VAL_TEST("--shrt=1", shrt, 1, true, 0),
- VAL_TEST("--incr", incr, 1, true, 0),
- VAL_TEST("--incr=1", incr, 0, true, -EINVAL),
- VAL_TEST("--string=string", string, "string", false, 0),
- VAL_TEST("--fmt=fmt", fmt, "fmt", false, 0),
- VAL_TEST("--file=file", file, "file", false, 0),
- VAL_TEST("--list=list", list, "list", false, 0),
- VAL_TEST("--str=str", str, "str", false, 0),
-};
-
-void toval_test(struct toval_test *test)
-{
- const char *desc = "Test argconfig parse";
- int ret;
- char *argv[] = { "test-argconfig", test->arg };
-
- OPT_ARGS(opts) = {
- OPT_FLAG("flag",'f', &cfg.flag, "flag"),
- OPT_SUFFIX("suffix", 's', &cfg.suffix, "suffix"),
- OPT_UINT("uint", 'u', &cfg.uint, "uint"),
- OPT_INT("int", 'i', &cfg.int_val, "int"),
- OPT_LONG("long", 'l', &cfg.long_val, "long"),
- OPT_DOUBLE("double", 'd', &cfg.double_val, "double"),
- OPT_BYTE("byte", 'b', &cfg.byte, "byte"),
- OPT_SHRT("shrt", 'S', &cfg.shrt, "shrt"),
- OPT_INCR("incr", 'I', &cfg.incr, "incr"),
- OPT_STRING("string", 't', "STRING", &cfg.string, "string"),
- OPT_FMT("fmt", 'F', &cfg.fmt, "fmt"),
- OPT_FILE("file", 'L', &cfg.file, "file"),
- OPT_LIST("list", 'T', &cfg.list, "list"),
- OPT_STR("str", 'r', &cfg.str, "str"),
- OPT_END()
- };
-
- ret = argconfig_parse(2, argv, desc, opts);
- if (ret != test->ret) {
- printf("ERROR: converting {%s} failed\n", test->arg);
- test_rc = 1;
- return;
- }
- if (ret)
- return;
-
- check_val(test->arg, &test->exp, test->val, test->size);
-}
-
-int main(void)
-{
- unsigned int i;
- FILE *f;
-
- test_rc = 0;
- setlocale(LC_NUMERIC, "C");
- f = freopen("/dev/null", "w", stderr);
- if (!f)
- printf("ERROR: reopening stderr failed: %s\n", strerror(errno));
-
- for (i = 0; i < ARRAY_SIZE(toval_tests); i++)
- toval_test(&toval_tests[i]);
-
- if (f)
- fclose(f);
-
- return test_rc ? EXIT_FAILURE : EXIT_SUCCESS;
-}
diff --git a/unit/test-suffix-binary-parse.c b/unit/test-suffix-binary-parse.c
deleted file mode 100644
index 5f6ac4a..0000000
--- a/unit/test-suffix-binary-parse.c
+++ /dev/null
@@ -1,68 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-or-later
-
-#include <string.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <errno.h>
-
-#include "../util/suffix.h"
-#include "../util/types.h"
-
-#define ARRAY_SIZE(a) (sizeof(a) / sizeof(a[0]))
-
-static int test_rc;
-
-static void check_num(const char *val, __u64 exp, __u64 num)
-{
- if (exp == num)
- return;
-
- printf("ERROR: printing {%s}, got '%llu', expected '%llu'\n",
- val, (unsigned long long)num, (unsigned long long)exp);
-
- test_rc = 1;
-}
-
-struct tonum_test {
- const char *val;
- const uint64_t exp;
- int ret;
-};
-
-static struct tonum_test tonum_tests[] = {
- { "1234", 1234, 0 },
- { "1Ki", 1024, 0},
- { "34Gi", 36507222016, 0 },
- { "34.9Ki", 0, -EINVAL},
- { "32Gii", 0, -EINVAL },
-};
-
-void tonum_test(struct tonum_test *test)
-{
- char *endptr;
- uint64_t num;
- int ret;
-
- ret = suffix_binary_parse(test->val, &endptr, &num);
- if (ret != test->ret) {
- printf("ERROR: converting {%s} failed\n", test->val);
- test_rc = 1;
- return;
- }
- if (ret)
- return;
-
- check_num(test->val, test->exp, num);
-}
-
-int main(void)
-{
- unsigned int i;
-
- test_rc = 0;
-
- for (i = 0; i < ARRAY_SIZE(tonum_tests); i++)
- tonum_test(&tonum_tests[i]);
-
- return test_rc ? EXIT_FAILURE : EXIT_SUCCESS;
-}
diff --git a/unit/test-suffix-si-parse.c b/unit/test-suffix-si-parse.c
index bc92455..879518b 100644
--- a/unit/test-suffix-si-parse.c
+++ b/unit/test-suffix-si-parse.c
@@ -3,8 +3,6 @@
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
-#include <errno.h>
-#include <locale.h>
#include "../util/suffix.h"
#include "../util/types.h"
@@ -13,54 +11,44 @@
static int test_rc;
-static void check_num(const char *val, __u64 exp, __u64 num)
+static void check_num(const char *val, int lbas, __u64 exp, __u64 num)
{
if (exp == num)
return;
- printf("ERROR: printing {%s}, got '%llu', expected '%llu'\n",
- val, (unsigned long long)num, (unsigned long long)exp);
+ printf("ERROR: printing {%s} (lbas %d), got '%llu', expected '%llu'\n",
+ val, lbas, (unsigned long long)num, (unsigned long long)exp);
test_rc = 1;
}
struct tonum_test {
const char *val;
- const uint64_t exp;
- int ret;
+ int lbas;
+ const __u64 exp;
};
static struct tonum_test tonum_tests[] = {
- { "11995709440", 11995709440, 0 },
- { "1199570940", 1199570940, 0},
- { "234.567M", 234567000, 0 },
- { "1.2k", 1200, 0 },
- { "6.14T", 6140000000000, 0 },
- { "123.4567k", 123456, 0 },
- { "12345.6789101112M", 12345678910, 0},
- { "6.14", 6, 0 },
- { "6.14#", 0, -EINVAL },
- { "2,33", 0, -EINVAL },
- { "3..3", 0, -EINVAL },
- { "123.12MM", 0, -EINVAL },
+ { "11995709440", 512, 11995709440 },
+ { "1199570940", 512, 1199570940 },
+ { "6.14T", 512, 11992187500 },
+ { "6.14T", 520, 11807692307 },
+ { "6.14T", 4096, 1499023437 },
+ { "6.14", 512, 0 },
+ { "6.14#", 512, 0 },
};
void tonum_test(struct tonum_test *test)
{
- char *endptr;
- uint64_t num;
- int ret;
-
- ret = suffix_si_parse(test->val, &endptr, &num);
- if (ret != test->ret) {
- printf("ERROR: converting {%s} failed\n", test->val);
- test_rc = 1;
- return;
- }
- if (ret)
- return;
+ __u64 num;
+ bool suffixed;
+
+ num = suffix_si_parse(test->val, &suffixed);
+
+ if (suffixed)
+ num /= test->lbas;
- check_num(test->val, test->exp, num);
+ check_num(test->val, test->lbas, test->exp, num);
}
int main(void)
@@ -68,7 +56,6 @@ int main(void)
unsigned int i;
test_rc = 0;
- setlocale(LC_NUMERIC, "C");
for (i = 0; i < ARRAY_SIZE(tonum_tests); i++)
tonum_test(&tonum_tests[i]);