path: root/tests/bugs
diff options
authorAnoop C S <>2019-08-10 10:30:26 +0530
committerAmar Tumballi <>2019-08-20 10:12:27 +0000
commitb4b683736367d93daad08a5ee6ca95778c07c5a4 (patch)
treec02004472d8c7081c9a9fe011497f2bf080125da /tests/bugs
parentfaaf22bbe899b0f64b0237398a0d8e3c082f9392 (diff)
performance/md-cache: Do not skip caching of null character xattr values
Null character string is a valid xattr value in file system. But for those xattrs processed by md-cache, it does not update its entries if value is null('\0'). This results in ENODATA when those xattrs are queried afterwards via getxattr() causing failures in basic operations like create, copy etc in a specially configured Samba setup for Mac OS clients. On the other side snapview-server is internally setting empty string("") as value for xattrs received as part of listxattr() and are not intended to be cached. Therefore we try to maintain that behaviour using an additional dictionary key to prevent updation of entries in getxattr() and fgetxattr() callbacks in md-cache. Credits: Poornima G <> Change-Id: I7859cbad0a06ca6d788420c2a495e658699c6ff7 Fixes: bz#1726205 Signed-off-by: Anoop C S <>
Diffstat (limited to 'tests/bugs')
1 files changed, 22 insertions, 0 deletions
diff --git a/tests/bugs/md-cache/bug-1726205.t b/tests/bugs/md-cache/bug-1726205.t
new file mode 100644
index 0000000..795130e
--- /dev/null
+++ b/tests/bugs/md-cache/bug-1726205.t
@@ -0,0 +1,22 @@
+. $(dirname $0)/../../include.rc
+. $(dirname $0)/../../volume.rc
+TEST glusterd;
+TEST $CLI volume create $V0 $H0:$B0/${V0}{1,2,3};
+TEST $CLI volume start $V0
+TEST $CLI volume set $V0 group samba
+TEST $GFS --volfile-id=/$V0 --volfile-server=$H0 $M0
+TEST touch $M0/file
+TEST "setfattr -n "user.DosStream.Zone.Identifier:\$DATA" -v '\0' $M0/file"
+TEST "getfattr -n "user.DosStream.Zone.Identifier:\$DATA" -e hex $M0/file | grep -q 0x00"