Message ID | 20230901180235.23980-22-mwilck@suse.com (mailing list archive) |
---|---|
State | Not Applicable, archived |
Delegated to: | christophe varoqui |
Headers | show |
Series | multipath-tools: user-friendly names rework | expand |
On Fri, Sep 01, 2023 at 08:02:34PM +0200, mwilck@suse.com wrote: > From: Martin Wilck <mwilck@suse.com> > > 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". > Reviewed-by: Benjamin Marzinski <bmarzins@redhat.com> > Signed-off-by: Martin Wilck <mwilck@suse.com> > --- > libmultipath/alias.c | 23 ++++++++++++----------- > tests/alias.c | 30 ++++++------------------------ > 2 files changed, 18 insertions(+), 35 deletions(-) > > diff --git a/libmultipath/alias.c b/libmultipath/alias.c > index 6003df0..0f5af17 100644 > --- a/libmultipath/alias.c > +++ b/libmultipath/alias.c > @@ -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]; > + 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; > + /* 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) > diff --git a/tests/alias.c b/tests/alias.c > index 4ac6425..4f54031 100644 > --- a/tests/alias.c > +++ b/tests/alias.c > @@ -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; > @@ -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); > @@ -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); \ > @@ -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); > } > @@ -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); > } > > @@ -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")); > -- > 2.41.0 -- dm-devel mailing list dm-devel@redhat.com https://listman.redhat.com/mailman/listinfo/dm-devel
diff --git a/libmultipath/alias.c b/libmultipath/alias.c index 6003df0..0f5af17 100644 --- a/libmultipath/alias.c +++ b/libmultipath/alias.c @@ -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]; + 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; + /* 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) diff --git a/tests/alias.c b/tests/alias.c index 4ac6425..4f54031 100644 --- a/tests/alias.c +++ b/tests/alias.c @@ -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; @@ -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); @@ -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); \ @@ -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); } @@ -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); } @@ -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"));