1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

tests: fix name-mangling test

We need to use "--verifyudev" for dmsetup mangle command used in
the name-mangling test since without the --verifyudev, we'd end up
with the failed rename.

Also, add direct check for the dev nodes - node with old name must
be gone and node with new name must be present. Before, we checked
just the output of the command.

One bug popped up here when renaming with udev and libdevmapper
fallback checking the udev when target mangle mode is "none"
(fixme added in the libdevmapper's node rename code).
This commit is contained in:
Peter Rajnoha 2014-03-17 11:51:30 +01:00
parent b16235de96
commit 12eb284eec
2 changed files with 44 additions and 3 deletions

View File

@ -1073,6 +1073,24 @@ static int _rename_dev_node(const char *old_name, const char *new_name,
oldpath, newpath); oldpath, newpath);
/* udev may already have renamed the node. Ignore ENOENT. */ /* udev may already have renamed the node. Ignore ENOENT. */
/* FIXME: when renaming to target mangling mode "none" with udev
* while there are some blacklisted characters in the node name,
* udev will remove the old_node, but fails to properly rename
* to new_node. The libdevmapper code tries to call
* rename(old_node,new_node), but that won't do anything
* since the old node is already removed by udev.
* For example renaming 'a\x20b' to 'a b':
* - udev removes 'a\x20b'
* - udev creates 'a' and 'b' (since it considers the ' ' as a delimiter
* - libdevmapper checks udev has done the rename properly
* - libdevmapper calls stat(new_node) and it does not see it
* - libdevmapper calls rename(old_node,new_node)
* - the rename is a NOP since the old_node does not exist anymore
*
* However, this situation is very rare - why would anyone need
* to rename to an unsupported mode??? So a fix for this would be
* just for completeness.
*/
if (rename(oldpath, newpath) < 0 && errno != ENOENT) { if (rename(oldpath, newpath) < 0 && errno != ENOENT) {
log_error("Unable to rename device node from '%s' to '%s'", log_error("Unable to rename device node from '%s' to '%s'",
old_name, new_name); old_name, new_name);

View File

@ -129,7 +129,7 @@ function check_mangle_cmd()
create_dm_dev none "$dm_name" create_dm_dev none "$dm_name"
dmsetup mangle --manglename $mode "${PREFIX}$dm_name" 1>out 2>err || true; dmsetup mangle --manglename $mode --verifyudev "${PREFIX}$dm_name" 1>out 2>err || true;
if [ "$expected" = "OK" ]; then if [ "$expected" = "OK" ]; then
grep "$CORRECT_FORM_STR" out || r=1 grep "$CORRECT_FORM_STR" out || r=1
@ -139,7 +139,30 @@ function check_mangle_cmd()
grep "$FAIL_MULTI_STR" err || r=1 grep "$FAIL_MULTI_STR" err || r=1
else else
rename_expected=1 rename_expected=1
grep -F "$RENAMING_STR ${PREFIX}$expected" out || r=1 if grep -F "$RENAMING_STR ${PREFIX}$expected" out; then
# Check the old node is really renamed.
test -b "$DM_DEV_DIR/mapper/${PREFIX}$dm_name" && r=1
# FIXME: when renaming to mode=none with udev, udev will
# remove the old_node, but fails to properly rename
# to new_node. The libdevmapper code tries to call
# rename(old_node,new_node), but that won't do anything
# since the old node is already removed by udev.
# For example renaming 'a\x20b' to 'a b':
# - udev removes 'a\x20b'
# - udev creates 'a' and 'b' (since it considers the ' ' as a delimiter)
# - libdevmapper checks udev has done the rename properly
# - libdevmapper calls stat(new_node) and it does not see it
# - libdevmapper calls rename(old_node,new_node)
# - the rename is a NOP since the old_node does not exist anymore
#
# Remove this condition once the problem is fixed in libdevmapper.
#
if [ "$mode" != "none" ]; then
test -b "$DM_DEV_DIR/mapper/${PREFIX}$expected" || r=1
fi
else
r=1
fi
fi fi
if [ $r = 0 -a $rename_expected = 1 ]; then if [ $r = 0 -a $rename_expected = 1 ]; then
@ -149,7 +172,7 @@ function check_mangle_cmd()
# failed to rename to expected or renamed when it should not - find the new name # failed to rename to expected or renamed when it should not - find the new name
new_name=$(sed -e "s/.*: $RENAMING_STR //g" out) new_name=$(sed -e "s/.*: $RENAMING_STR //g" out)
# try to remove any of the form - falling back to less probable error scenario # try to remove any of the form - falling back to less probable error scenario
aux dmsetup remove --verifyudev --manglename none "$new_name" || \ remove_dm_dev none "$new_name" || \
remove_dm_dev none "$dm_name" || remove_dm_dev none "$expected" remove_dm_dev none "$dm_name" || remove_dm_dev none "$expected"
else else
# successfuly done nothing # successfuly done nothing