diff --git a/hadoop-mapreduce-project/CHANGES.txt b/hadoop-mapreduce-project/CHANGES.txt index 96063facde9..40782eee931 100644 --- a/hadoop-mapreduce-project/CHANGES.txt +++ b/hadoop-mapreduce-project/CHANGES.txt @@ -484,6 +484,9 @@ Release 0.23.5 - UNRELEASED MAPREDUCE-4763 repair test TestUmbilicalProtocolWithJobToken (Ivan A. Veselovsky via bobby) + + MAPREDUCE-4771. KeyFieldBasedPartitioner not partitioning properly when + configured (jlowe via bobby) Release 0.23.4 - UNRELEASED diff --git a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-core/src/main/java/org/apache/hadoop/mapreduce/lib/partition/KeyFieldBasedPartitioner.java b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-core/src/main/java/org/apache/hadoop/mapreduce/lib/partition/KeyFieldBasedPartitioner.java index 0927c1a1766..44cb624c5a8 100644 --- a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-core/src/main/java/org/apache/hadoop/mapreduce/lib/partition/KeyFieldBasedPartitioner.java +++ b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-core/src/main/java/org/apache/hadoop/mapreduce/lib/partition/KeyFieldBasedPartitioner.java @@ -63,6 +63,7 @@ public class KeyFieldBasedPartitioner extends Partitioner public void setConf(Configuration conf) { this.conf = conf; + keyFieldHelper = new KeyFieldHelper(); String keyFieldSeparator = conf.get(MRJobConfig.MAP_OUTPUT_KEY_FIELD_SEPERATOR, "\t"); keyFieldHelper.setKeyFieldSeparator(keyFieldSeparator); diff --git a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-jobclient/src/test/java/org/apache/hadoop/mapred/lib/TestKeyFieldBasedPartitioner.java b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-jobclient/src/test/java/org/apache/hadoop/mapred/lib/TestKeyFieldBasedPartitioner.java index 2ac80d2bba0..02b0507742a 100644 --- a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-jobclient/src/test/java/org/apache/hadoop/mapred/lib/TestKeyFieldBasedPartitioner.java +++ b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-jobclient/src/test/java/org/apache/hadoop/mapred/lib/TestKeyFieldBasedPartitioner.java @@ -17,17 +17,18 @@ */ package org.apache.hadoop.mapred.lib; +import static org.junit.Assert.assertEquals; + import org.apache.hadoop.io.Text; import org.apache.hadoop.mapred.JobConf; -import org.apache.hadoop.mapred.lib.KeyFieldBasedPartitioner; +import org.junit.Test; -import junit.framework.TestCase; - -public class TestKeyFieldBasedPartitioner extends TestCase { +public class TestKeyFieldBasedPartitioner { /** * Test is key-field-based partitioned works with empty key. */ + @Test public void testEmptyKey() throws Exception { KeyFieldBasedPartitioner kfbp = new KeyFieldBasedPartitioner(); @@ -37,4 +38,18 @@ public class TestKeyFieldBasedPartitioner extends TestCase { assertEquals("Empty key should map to 0th partition", 0, kfbp.getPartition(new Text(), new Text(), 10)); } + + @Test + public void testMultiConfigure() { + KeyFieldBasedPartitioner kfbp = + new KeyFieldBasedPartitioner(); + JobConf conf = new JobConf(); + conf.set(KeyFieldBasedPartitioner.PARTITIONER_OPTIONS, "-k1,1"); + kfbp.setConf(conf); + Text key = new Text("foo\tbar"); + Text val = new Text("val"); + int partNum = kfbp.getPartition(key, val, 4096); + kfbp.configure(conf); + assertEquals(partNum, kfbp.getPartition(key,val, 4096)); + } } \ No newline at end of file