e8ea08d9a9
The only place where shard translator was initialising inode ctx was lookup callback. But if the inodes are created and linked through readdirp, shard_lookup() path _may_ not be exercised before FUSE winds other fops on them. Since shard translator does an inode_ctx_get() first thing in most fops, an uninitialised ctx could cause it to fail the operation with ENOMEM. The solution would be to also initialise inode ctx if it has not been done already in readdir(p) callback. Change-Id: I3e058cd2a29bc6a69a96aaac89165c3251315625 BUG: 1250855 Signed-off-by: Krutika Dhananjay <kdhananj@redhat.com> Reviewed-on: http://review.gluster.org/11854 Tested-by: NetBSD Build System <jenkins@build.gluster.org> Reviewed-by: Pranith Kumar Karampuri <pkarampu@redhat.com> Tested-by: Gluster Build System <jenkins@build.gluster.com>
35 lines
563 B
Bash
35 lines
563 B
Bash
#!/bin/bash
|
|
|
|
. $(dirname $0)/../../include.rc
|
|
|
|
cleanup;
|
|
|
|
TESTS_EXPECTED_IN_LOOP=40
|
|
|
|
TEST glusterd
|
|
TEST pidof glusterd
|
|
TEST $CLI volume create $V0 $H0:$B0/${V0}{0,1}
|
|
TEST $CLI volume start $V0
|
|
|
|
TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0
|
|
TEST mkdir $M0/dir
|
|
|
|
for i in {1..20}; do
|
|
TEST_IN_LOOP touch $M0/dir/$i;
|
|
done
|
|
|
|
TEST $CLI volume set $V0 features.shard on
|
|
|
|
TEST ls $M0
|
|
TEST ls $M0/dir
|
|
|
|
for i in {1..10}; do
|
|
TEST_IN_LOOP mv $M0/dir/$i $M0/dir/$i-sharded;
|
|
done
|
|
|
|
for i in {11..20}; do
|
|
TEST_IN_LOOP unlink $M0/dir/$i;
|
|
done
|
|
|
|
cleanup;
|