YARN-1940. deleteAsUser() terminates early without deleting more files on error. Contributed by Rushabh S Shah
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1588546 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
bc0b7c6145
commit
cda8646cfa
|
@ -68,6 +68,9 @@ Release 2.5.0 - UNRELEASED
|
|||
YARN-1784. TestContainerAllocation assumes CapacityScheduler.
|
||||
(Robert Kanter via kasha)
|
||||
|
||||
YARN-1940. deleteAsUser() terminates early without deleting more files on
|
||||
error (Rushabh S Shah via jlowe)
|
||||
|
||||
Release 2.4.1 - UNRELEASED
|
||||
|
||||
INCOMPATIBLE CHANGES
|
||||
|
|
|
@ -1082,6 +1082,7 @@ static int delete_path(const char *full_path,
|
|||
FTS* tree = fts_open(paths, FTS_PHYSICAL | FTS_XDEV, NULL);
|
||||
FTSENT* entry = NULL;
|
||||
int ret = 0;
|
||||
int ret_errno = 0;
|
||||
|
||||
if (tree == NULL) {
|
||||
fprintf(LOGFILE,
|
||||
|
@ -1099,8 +1100,14 @@ static int delete_path(const char *full_path,
|
|||
if (rmdir(entry->fts_accpath) != 0) {
|
||||
fprintf(LOGFILE, "Couldn't delete directory %s - %s\n",
|
||||
entry->fts_path, strerror(errno));
|
||||
if (errno == EROFS) {
|
||||
exit_code = -1;
|
||||
}
|
||||
// record the first errno
|
||||
if (errno != ENOENT && ret_errno == 0) {
|
||||
ret_errno = errno;
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
|
@ -1111,8 +1118,14 @@ static int delete_path(const char *full_path,
|
|||
if (unlink(entry->fts_accpath) != 0) {
|
||||
fprintf(LOGFILE, "Couldn't delete file %s - %s\n", entry->fts_path,
|
||||
strerror(errno));
|
||||
if (errno == EROFS) {
|
||||
exit_code = -1;
|
||||
}
|
||||
// record the first errno
|
||||
if (errno != ENOENT && ret_errno == 0) {
|
||||
ret_errno = errno;
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
case FTS_DNR: // Unreadable directory
|
||||
|
@ -1154,6 +1167,9 @@ static int delete_path(const char *full_path,
|
|||
}
|
||||
}
|
||||
ret = fts_close(tree);
|
||||
if (ret_errno != 0) {
|
||||
exit_code = -1;
|
||||
}
|
||||
if (exit_code == 0 && ret != 0) {
|
||||
fprintf(LOGFILE, "Error in fts_close while deleting %s\n", full_path);
|
||||
exit_code = -1;
|
||||
|
|
Loading…
Reference in New Issue