Skip to content

Commit

Permalink
libmultipath: adapt to new semantics of dm_get_uuid()
Browse files Browse the repository at this point in the history
dm_get_uuid() will return 1 for non-existing maps. Thus we don't need
to call dm_map_present() any more in alias_already_taken(). This changes
our semantics: previously we'd avoid using an alias for which dm_get_uuid()
had failed. Now we treat failure in dm_get_uuid() as indication that the
map doesn't exist. This is not dangerous because dm_task_get_uuid() cannot
fail, and thus the modified dm_get_uuid() will fail if and only if
dm_map_present() would return false.

This makes the "failed alias" test mostly obsolete, as "failed" is now
treated as "unused".

Signed-off-by: Martin Wilck <[email protected]>
  • Loading branch information
mwilck committed Aug 29, 2023
1 parent 5e7a0ba commit ef81352
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 36 deletions.
25 changes: 13 additions & 12 deletions libmultipath/alias.c
Original file line number Diff line number Diff line change
Expand Up @@ -295,18 +295,19 @@ scan_devname(const char *alias, const char *prefix)
static bool alias_already_taken(const char *alias, const char *map_wwid)
{

if (dm_map_present(alias)) {
char wwid[WWID_SIZE];

/* If both the name and the wwid match, then it's fine.*/
if (dm_get_uuid(alias, wwid, sizeof(wwid)) == 0 &&
strncmp(map_wwid, wwid, sizeof(wwid)) == 0)
return false;
condlog(3, "%s: alias '%s' already taken, reselecting alias",
map_wwid, alias);
return true;
}
return false;
char wwid[WWID_SIZE];

/* If the map doesn't exist, it's fine */
if (dm_get_uuid(alias, wwid, sizeof(wwid)) != 0)
return false;

/* If both the name and the wwid match, it's fine.*/
if (strncmp(map_wwid, wwid, sizeof(wwid)) == 0)
return false;

condlog(3, "%s: alias '%s' already taken, reselecting alias",
map_wwid, alias);
return true;
}

static bool id_already_taken(int id, const char *prefix, const char *map_wwid)
Expand Down
30 changes: 6 additions & 24 deletions tests/alias.c
Original file line number Diff line number Diff line change
Expand Up @@ -73,12 +73,6 @@ int __wrap_mkstemp(char *template)
return 10;
}

int __wrap_dm_map_present(const char * str)
{
check_expected(str);
return mock_type(int);
}

int __wrap_dm_get_uuid(const char *name, char *uuid, int uuid_len)
{
int ret;
Expand Down Expand Up @@ -398,14 +392,13 @@ static int test_scan_devname(void)

static void mock_unused_alias(const char *alias)
{
expect_string(__wrap_dm_map_present, str, alias);
will_return(__wrap_dm_map_present, 0);
expect_string(__wrap_dm_get_uuid, name, alias);
expect_value(__wrap_dm_get_uuid, uuid_len, WWID_SIZE);
will_return(__wrap_dm_get_uuid, 1);
}

static void mock_self_alias(const char *alias, const char *wwid)
{
expect_string(__wrap_dm_map_present, str, alias);
will_return(__wrap_dm_map_present, 1);
expect_string(__wrap_dm_get_uuid, name, alias);
expect_value(__wrap_dm_get_uuid, uuid_len, WWID_SIZE);
will_return(__wrap_dm_get_uuid, 0);
Expand All @@ -432,18 +425,13 @@ static void mock_self_alias(const char *alias, const char *wwid)

#define mock_failed_alias(alias, wwid) \
do { \
expect_string(__wrap_dm_map_present, str, alias); \
will_return(__wrap_dm_map_present, 1); \
expect_string(__wrap_dm_get_uuid, name, alias); \
expect_value(__wrap_dm_get_uuid, uuid_len, WWID_SIZE); \
will_return(__wrap_dm_get_uuid, 1); \
expect_condlog(3, USED_STR(alias, wwid)); \
} while (0)

#define mock_used_alias(alias, wwid) \
do { \
expect_string(__wrap_dm_map_present, str, alias); \
will_return(__wrap_dm_map_present, 1); \
expect_string(__wrap_dm_get_uuid, name, alias); \
expect_value(__wrap_dm_get_uuid, uuid_len, WWID_SIZE); \
will_return(__wrap_dm_get_uuid, 0); \
Expand Down Expand Up @@ -566,9 +554,8 @@ static void lb_empty_failed(void **state)
mock_bindings_file("");
expect_condlog(3, NOMATCH_WWID_STR("WWID0"));
mock_failed_alias("MPATHa", "WWID0");
mock_unused_alias("MPATHb");
rc = lookup_binding(NULL, "WWID0", &alias, "MPATH", 1);
assert_int_equal(rc, 2);
assert_int_equal(rc, 1);
assert_ptr_equal(alias, NULL);
free(alias);
}
Expand Down Expand Up @@ -666,9 +653,8 @@ static void lb_nomatch_a_3_used_failed_self(void **state)
mock_used_alias("MPATHc", "WWID1");
mock_used_alias("MPATHd", "WWID1");
mock_failed_alias("MPATHe", "WWID1");
mock_self_alias("MPATHf", "WWID1");
rc = lookup_binding(NULL, "WWID1", &alias, "MPATH", 1);
assert_int_equal(rc, 6);
assert_int_equal(rc, 5);
assert_ptr_equal(alias, NULL);
}

Expand Down Expand Up @@ -949,11 +935,7 @@ static void lb_nomatch_b_a_aa_zz(void **state)
* lookup_binding finds MPATHaaa as next free entry, because MPATHaa is
* found before MPATHb, and MPATHzz was in the bindings, too.
*/
for (i = 0; i <= 26; i++) {
print_strbuf(&buf, "MPATH");
format_devname(&buf, i + 1);
print_strbuf(&buf, " WWID%d\n", i);
}
fill_bindings(&buf, 0, 26);
print_strbuf(&buf, "MPATHzz WWID676\n");
mock_bindings_file(get_strbuf_str(&buf));
expect_condlog(3, NOMATCH_WWID_STR("WWID703"));
Expand Down

0 comments on commit ef81352

Please sign in to comment.