MAPREDUCE-6044. Fully qualified intermediate done dir path breaks per-user dir creation on Windows. Contributed by Zhijie Shen.
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1619863 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
0097b15e21
commit
524a63e59e
|
@ -255,6 +255,9 @@ Release 2.6.0 - UNRELEASED
|
||||||
MAPREDUCE-6012. DBInputSplit creates invalid ranges on Oracle.
|
MAPREDUCE-6012. DBInputSplit creates invalid ranges on Oracle.
|
||||||
(Wei Yan via kasha)
|
(Wei Yan via kasha)
|
||||||
|
|
||||||
|
MAPREDUCE-6044. Fully qualified intermediate done dir path breaks per-user dir
|
||||||
|
creation on Windows. (zjshen)
|
||||||
|
|
||||||
Release 2.5.0 - 2014-08-11
|
Release 2.5.0 - 2014-08-11
|
||||||
|
|
||||||
INCOMPATIBLE CHANGES
|
INCOMPATIBLE CHANGES
|
||||||
|
|
|
@ -25,7 +25,6 @@ import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.times;
|
import static org.mockito.Mockito.times;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
import static org.mockito.Mockito.never;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
|
@ -53,6 +52,8 @@ import org.apache.hadoop.mapreduce.v2.api.records.JobId;
|
||||||
import org.apache.hadoop.mapreduce.v2.app.AppContext;
|
import org.apache.hadoop.mapreduce.v2.app.AppContext;
|
||||||
import org.apache.hadoop.mapreduce.v2.app.job.Job;
|
import org.apache.hadoop.mapreduce.v2.app.job.Job;
|
||||||
import org.apache.hadoop.mapreduce.v2.app.job.JobStateInternal;
|
import org.apache.hadoop.mapreduce.v2.app.job.JobStateInternal;
|
||||||
|
import org.apache.hadoop.mapreduce.v2.jobhistory.JHAdminConfig;
|
||||||
|
import org.apache.hadoop.mapreduce.v2.jobhistory.JobHistoryUtils;
|
||||||
import org.apache.hadoop.mapreduce.v2.util.MRBuilderUtils;
|
import org.apache.hadoop.mapreduce.v2.util.MRBuilderUtils;
|
||||||
import org.apache.hadoop.yarn.api.records.ApplicationAttemptId;
|
import org.apache.hadoop.yarn.api.records.ApplicationAttemptId;
|
||||||
import org.apache.hadoop.yarn.api.records.ApplicationId;
|
import org.apache.hadoop.yarn.api.records.ApplicationId;
|
||||||
|
@ -399,6 +400,33 @@ public class TestJobHistoryEventHandler {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetHistoryIntermediateDoneDirForUser() throws IOException {
|
||||||
|
// Test relative path
|
||||||
|
Configuration conf = new Configuration();
|
||||||
|
conf.set(JHAdminConfig.MR_HISTORY_INTERMEDIATE_DONE_DIR,
|
||||||
|
"/mapred/history/done_intermediate");
|
||||||
|
conf.set(MRJobConfig.USER_NAME, System.getProperty("user.name"));
|
||||||
|
String pathStr = JobHistoryUtils.getHistoryIntermediateDoneDirForUser(conf);
|
||||||
|
Assert.assertEquals("/mapred/history/done_intermediate/" +
|
||||||
|
System.getProperty("user.name"), pathStr);
|
||||||
|
|
||||||
|
// Test fully qualified path
|
||||||
|
// Create default configuration pointing to the minicluster
|
||||||
|
conf.set(CommonConfigurationKeysPublic.FS_DEFAULT_NAME_KEY,
|
||||||
|
dfsCluster.getURI().toString());
|
||||||
|
FileOutputStream os = new FileOutputStream(coreSitePath);
|
||||||
|
conf.writeXml(os);
|
||||||
|
os.close();
|
||||||
|
// Simulate execution under a non-default namenode
|
||||||
|
conf.set(CommonConfigurationKeysPublic.FS_DEFAULT_NAME_KEY,
|
||||||
|
"file:///");
|
||||||
|
pathStr = JobHistoryUtils.getHistoryIntermediateDoneDirForUser(conf);
|
||||||
|
Assert.assertEquals(dfsCluster.getURI().toString() +
|
||||||
|
"/mapred/history/done_intermediate/" + System.getProperty("user.name"),
|
||||||
|
pathStr);
|
||||||
|
}
|
||||||
|
|
||||||
private void queueEvent(JHEvenHandlerForTest jheh, JobHistoryEvent event) {
|
private void queueEvent(JHEvenHandlerForTest jheh, JobHistoryEvent event) {
|
||||||
jheh.handle(event);
|
jheh.handle(event);
|
||||||
}
|
}
|
||||||
|
|
|
@ -292,8 +292,8 @@ public class JobHistoryUtils {
|
||||||
* @return the intermediate done directory for jobhistory files.
|
* @return the intermediate done directory for jobhistory files.
|
||||||
*/
|
*/
|
||||||
public static String getHistoryIntermediateDoneDirForUser(Configuration conf) throws IOException {
|
public static String getHistoryIntermediateDoneDirForUser(Configuration conf) throws IOException {
|
||||||
return getConfiguredHistoryIntermediateDoneDirPrefix(conf) + File.separator
|
return new Path(getConfiguredHistoryIntermediateDoneDirPrefix(conf),
|
||||||
+ UserGroupInformation.getCurrentUser().getShortUserName();
|
UserGroupInformation.getCurrentUser().getShortUserName()).toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean shouldCreateNonUserDirectory(Configuration conf) {
|
public static boolean shouldCreateNonUserDirectory(Configuration conf) {
|
||||||
|
|
Loading…
Reference in New Issue