Browse Source

Extend path_offset testcase for handling of duplicated separators

Paths with multiple '/' characters in a row (e.g. //somenode//somsubnode),
or trailing '/' characters (e.g. '/somenode/somesubnode/') should be
handled by fdt_path_offset(), and treated as equivalent to
/somenode/somesubnode.

Our current path_offset testcase doesn't check for these cases, so extend
it so it does.

Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
main
David Gibson 10 years ago
parent
commit
ecd4f9d125
  1. 10
      tests/path_offset.c

10
tests/path_offset.c

@ -58,6 +58,8 @@ static void check_path_offset(void *fdt, char *path, int offset) @@ -58,6 +58,8 @@ static void check_path_offset(void *fdt, char *path, int offset)
{
int rc;

verbose_printf("Checking offset of \"%s\" is %d...\n", path, offset);

rc = fdt_path_offset(fdt, path);
if (rc < 0)
FAIL("fdt_path_offset(\"%s\") failed: %s",
@ -92,5 +94,13 @@ int main(int argc, char *argv[]) @@ -92,5 +94,13 @@ int main(int argc, char *argv[])
check_path_offset(fdt, "/subnode@2/subsubnode@0", subsubnode2_offset);
check_path_offset(fdt, "/subnode@2/subsubnode", subsubnode2_offset2);

/* Test paths with extraneous separators */
check_path_offset(fdt, "//", 0);
check_path_offset(fdt, "///", 0);
check_path_offset(fdt, "//subnode@1", subnode1_offset);
check_path_offset(fdt, "/subnode@1/", subnode1_offset);
check_path_offset(fdt, "//subnode@1///", subnode1_offset);
check_path_offset(fdt, "/subnode@2////subsubnode", subsubnode2_offset2);

PASS();
}

Loading…
Cancel
Save