MAPREDUCE-5234. Change mapred.TaskReport and mapreduce.TaskReport for binary compatibility with mapred in 1.x but incompatible with 0.23.x. Contributed by Mayank Bansal.
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1483940 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
ca80246731
commit
0b668c21b2
@ -172,6 +172,10 @@ Release 2.0.5-beta - UNRELEASED
|
||||
MAPREDUCE-4067. Changed MRClientProtocol api to throw IOException only (Xuan
|
||||
Gong via vinodkv)
|
||||
|
||||
MAPREDUCE-5234. Change mapred.TaskReport and mapreduce.TaskReport for binary
|
||||
compatibility with mapred in 1.x but incompatible with 0.23.x. (Mayank Bansal
|
||||
via vinodkv)
|
||||
|
||||
NEW FEATURES
|
||||
|
||||
IMPROVEMENTS
|
||||
|
@ -75,7 +75,7 @@ public class TaskReport extends org.apache.hadoop.mapreduce.TaskReport {
|
||||
|
||||
static TaskReport downgrade(
|
||||
org.apache.hadoop.mapreduce.TaskReport report) {
|
||||
return new TaskReport(TaskID.downgrade(report.getTaskId()),
|
||||
return new TaskReport(TaskID.downgrade(report.getTaskID()),
|
||||
report.getProgress(), report.getState(), report.getDiagnostics(),
|
||||
report.getCurrentStatus(), report.getStartTime(), report.getFinishTime(),
|
||||
Counters.downgrade(report.getTaskCounters()));
|
||||
@ -90,9 +90,16 @@ public class TaskReport extends org.apache.hadoop.mapreduce.TaskReport {
|
||||
return ret.toArray(new TaskReport[0]);
|
||||
}
|
||||
|
||||
/** The string of the task id. */
|
||||
public String getTaskId() {
|
||||
return TaskID.downgrade(super.getTaskID()).toString();
|
||||
}
|
||||
|
||||
/** The id of the task. */
|
||||
public TaskID getTaskID() { return TaskID.downgrade(super.getTaskId()); }
|
||||
|
||||
public TaskID getTaskID() {
|
||||
return TaskID.downgrade(super.getTaskID());
|
||||
}
|
||||
|
||||
public Counters getCounters() {
|
||||
return Counters.downgrade(super.getTaskCounters());
|
||||
}
|
||||
|
@ -30,6 +30,7 @@ import org.apache.hadoop.io.Text;
|
||||
import org.apache.hadoop.io.Writable;
|
||||
import org.apache.hadoop.io.WritableUtils;
|
||||
import org.apache.hadoop.mapred.TIPStatus;
|
||||
import org.apache.hadoop.mapred.TaskID;
|
||||
import org.apache.hadoop.util.StringInterner;
|
||||
|
||||
/** A report on the state of a task. */
|
||||
@ -76,9 +77,16 @@ public class TaskReport implements Writable {
|
||||
this.finishTime = finishTime;
|
||||
this.counters = counters;
|
||||
}
|
||||
|
||||
/** The id of the task. */
|
||||
public TaskID getTaskId() { return taskid; }
|
||||
|
||||
/** The string of the task ID. */
|
||||
public String getTaskId() {
|
||||
return taskid.toString();
|
||||
}
|
||||
|
||||
/** The ID of the task. */
|
||||
public TaskID getTaskID() {
|
||||
return taskid;
|
||||
}
|
||||
|
||||
/** The amount completed, between zero and one. */
|
||||
public float getProgress() { return progress; }
|
||||
@ -171,7 +179,7 @@ public class TaskReport implements Writable {
|
||||
&& this.progress == report.getProgress()
|
||||
&& this.startTime == report.getStartTime()
|
||||
&& this.state.equals(report.getState())
|
||||
&& this.taskid.equals(report.getTaskId());
|
||||
&& this.taskid.equals(report.getTaskID());
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
@ -26,6 +26,11 @@ import java.io.IOException;
|
||||
|
||||
import org.apache.hadoop.fs.Path;
|
||||
import org.apache.hadoop.io.Text;
|
||||
import org.apache.hadoop.mapreduce.JobID;
|
||||
import org.apache.hadoop.mapreduce.TaskID;
|
||||
import org.apache.hadoop.mapreduce.TaskType;
|
||||
import org.apache.hadoop.mapreduce.JobStatus.State;
|
||||
import org.junit.Assert;
|
||||
import org.junit.Test;
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
@ -53,4 +58,20 @@ public class TestJobInfo {
|
||||
assertEquals(info.getUser().toString(), copyinfo.getUser().toString());
|
||||
|
||||
}
|
||||
|
||||
@Test(timeout = 5000)
|
||||
public void testTaskID() throws IOException, InterruptedException {
|
||||
JobID jobid = new JobID("1014873536921", 6);
|
||||
TaskID tid = new TaskID(jobid, TaskType.MAP, 0);
|
||||
org.apache.hadoop.mapred.TaskID tid1 =
|
||||
org.apache.hadoop.mapred.TaskID.downgrade(tid);
|
||||
org.apache.hadoop.mapred.TaskReport treport =
|
||||
new org.apache.hadoop.mapred.TaskReport(tid1, 0.0f,
|
||||
State.FAILED.toString(), null, TIPStatus.FAILED, 100, 100,
|
||||
new org.apache.hadoop.mapred.Counters());
|
||||
Assert
|
||||
.assertEquals(treport.getTaskId(), "task_1014873536921_0006_m_000000");
|
||||
Assert.assertEquals(treport.getTaskID().toString(),
|
||||
"task_1014873536921_0006_m_000000");
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user