glusterfs/tests/bugs/shard/bug-1250855.t
Krutika Dhananjay e8ea08d9a9 features/shard: Fill inode ctx in readdir(p) callback too
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>
2015-08-12 05:09:40 -07:00

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;