}
run_test 230h "migrate .. and root"
+test_230i() {
+ [ $PARALLEL == "yes" ] && skip "skip parallel run" && return
+ [ $MDSCOUNT -lt 2 ] && skip "needs >= 2 MDTs" && return
+
+ mkdir -p $DIR/$tdir/migrate_dir
+
+ $LFS migrate -m 1 $DIR/$tdir/migrate_dir/ ||
+ error "migration fails with a tailing slash"
+
+ $LFS migrate -m 0 $DIR/$tdir/migrate_dir// ||
+ error "migration fails with two tailing slashes"
+}
+run_test 230i "lfs migrate -m tolerates trailing slashes"
+
test_231a()
{
# For simplicity this test assumes that max_pages_per_rpc
}
/* set errno upon failure */
-static DIR *opendir_parent(char *path)
+static DIR *opendir_parent(const char *path)
{
- DIR *parent;
- char *fname;
- char c;
+ char *path_copy;
+ char *parent_path;
+ DIR *parent;
- fname = strrchr(path, '/');
- if (fname == NULL)
- return opendir(".");
-
- c = fname[1];
- fname[1] = '\0';
- parent = opendir(path);
- fname[1] = c;
- return parent;
+ path_copy = strdup(path);
+ if (path_copy == NULL)
+ return NULL;
+
+ parent_path = dirname(path_copy);
+ parent = opendir(parent_path);
+ free(path_copy);
+
+ return parent;
}
static int cb_get_dirstripe(char *path, DIR *d, struct find_param *param)
struct obd_ioctl_data data = { 0 };
int fd;
int ret;
+ char *path_copy;
char *filename;
bool retry = false;
fd = dirfd(tmp_parent);
- filename = basename(path);
+ path_copy = strdup(path);
+ filename = basename(path_copy);
data.ioc_inlbuf1 = (char *)filename;
data.ioc_inllen1 = strlen(filename) + 1;
data.ioc_inlbuf2 = (char *)¶m->fp_mdt_index;
if (parent == NULL)
closedir(tmp_parent);
+ free(path_copy);
+
return ret;
}