YARN-8943. Upgrade JUnit from 4 to 5 in hadoop-yarn-api.

Signed-off-by: Takanobu Asanuma <tasanuma@apache.org>
This commit is contained in:
Akira Ajisaka 2018-10-25 14:19:42 +09:00 committed by Takanobu Asanuma
parent b1120d27ab
commit c65218ee8e
9 changed files with 305 additions and 265 deletions

View File

@ -72,6 +72,27 @@
<artifactId>junit</artifactId> <artifactId>junit</artifactId>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-api</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-engine</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
<scope>test</scope>
</dependency>
<!-- Only required to run tests in an IDE that bundles an older version -->
<dependency>
<groupId>org.junit.platform</groupId>
<artifactId>junit-platform-launcher</artifactId>
<scope>test</scope>
</dependency>
<dependency> <dependency>
<groupId>com.fasterxml.jackson.core</groupId> <groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId> <artifactId>jackson-annotations</artifactId>

View File

@ -17,27 +17,29 @@
*/ */
package org.apache.hadoop.yarn.api.records; package org.apache.hadoop.yarn.api.records;
import org.junit.Test; import org.junit.jupiter.api.Test;
import static org.junit.Assert.assertEquals; import static org.junit.jupiter.api.Assertions.assertEquals;
/** /**
* The class to test {@link Resource}. * The class to test {@link Resource}.
*/ */
public class TestResource { class TestResource {
@Test @Test
public void testCastToIntSafely() { void testCastToIntSafely() {
assertEquals(0, Resource.castToIntSafely(0)); assertEquals(0, Resource.castToIntSafely(0));
assertEquals(1, Resource.castToIntSafely(1)); assertEquals(1, Resource.castToIntSafely(1));
assertEquals(Integer.MAX_VALUE, assertEquals(Integer.MAX_VALUE,
Resource.castToIntSafely(Integer.MAX_VALUE)); Resource.castToIntSafely(Integer.MAX_VALUE));
assertEquals("Cast to Integer.MAX_VALUE if the long is greater than " assertEquals(Integer.MAX_VALUE,
+ "Integer.MAX_VALUE", Integer.MAX_VALUE, Resource.castToIntSafely(Integer.MAX_VALUE + 1L),
Resource.castToIntSafely(Integer.MAX_VALUE + 1L)); "Cast to Integer.MAX_VALUE if the long is greater than "
assertEquals("Cast to Integer.MAX_VALUE if the long is greater than " + "Integer.MAX_VALUE");
+ "Integer.MAX_VALUE", Integer.MAX_VALUE, assertEquals(Integer.MAX_VALUE,
Resource.castToIntSafely(Long.MAX_VALUE)); Resource.castToIntSafely(Long.MAX_VALUE),
"Cast to Integer.MAX_VALUE if the long is greater than "
+ "Integer.MAX_VALUE");
} }
} }

View File

@ -17,19 +17,19 @@
*/ */
package org.apache.hadoop.yarn.api.records; package org.apache.hadoop.yarn.api.records;
import static org.junit.Assert.assertEquals; import static org.junit.jupiter.api.Assertions.assertEquals;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.Path;
import org.apache.hadoop.yarn.conf.YarnConfiguration; import org.apache.hadoop.yarn.conf.YarnConfiguration;
import org.apache.hadoop.yarn.factories.RecordFactory; import org.apache.hadoop.yarn.factories.RecordFactory;
import org.junit.Test; import org.junit.jupiter.api.Test;
/** Test for the URL class. */ /** Test for the URL class. */
public class TestURL { class TestURL {
@Test @Test
public void testConversion() throws Exception { void testConversion() throws Exception {
Configuration conf = new Configuration(); Configuration conf = new Configuration();
conf.set(YarnConfiguration.IPC_RECORD_FACTORY_CLASS, conf.set(YarnConfiguration.IPC_RECORD_FACTORY_CLASS,
RecordFactoryForTest.class.getName()); RecordFactoryForTest.class.getName());

View File

@ -18,18 +18,18 @@
package org.apache.hadoop.yarn.api.records.timelineservice; package org.apache.hadoop.yarn.api.records.timelineservice;
import static org.junit.Assert.assertTrue; import static org.junit.jupiter.api.Assertions.assertTrue;
import static org.junit.Assert.assertEquals; import static org.junit.jupiter.api.Assertions.assertEquals;
import org.junit.Test; import org.junit.jupiter.api.Test;
/** /**
* Various tests for the ApplicationEntity class. * Various tests for the ApplicationEntity class.
* *
*/ */
public class TestApplicationEntity { class TestApplicationEntity {
@Test @Test
public void testIsApplicationEntity() { void testIsApplicationEntity() {
TimelineEntity te = new TimelineEntity(); TimelineEntity te = new TimelineEntity();
te.setType(TimelineEntityType.YARN_APPLICATION.toString()); te.setType(TimelineEntityType.YARN_APPLICATION.toString());
assertTrue(ApplicationEntity.isApplicationEntity(te)); assertTrue(ApplicationEntity.isApplicationEntity(te));
@ -43,7 +43,7 @@ public class TestApplicationEntity {
} }
@Test @Test
public void testGetApplicationEvent() { void testGetApplicationEvent() {
TimelineEntity te = null; TimelineEntity te = null;
TimelineEvent tEvent = ApplicationEntity.getApplicationEvent(te, TimelineEvent tEvent = ApplicationEntity.getApplicationEvent(te,
"no event"); "no event");

View File

@ -17,20 +17,20 @@
*/ */
package org.apache.hadoop.yarn.api.records.timelineservice; package org.apache.hadoop.yarn.api.records.timelineservice;
import static org.junit.Assert.assertEquals; import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.Assert.fail; import static org.junit.jupiter.api.Assertions.fail;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import org.apache.hadoop.yarn.api.records.timelineservice.TimelineMetric.Type; import org.apache.hadoop.yarn.api.records.timelineservice.TimelineMetric.Type;
import org.junit.Test; import org.junit.jupiter.api.Test;
public class TestTimelineMetric { class TestTimelineMetric {
@Test @Test
public void testTimelineMetricAggregation() { void testTimelineMetricAggregation() {
long ts = System.currentTimeMillis(); long ts = System.currentTimeMillis();
// single_value metric add against null metric // single_value metric add against null metric
TimelineMetric m1 = getSingleValueMetric("MEGA_BYTES_MILLIS", TimelineMetric m1 = getSingleValueMetric("MEGA_BYTES_MILLIS",

View File

@ -49,17 +49,19 @@ import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.targetIn;
import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.targetNodeAttribute; import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.targetNodeAttribute;
import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.targetNotIn; import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.targetNotIn;
import org.junit.Assert; import static org.junit.jupiter.api.Assertions.assertEquals;
import org.junit.Test; import static org.junit.jupiter.api.Assertions.assertTrue;
import static org.junit.jupiter.api.Assertions.fail;
import org.junit.jupiter.api.Test;
/** /**
* Class to test placement constraint parser. * Class to test placement constraint parser.
*/ */
public class TestPlacementConstraintParser { class TestPlacementConstraintParser {
@Test @Test
public void testTargetExpressionParser() void testTargetExpressionParser() throws PlacementConstraintParseException {
throws PlacementConstraintParseException {
String expressionStr; String expressionStr;
ConstraintParser parser; ConstraintParser parser;
AbstractConstraint constraint; AbstractConstraint constraint;
@ -70,22 +72,22 @@ public class TestPlacementConstraintParser {
expressionStr = "NOTIN, NODE, foo"; expressionStr = "NOTIN, NODE, foo";
parser = new TargetConstraintParser(expressionStr); parser = new TargetConstraintParser(expressionStr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof SingleConstraint); assertTrue(constraint instanceof SingleConstraint);
single = (SingleConstraint) constraint; single = (SingleConstraint) constraint;
Assert.assertEquals("node", single.getScope()); assertEquals("node", single.getScope());
Assert.assertEquals(0, single.getMinCardinality()); assertEquals(0, single.getMinCardinality());
Assert.assertEquals(0, single.getMaxCardinality()); assertEquals(0, single.getMaxCardinality());
verifyConstraintToString(expressionStr, constraint); verifyConstraintToString(expressionStr, constraint);
// lower cases is also valid // lower cases is also valid
expressionStr = "notin, node, foo"; expressionStr = "notin, node, foo";
parser = new TargetConstraintParser(expressionStr); parser = new TargetConstraintParser(expressionStr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof SingleConstraint); assertTrue(constraint instanceof SingleConstraint);
single = (SingleConstraint) constraint; single = (SingleConstraint) constraint;
Assert.assertEquals("node", single.getScope()); assertEquals("node", single.getScope());
Assert.assertEquals(0, single.getMinCardinality()); assertEquals(0, single.getMinCardinality());
Assert.assertEquals(0, single.getMaxCardinality()); assertEquals(0, single.getMaxCardinality());
verifyConstraintToString(expressionStr, constraint); verifyConstraintToString(expressionStr, constraint);
// Affinity with single target tag // Affinity with single target tag
@ -93,11 +95,11 @@ public class TestPlacementConstraintParser {
expressionStr = "IN, NODE, foo"; expressionStr = "IN, NODE, foo";
parser = new TargetConstraintParser(expressionStr); parser = new TargetConstraintParser(expressionStr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof SingleConstraint); assertTrue(constraint instanceof SingleConstraint);
single = (SingleConstraint) constraint; single = (SingleConstraint) constraint;
Assert.assertEquals("node", single.getScope()); assertEquals("node", single.getScope());
Assert.assertEquals(1, single.getMinCardinality()); assertEquals(1, single.getMinCardinality());
Assert.assertEquals(Integer.MAX_VALUE, single.getMaxCardinality()); assertEquals(Integer.MAX_VALUE, single.getMaxCardinality());
verifyConstraintToString(expressionStr, constraint); verifyConstraintToString(expressionStr, constraint);
// Anti-affinity with multiple target tags // Anti-affinity with multiple target tags
@ -105,17 +107,17 @@ public class TestPlacementConstraintParser {
expressionStr = "NOTIN, NODE, foo, bar, exp"; expressionStr = "NOTIN, NODE, foo, bar, exp";
parser = new TargetConstraintParser(expressionStr); parser = new TargetConstraintParser(expressionStr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof SingleConstraint); assertTrue(constraint instanceof SingleConstraint);
single = (SingleConstraint) constraint; single = (SingleConstraint) constraint;
Assert.assertEquals("node", single.getScope()); assertEquals("node", single.getScope());
Assert.assertEquals(0, single.getMinCardinality()); assertEquals(0, single.getMinCardinality());
Assert.assertEquals(0, single.getMaxCardinality()); assertEquals(0, single.getMaxCardinality());
Assert.assertEquals(3, single.getTargetExpressions().size()); assertEquals(3, single.getTargetExpressions().size());
Set<TargetExpression> expectedTargetExpressions = Sets.newHashSet( Set<TargetExpression> expectedTargetExpressions = Sets.newHashSet(
PlacementTargets.allocationTag("foo"), PlacementTargets.allocationTag("foo"),
PlacementTargets.allocationTag("bar"), PlacementTargets.allocationTag("bar"),
PlacementTargets.allocationTag("exp")); PlacementTargets.allocationTag("exp"));
Assert.assertTrue(Sets.difference(expectedTargetExpressions, assertTrue(Sets.difference(expectedTargetExpressions,
single.getTargetExpressions()).isEmpty()); single.getTargetExpressions()).isEmpty());
verifyConstraintToString(expressionStr, constraint); verifyConstraintToString(expressionStr, constraint);
@ -124,13 +126,13 @@ public class TestPlacementConstraintParser {
try { try {
parser.parse(); parser.parse();
} catch (Exception e) { } catch (Exception e) {
Assert.assertTrue(e instanceof PlacementConstraintParseException); assertTrue(e instanceof PlacementConstraintParseException);
Assert.assertTrue(e.getMessage().contains("expecting in or notin")); assertTrue(e.getMessage().contains("expecting in or notin"));
} }
} }
@Test @Test
public void testCardinalityConstraintParser() void testCardinalityConstraintParser()
throws PlacementConstraintParseException { throws PlacementConstraintParseException {
String expressionExpr; String expressionExpr;
ConstraintParser parser; ConstraintParser parser;
@ -141,34 +143,34 @@ public class TestPlacementConstraintParser {
expressionExpr = "cardinality, NODE, foo, 0, 1"; expressionExpr = "cardinality, NODE, foo, 0, 1";
parser = new CardinalityConstraintParser(expressionExpr); parser = new CardinalityConstraintParser(expressionExpr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof SingleConstraint); assertTrue(constraint instanceof SingleConstraint);
single = (SingleConstraint) constraint; single = (SingleConstraint) constraint;
Assert.assertEquals("node", single.getScope()); assertEquals("node", single.getScope());
Assert.assertEquals(0, single.getMinCardinality()); assertEquals(0, single.getMinCardinality());
Assert.assertEquals(1, single.getMaxCardinality()); assertEquals(1, single.getMaxCardinality());
Assert.assertEquals(1, single.getTargetExpressions().size()); assertEquals(1, single.getTargetExpressions().size());
TargetExpression exp = TargetExpression exp =
single.getTargetExpressions().iterator().next(); single.getTargetExpressions().iterator().next();
Assert.assertEquals("ALLOCATION_TAG", exp.getTargetType().toString()); assertEquals("ALLOCATION_TAG", exp.getTargetType().toString());
Assert.assertEquals(1, exp.getTargetValues().size()); assertEquals(1, exp.getTargetValues().size());
Assert.assertEquals("foo", exp.getTargetValues().iterator().next()); assertEquals("foo", exp.getTargetValues().iterator().next());
verifyConstraintToString(expressionExpr, constraint); verifyConstraintToString(expressionExpr, constraint);
// cardinality,NODE,foo,bar,moo,0,1 // cardinality,NODE,foo,bar,moo,0,1
expressionExpr = "cardinality,RACK,foo,bar,moo,0,1"; expressionExpr = "cardinality,RACK,foo,bar,moo,0,1";
parser = new CardinalityConstraintParser(expressionExpr); parser = new CardinalityConstraintParser(expressionExpr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof SingleConstraint); assertTrue(constraint instanceof SingleConstraint);
single = (SingleConstraint) constraint; single = (SingleConstraint) constraint;
Assert.assertEquals("rack", single.getScope()); assertEquals("rack", single.getScope());
Assert.assertEquals(0, single.getMinCardinality()); assertEquals(0, single.getMinCardinality());
Assert.assertEquals(1, single.getMaxCardinality()); assertEquals(1, single.getMaxCardinality());
Assert.assertEquals(3, single.getTargetExpressions().size()); assertEquals(3, single.getTargetExpressions().size());
Set<TargetExpression> expectedTargetExpressions = Sets.newHashSet( Set<TargetExpression> expectedTargetExpressions = Sets.newHashSet(
PlacementTargets.allocationTag("foo"), PlacementTargets.allocationTag("foo"),
PlacementTargets.allocationTag("bar"), PlacementTargets.allocationTag("bar"),
PlacementTargets.allocationTag("moo")); PlacementTargets.allocationTag("moo"));
Assert.assertTrue(Sets.difference(expectedTargetExpressions, assertTrue(Sets.difference(expectedTargetExpressions,
single.getTargetExpressions()).isEmpty()); single.getTargetExpressions()).isEmpty());
verifyConstraintToString(expressionExpr, constraint); verifyConstraintToString(expressionExpr, constraint);
@ -177,9 +179,9 @@ public class TestPlacementConstraintParser {
parser = new CardinalityConstraintParser( parser = new CardinalityConstraintParser(
"cardinality,NOWHERE,foo,bar,moo,0,1"); "cardinality,NOWHERE,foo,bar,moo,0,1");
parser.parse(); parser.parse();
Assert.fail("Expecting a parsing failure!"); fail("Expecting a parsing failure!");
} catch (PlacementConstraintParseException e) { } catch (PlacementConstraintParseException e) {
Assert.assertTrue(e.getMessage() assertTrue(e.getMessage()
.contains("expecting scope to node or rack, but met NOWHERE")); .contains("expecting scope to node or rack, but met NOWHERE"));
} }
@ -188,15 +190,15 @@ public class TestPlacementConstraintParser {
parser = new CardinalityConstraintParser( parser = new CardinalityConstraintParser(
"cardinality,NODE,0,1"); "cardinality,NODE,0,1");
parser.parse(); parser.parse();
Assert.fail("Expecting a parsing failure!"); fail("Expecting a parsing failure!");
} catch (PlacementConstraintParseException e) { } catch (PlacementConstraintParseException e) {
Assert.assertTrue(e.getMessage() assertTrue(e.getMessage()
.contains("at least 5 elements, but only 4 is given")); .contains("at least 5 elements, but only 4 is given"));
} }
} }
@Test @Test
public void testAndConstraintParser() void testAndConstraintParser()
throws PlacementConstraintParseException { throws PlacementConstraintParseException {
String expressionExpr; String expressionExpr;
ConstraintParser parser; ConstraintParser parser;
@ -206,33 +208,33 @@ public class TestPlacementConstraintParser {
expressionExpr = "AND(NOTIN,NODE,foo:NOTIN,NODE,bar)"; expressionExpr = "AND(NOTIN,NODE,foo:NOTIN,NODE,bar)";
parser = new ConjunctionConstraintParser(expressionExpr); parser = new ConjunctionConstraintParser(expressionExpr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof And); assertTrue(constraint instanceof And);
and = (And) constraint; and = (And) constraint;
Assert.assertEquals(2, and.getChildren().size()); assertEquals(2, and.getChildren().size());
verifyConstraintToString(expressionExpr, constraint); verifyConstraintToString(expressionExpr, constraint);
expressionExpr = "AND(NOTIN,NODE,foo:cardinality,NODE,foo,0,1)"; expressionExpr = "AND(NOTIN,NODE,foo:cardinality,NODE,foo,0,1)";
parser = new ConjunctionConstraintParser(expressionExpr); parser = new ConjunctionConstraintParser(expressionExpr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof And); assertTrue(constraint instanceof And);
Assert.assertEquals(2, and.getChildren().size()); assertEquals(2, and.getChildren().size());
verifyConstraintToString(expressionExpr, constraint); verifyConstraintToString(expressionExpr, constraint);
expressionExpr = expressionExpr =
"AND(NOTIN,NODE,foo:AND(NOTIN,NODE,foo:cardinality,NODE,foo,0,1))"; "AND(NOTIN,NODE,foo:AND(NOTIN,NODE,foo:cardinality,NODE,foo,0,1))";
parser = new ConjunctionConstraintParser(expressionExpr); parser = new ConjunctionConstraintParser(expressionExpr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof And); assertTrue(constraint instanceof And);
and = (And) constraint; and = (And) constraint;
Assert.assertTrue(and.getChildren().get(0) instanceof SingleConstraint); assertTrue(and.getChildren().get(0) instanceof SingleConstraint);
Assert.assertTrue(and.getChildren().get(1) instanceof And); assertTrue(and.getChildren().get(1) instanceof And);
and = (And) and.getChildren().get(1); and = (And) and.getChildren().get(1);
Assert.assertEquals(2, and.getChildren().size()); assertEquals(2, and.getChildren().size());
verifyConstraintToString(expressionExpr, constraint); verifyConstraintToString(expressionExpr, constraint);
} }
@Test @Test
public void testOrConstraintParser() void testOrConstraintParser()
throws PlacementConstraintParseException { throws PlacementConstraintParseException {
String expressionExpr; String expressionExpr;
ConstraintParser parser; ConstraintParser parser;
@ -242,33 +244,33 @@ public class TestPlacementConstraintParser {
expressionExpr = "OR(NOTIN,NODE,foo:NOTIN,NODE,bar)"; expressionExpr = "OR(NOTIN,NODE,foo:NOTIN,NODE,bar)";
parser = new ConjunctionConstraintParser(expressionExpr); parser = new ConjunctionConstraintParser(expressionExpr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof Or); assertTrue(constraint instanceof Or);
or = (Or) constraint; or = (Or) constraint;
Assert.assertEquals(2, or.getChildren().size()); assertEquals(2, or.getChildren().size());
verifyConstraintToString(expressionExpr, constraint); verifyConstraintToString(expressionExpr, constraint);
expressionExpr = "OR(NOTIN,NODE,foo:cardinality,NODE,foo,0,1)"; expressionExpr = "OR(NOTIN,NODE,foo:cardinality,NODE,foo,0,1)";
parser = new ConjunctionConstraintParser(expressionExpr); parser = new ConjunctionConstraintParser(expressionExpr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof Or); assertTrue(constraint instanceof Or);
Assert.assertEquals(2, or.getChildren().size()); assertEquals(2, or.getChildren().size());
verifyConstraintToString(expressionExpr, constraint); verifyConstraintToString(expressionExpr, constraint);
expressionExpr = expressionExpr =
"OR(NOTIN,NODE,foo:OR(NOTIN,NODE,foo:cardinality,NODE,foo,0,1))"; "OR(NOTIN,NODE,foo:OR(NOTIN,NODE,foo:cardinality,NODE,foo,0,1))";
parser = new ConjunctionConstraintParser(expressionExpr); parser = new ConjunctionConstraintParser(expressionExpr);
constraint = parser.parse(); constraint = parser.parse();
Assert.assertTrue(constraint instanceof Or); assertTrue(constraint instanceof Or);
or = (Or) constraint; or = (Or) constraint;
Assert.assertTrue(or.getChildren().get(0) instanceof SingleConstraint); assertTrue(or.getChildren().get(0) instanceof SingleConstraint);
Assert.assertTrue(or.getChildren().get(1) instanceof Or); assertTrue(or.getChildren().get(1) instanceof Or);
or = (Or) or.getChildren().get(1); or = (Or) or.getChildren().get(1);
Assert.assertEquals(2, or.getChildren().size()); assertEquals(2, or.getChildren().size());
verifyConstraintToString(expressionExpr, constraint); verifyConstraintToString(expressionExpr, constraint);
} }
@Test @Test
public void testMultipleConstraintsTokenizer() void testMultipleConstraintsTokenizer()
throws PlacementConstraintParseException { throws PlacementConstraintParseException {
MultipleConstraintsTokenizer ct; MultipleConstraintsTokenizer ct;
SourceTagsTokenizer st; SourceTagsTokenizer st;
@ -310,9 +312,9 @@ public class TestPlacementConstraintParser {
st = new SourceTagsTokenizer("A(B)"); st = new SourceTagsTokenizer("A(B)");
mp = new TokenizerTester(st, "A", "B"); mp = new TokenizerTester(st, "A", "B");
mp.verify(); mp.verify();
Assert.fail("Expecting a parsing failure"); fail("Expecting a parsing failure");
} catch (PlacementConstraintParseException e) { } catch (PlacementConstraintParseException e) {
Assert.assertTrue(e.getMessage() assertTrue(e.getMessage()
.contains("Value of the expression must be an integer")); .contains("Value of the expression must be an integer"));
} }
} }
@ -334,15 +336,15 @@ public class TestPlacementConstraintParser {
int i = 0; int i = 0;
while (tokenizer.hasMoreElements()) { while (tokenizer.hasMoreElements()) {
String current = tokenizer.nextElement(); String current = tokenizer.nextElement();
Assert.assertTrue(i < expectedExtractions.length); assertTrue(i < expectedExtractions.length);
Assert.assertEquals(expectedExtractions[i], current); assertEquals(expectedExtractions[i], current);
i++; i++;
} }
} }
} }
@Test @Test
public void testParsePlacementSpec() void testParsePlacementSpec()
throws PlacementConstraintParseException { throws PlacementConstraintParseException {
Map<SourceTags, PlacementConstraint> result; Map<SourceTags, PlacementConstraint> result;
PlacementConstraint expectedPc1, expectedPc2; PlacementConstraint expectedPc1, expectedPc2;
@ -352,92 +354,92 @@ public class TestPlacementConstraintParser {
// Only Source Tag without constraint // Only Source Tag without constraint
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("foo(3)"); .parsePlacementSpec("foo(3)");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
tag1 = result.keySet().iterator().next(); tag1 = result.keySet().iterator().next();
Assert.assertEquals("foo", tag1.getTag()); assertEquals("foo", tag1.getTag());
Assert.assertEquals(3, tag1.getNumOfAllocations()); assertEquals(3, tag1.getNumOfAllocations());
expectedPc1 = null; expectedPc1 = null;
actualPc1 = result.values().iterator().next(); actualPc1 = result.values().iterator().next();
Assert.assertEquals(expectedPc1, actualPc1); assertEquals(expectedPc1, actualPc1);
// A single anti-affinity constraint // A single anti-affinity constraint
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("foo(3),notin,node,foo"); .parsePlacementSpec("foo(3),notin,node,foo");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
tag1 = result.keySet().iterator().next(); tag1 = result.keySet().iterator().next();
Assert.assertEquals("foo", tag1.getTag()); assertEquals("foo", tag1.getTag());
Assert.assertEquals(3, tag1.getNumOfAllocations()); assertEquals(3, tag1.getNumOfAllocations());
expectedPc1 = targetNotIn("node", allocationTag("foo")).build(); expectedPc1 = targetNotIn("node", allocationTag("foo")).build();
actualPc1 = result.values().iterator().next(); actualPc1 = result.values().iterator().next();
Assert.assertEquals(expectedPc1, actualPc1); assertEquals(expectedPc1, actualPc1);
// Upper case // Upper case
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("foo(3),NOTIN,NODE,foo"); .parsePlacementSpec("foo(3),NOTIN,NODE,foo");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
tag1 = result.keySet().iterator().next(); tag1 = result.keySet().iterator().next();
Assert.assertEquals("foo", tag1.getTag()); assertEquals("foo", tag1.getTag());
Assert.assertEquals(3, tag1.getNumOfAllocations()); assertEquals(3, tag1.getNumOfAllocations());
expectedPc1 = targetNotIn("node", allocationTag("foo")).build(); expectedPc1 = targetNotIn("node", allocationTag("foo")).build();
actualPc1 = result.values().iterator().next(); actualPc1 = result.values().iterator().next();
Assert.assertEquals(expectedPc1, actualPc1); assertEquals(expectedPc1, actualPc1);
// A single cardinality constraint // A single cardinality constraint
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("foo(10),cardinality,node,foo,bar,0,100"); .parsePlacementSpec("foo(10),cardinality,node,foo,bar,0,100");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
tag1 = result.keySet().iterator().next(); tag1 = result.keySet().iterator().next();
Assert.assertEquals("foo", tag1.getTag()); assertEquals("foo", tag1.getTag());
Assert.assertEquals(10, tag1.getNumOfAllocations()); assertEquals(10, tag1.getNumOfAllocations());
TargetExpression[] targetExpressions = new TargetExpression[] { TargetExpression[] targetExpressions = new TargetExpression[] {
PlacementTargets.allocationTag("foo"), PlacementTargets.allocationTag("foo"),
PlacementTargets.allocationTag("bar")}; PlacementTargets.allocationTag("bar")};
expectedPc1 = PlacementConstraints.targetCardinality("node", 0, expectedPc1 = PlacementConstraints.targetCardinality("node", 0,
100, targetExpressions).build(); 100, targetExpressions).build();
Assert.assertEquals(expectedPc1, result.values().iterator().next()); assertEquals(expectedPc1, result.values().iterator().next());
// Two constraint expressions // Two constraint expressions
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("foo(3),notin,node,foo:bar(2),in,node,foo"); .parsePlacementSpec("foo(3),notin,node,foo:bar(2),in,node,foo");
Assert.assertEquals(2, result.size()); assertEquals(2, result.size());
Iterator<SourceTags> keyIt = result.keySet().iterator(); Iterator<SourceTags> keyIt = result.keySet().iterator();
tag1 = keyIt.next(); tag1 = keyIt.next();
Assert.assertEquals("foo", tag1.getTag()); assertEquals("foo", tag1.getTag());
Assert.assertEquals(3, tag1.getNumOfAllocations()); assertEquals(3, tag1.getNumOfAllocations());
tag2 = keyIt.next(); tag2 = keyIt.next();
Assert.assertEquals("bar", tag2.getTag()); assertEquals("bar", tag2.getTag());
Assert.assertEquals(2, tag2.getNumOfAllocations()); assertEquals(2, tag2.getNumOfAllocations());
Iterator<PlacementConstraint> valueIt = result.values().iterator(); Iterator<PlacementConstraint> valueIt = result.values().iterator();
expectedPc1 = targetNotIn("node", allocationTag("foo")).build(); expectedPc1 = targetNotIn("node", allocationTag("foo")).build();
expectedPc2 = targetIn("node", allocationTag("foo")).build(); expectedPc2 = targetIn("node", allocationTag("foo")).build();
Assert.assertEquals(expectedPc1, valueIt.next()); assertEquals(expectedPc1, valueIt.next());
Assert.assertEquals(expectedPc2, valueIt.next()); assertEquals(expectedPc2, valueIt.next());
// And constraint // And constraint
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("foo(1000),and(notin,node,bar:in,node,foo)"); .parsePlacementSpec("foo(1000),and(notin,node,bar:in,node,foo)");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
keyIt = result.keySet().iterator(); keyIt = result.keySet().iterator();
tag1 = keyIt.next(); tag1 = keyIt.next();
Assert.assertEquals("foo", tag1.getTag()); assertEquals("foo", tag1.getTag());
Assert.assertEquals(1000, tag1.getNumOfAllocations()); assertEquals(1000, tag1.getNumOfAllocations());
actualPc1 = result.values().iterator().next(); actualPc1 = result.values().iterator().next();
expectedPc1 = and(targetNotIn("node", allocationTag("bar")), expectedPc1 = and(targetNotIn("node", allocationTag("bar")),
targetIn("node", allocationTag("foo"))).build(); targetIn("node", allocationTag("foo"))).build();
Assert.assertEquals(expectedPc1, actualPc1); assertEquals(expectedPc1, actualPc1);
// Multiple constraints with nested forms. // Multiple constraints with nested forms.
result = PlacementConstraintParser.parsePlacementSpec( result = PlacementConstraintParser.parsePlacementSpec(
"foo(1000),and(notin,node,bar:or(in,node,foo:in,node,moo))" "foo(1000),and(notin,node,bar:or(in,node,foo:in,node,moo))"
+ ":bar(200),notin,node,foo"); + ":bar(200),notin,node,foo");
Assert.assertEquals(2, result.size()); assertEquals(2, result.size());
keyIt = result.keySet().iterator(); keyIt = result.keySet().iterator();
tag1 = keyIt.next(); tag1 = keyIt.next();
tag2 = keyIt.next(); tag2 = keyIt.next();
Assert.assertEquals("foo", tag1.getTag()); assertEquals("foo", tag1.getTag());
Assert.assertEquals(1000, tag1.getNumOfAllocations()); assertEquals(1000, tag1.getNumOfAllocations());
Assert.assertEquals("bar", tag2.getTag()); assertEquals("bar", tag2.getTag());
Assert.assertEquals(200, tag2.getNumOfAllocations()); assertEquals(200, tag2.getNumOfAllocations());
valueIt = result.values().iterator(); valueIt = result.values().iterator();
actualPc1 = valueIt.next(); actualPc1 = valueIt.next();
actualPc2 = valueIt.next(); actualPc2 = valueIt.next();
@ -445,18 +447,18 @@ public class TestPlacementConstraintParser {
expectedPc1 = and(targetNotIn("node", allocationTag("bar")), expectedPc1 = and(targetNotIn("node", allocationTag("bar")),
or(targetIn("node", allocationTag("foo")), or(targetIn("node", allocationTag("foo")),
targetIn("node", allocationTag("moo")))).build(); targetIn("node", allocationTag("moo")))).build();
Assert.assertEquals(actualPc1, expectedPc1); assertEquals(actualPc1, expectedPc1);
expectedPc2 = targetNotIn("node", allocationTag("foo")).build(); expectedPc2 = targetNotIn("node", allocationTag("foo")).build();
Assert.assertEquals(expectedPc2, actualPc2); assertEquals(expectedPc2, actualPc2);
// Failure Cases // Failure Cases
String[] invalidSpecs = {"foo(3", "foo),bar", "foobar", "),java=1.7,1.8"}; String[] invalidSpecs = {"foo(3", "foo),bar", "foobar", "),java=1.7,1.8"};
for (String spec : invalidSpecs) { for (String spec : invalidSpecs) {
try { try {
result = PlacementConstraintParser.parsePlacementSpec(spec); result = PlacementConstraintParser.parsePlacementSpec(spec);
Assert.fail("Expected a failure!"); fail("Expected a failure!");
} catch (Exception e) { } catch (Exception e) {
Assert.assertTrue(e instanceof PlacementConstraintParseException); assertTrue(e instanceof PlacementConstraintParseException);
} }
} }
} }
@ -475,13 +477,13 @@ public class TestPlacementConstraintParser {
try { try {
PlacementConstraintParser.parseExpression(constrainExpr); PlacementConstraintParser.parseExpression(constrainExpr);
} catch (PlacementConstraintParseException e) { } catch (PlacementConstraintParseException e) {
Assert.fail("The parser is unable to parse the expression: " fail("The parser is unable to parse the expression: "
+ constrainExpr + ", caused by: " + e.getMessage()); + constrainExpr + ", caused by: " + e.getMessage());
} }
} }
@Test @Test
public void testParseNodeAttributeSpec() void testParseNodeAttributeSpec()
throws PlacementConstraintParseException { throws PlacementConstraintParseException {
Map<SourceTags, PlacementConstraint> result; Map<SourceTags, PlacementConstraint> result;
PlacementConstraint.AbstractConstraint expectedPc1, expectedPc2; PlacementConstraint.AbstractConstraint expectedPc1, expectedPc2;
@ -490,33 +492,33 @@ public class TestPlacementConstraintParser {
// A single node attribute constraint // A single node attribute constraint
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("xyz(4),rm.yarn.io/foo=true"); .parsePlacementSpec("xyz(4),rm.yarn.io/foo=true");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
TargetExpression target = PlacementTargets TargetExpression target = PlacementTargets
.nodeAttribute("rm.yarn.io/foo", "true"); .nodeAttribute("rm.yarn.io/foo", "true");
expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.EQ, target); expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.EQ, target);
actualPc1 = result.values().iterator().next(); actualPc1 = result.values().iterator().next();
Assert.assertEquals(expectedPc1, actualPc1.getConstraintExpr()); assertEquals(expectedPc1, actualPc1.getConstraintExpr());
// A single node attribute constraint // A single node attribute constraint
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("xyz(3),rm.yarn.io/foo!=abc"); .parsePlacementSpec("xyz(3),rm.yarn.io/foo!=abc");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
target = PlacementTargets target = PlacementTargets
.nodeAttribute("rm.yarn.io/foo", "abc"); .nodeAttribute("rm.yarn.io/foo", "abc");
expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.NE, target); expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.NE, target);
actualPc1 = result.values().iterator().next(); actualPc1 = result.values().iterator().next();
Assert.assertEquals(expectedPc1, actualPc1.getConstraintExpr()); assertEquals(expectedPc1, actualPc1.getConstraintExpr());
actualPc1 = result.values().iterator().next(); actualPc1 = result.values().iterator().next();
Assert.assertEquals(expectedPc1, actualPc1.getConstraintExpr()); assertEquals(expectedPc1, actualPc1.getConstraintExpr());
// A single node attribute constraint // A single node attribute constraint
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec( .parsePlacementSpec(
"xyz(1),rm.yarn.io/foo!=abc:zxy(1),rm.yarn.io/bar=true"); "xyz(1),rm.yarn.io/foo!=abc:zxy(1),rm.yarn.io/bar=true");
Assert.assertEquals(2, result.size()); assertEquals(2, result.size());
target = PlacementTargets target = PlacementTargets
.nodeAttribute("rm.yarn.io/foo", "abc"); .nodeAttribute("rm.yarn.io/foo", "abc");
expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.NE, target); expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.NE, target);
@ -527,25 +529,25 @@ public class TestPlacementConstraintParser {
Iterator<PlacementConstraint> valueIt = result.values().iterator(); Iterator<PlacementConstraint> valueIt = result.values().iterator();
actualPc1 = valueIt.next(); actualPc1 = valueIt.next();
actualPc2 = valueIt.next(); actualPc2 = valueIt.next();
Assert.assertEquals(expectedPc1, actualPc1.getConstraintExpr()); assertEquals(expectedPc1, actualPc1.getConstraintExpr());
Assert.assertEquals(expectedPc2, actualPc2.getConstraintExpr()); assertEquals(expectedPc2, actualPc2.getConstraintExpr());
// A single node attribute constraint w/o source tags // A single node attribute constraint w/o source tags
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("rm.yarn.io/foo=true"); .parsePlacementSpec("rm.yarn.io/foo=true");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
target = PlacementTargets.nodeAttribute("rm.yarn.io/foo", "true"); target = PlacementTargets.nodeAttribute("rm.yarn.io/foo", "true");
expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.EQ, target); expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.EQ, target);
SourceTags actualSourceTags = result.keySet().iterator().next(); SourceTags actualSourceTags = result.keySet().iterator().next();
Assert.assertTrue(actualSourceTags.isEmpty()); assertTrue(actualSourceTags.isEmpty());
actualPc1 = result.values().iterator().next(); actualPc1 = result.values().iterator().next();
Assert.assertEquals(expectedPc1, actualPc1.getConstraintExpr()); assertEquals(expectedPc1, actualPc1.getConstraintExpr());
// Node Attribute Constraint With Multiple Values // Node Attribute Constraint With Multiple Values
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("java=1.7,1.8"); .parsePlacementSpec("java=1.7,1.8");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
Set<String> constraintEntities = new TreeSet<>(); Set<String> constraintEntities = new TreeSet<>();
constraintEntities.add("1.7"); constraintEntities.add("1.7");
@ -554,52 +556,52 @@ public class TestPlacementConstraintParser {
constraintEntities.toArray(new String[constraintEntities.size()])); constraintEntities.toArray(new String[constraintEntities.size()]));
expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.EQ, target); expectedPc1 = targetNodeAttribute("node", NodeAttributeOpCode.EQ, target);
actualSourceTags = result.keySet().iterator().next(); actualSourceTags = result.keySet().iterator().next();
Assert.assertTrue(actualSourceTags.isEmpty()); assertTrue(actualSourceTags.isEmpty());
actualPc1 = result.values().iterator().next(); actualPc1 = result.values().iterator().next();
Assert.assertEquals(expectedPc1, actualPc1.getConstraintExpr()); assertEquals(expectedPc1, actualPc1.getConstraintExpr());
// If source tags is not specified for a node-attribute constraint, // If source tags is not specified for a node-attribute constraint,
// then this expression must be single constraint expression. // then this expression must be single constraint expression.
try { try {
PlacementConstraintParser PlacementConstraintParser
.parsePlacementSpec("rm.yarn.io/foo=true:xyz(1),notin,node,xyz"); .parsePlacementSpec("rm.yarn.io/foo=true:xyz(1),notin,node,xyz");
Assert.fail("Expected a failure!"); fail("Expected a failure!");
} catch (Exception e) { } catch (Exception e) {
Assert.assertTrue(e instanceof PlacementConstraintParseException); assertTrue(e instanceof PlacementConstraintParseException);
} }
} }
@Test @Test
public void testParseAllocationTagNameSpace() void testParseAllocationTagNameSpace()
throws PlacementConstraintParseException { throws PlacementConstraintParseException {
Map<SourceTags, PlacementConstraint> result; Map<SourceTags, PlacementConstraint> result;
// Constraint with Two Different NameSpaces // Constraint with Two Different NameSpaces
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("foo(2),notin,node,not-self/bar,all/moo"); .parsePlacementSpec("foo(2),notin,node,not-self/bar,all/moo");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
Set<TargetExpression> expectedTargetExpressions = Sets.newHashSet( Set<TargetExpression> expectedTargetExpressions = Sets.newHashSet(
PlacementTargets.allocationTagWithNamespace("not-self", "bar"), PlacementTargets.allocationTagWithNamespace("not-self", "bar"),
PlacementTargets.allocationTagWithNamespace("all", "moo")); PlacementTargets.allocationTagWithNamespace("all", "moo"));
AbstractConstraint constraint = result.values().iterator().next(). AbstractConstraint constraint = result.values().iterator().next().
getConstraintExpr(); getConstraintExpr();
Assert.assertTrue(constraint instanceof SingleConstraint); assertTrue(constraint instanceof SingleConstraint);
SingleConstraint single = (SingleConstraint) constraint; SingleConstraint single = (SingleConstraint) constraint;
Assert.assertEquals(2, single.getTargetExpressions().size()); assertEquals(2, single.getTargetExpressions().size());
Assert.assertTrue(Sets.difference(expectedTargetExpressions, assertTrue(Sets.difference(expectedTargetExpressions,
single.getTargetExpressions()).isEmpty()); single.getTargetExpressions()).isEmpty());
// Constraint With Default NameSpace SELF // Constraint With Default NameSpace SELF
result = PlacementConstraintParser result = PlacementConstraintParser
.parsePlacementSpec("foo(2),notin,node,moo"); .parsePlacementSpec("foo(2),notin,node,moo");
Assert.assertEquals(1, result.size()); assertEquals(1, result.size());
TargetExpression expectedTargetExpression = PlacementTargets. TargetExpression expectedTargetExpression = PlacementTargets.
allocationTagWithNamespace("self", "moo"); allocationTagWithNamespace("self", "moo");
constraint = result.values().iterator().next().getConstraintExpr(); constraint = result.values().iterator().next().getConstraintExpr();
Assert.assertTrue(constraint instanceof SingleConstraint); assertTrue(constraint instanceof SingleConstraint);
single = (SingleConstraint) constraint; single = (SingleConstraint) constraint;
Assert.assertEquals(1, single.getTargetExpressions().size()); assertEquals(1, single.getTargetExpressions().size());
Assert.assertEquals(expectedTargetExpression, assertEquals(expectedTargetExpression,
single.getTargetExpressions().iterator().next()); single.getTargetExpressions().iterator().next());
// Constraint With Invalid NameSpace // Constraint With Invalid NameSpace
@ -610,8 +612,8 @@ public class TestPlacementConstraintParser {
} catch(PlacementConstraintParseException e) { } catch(PlacementConstraintParseException e) {
caughtException = true; caughtException = true;
} }
Assert.assertTrue("PlacementConstraintParseException is expected", assertTrue(caughtException,
caughtException); "PlacementConstraintParseException is expected");
} }
} }

View File

@ -27,6 +27,8 @@ import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.targetIn;
import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.targetNotIn; import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.targetNotIn;
import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.PlacementTargets.allocationTag; import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.PlacementTargets.allocationTag;
import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.PlacementTargets.nodeAttribute; import static org.apache.hadoop.yarn.api.resource.PlacementConstraints.PlacementTargets.nodeAttribute;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import org.apache.hadoop.yarn.api.records.AllocationTagNamespaceType; import org.apache.hadoop.yarn.api.records.AllocationTagNamespaceType;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.AbstractConstraint; import org.apache.hadoop.yarn.api.resource.PlacementConstraint.AbstractConstraint;
@ -34,36 +36,35 @@ import org.apache.hadoop.yarn.api.resource.PlacementConstraint.And;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.SingleConstraint; import org.apache.hadoop.yarn.api.resource.PlacementConstraint.SingleConstraint;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.TargetExpression; import org.apache.hadoop.yarn.api.resource.PlacementConstraint.TargetExpression;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.TargetExpression.TargetType; import org.apache.hadoop.yarn.api.resource.PlacementConstraint.TargetExpression.TargetType;
import org.junit.Assert; import org.junit.jupiter.api.Test;
import org.junit.Test;
/** /**
* Test class for the various static methods in * Test class for the various static methods in
* {@link org.apache.hadoop.yarn.api.resource.PlacementConstraints}. * {@link org.apache.hadoop.yarn.api.resource.PlacementConstraints}.
*/ */
public class TestPlacementConstraints { class TestPlacementConstraints {
@Test @Test
public void testNodeAffinityToTag() { void testNodeAffinityToTag() {
AbstractConstraint constraintExpr = AbstractConstraint constraintExpr =
targetIn(NODE, allocationTag("hbase-m")); targetIn(NODE, allocationTag("hbase-m"));
SingleConstraint sConstraint = (SingleConstraint) constraintExpr; SingleConstraint sConstraint = (SingleConstraint) constraintExpr;
Assert.assertEquals(NODE, sConstraint.getScope()); assertEquals(NODE, sConstraint.getScope());
Assert.assertEquals(1, sConstraint.getMinCardinality()); assertEquals(1, sConstraint.getMinCardinality());
Assert.assertEquals(Integer.MAX_VALUE, sConstraint.getMaxCardinality()); assertEquals(Integer.MAX_VALUE, sConstraint.getMaxCardinality());
Assert.assertEquals(1, sConstraint.getTargetExpressions().size()); assertEquals(1, sConstraint.getTargetExpressions().size());
TargetExpression tExpr = TargetExpression tExpr =
sConstraint.getTargetExpressions().iterator().next(); sConstraint.getTargetExpressions().iterator().next();
Assert.assertEquals(AllocationTagNamespaceType.SELF.toString(), assertEquals(AllocationTagNamespaceType.SELF.toString(),
tExpr.getTargetKey()); tExpr.getTargetKey());
Assert.assertEquals(TargetType.ALLOCATION_TAG, tExpr.getTargetType()); assertEquals(TargetType.ALLOCATION_TAG, tExpr.getTargetType());
Assert.assertEquals(1, tExpr.getTargetValues().size()); assertEquals(1, tExpr.getTargetValues().size());
Assert.assertEquals("hbase-m", tExpr.getTargetValues().iterator().next()); assertEquals("hbase-m", tExpr.getTargetValues().iterator().next());
PlacementConstraint constraint = PlacementConstraints.build(constraintExpr); PlacementConstraint constraint = PlacementConstraints.build(constraintExpr);
Assert.assertNotNull(constraint.getConstraintExpr()); assertNotNull(constraint.getConstraintExpr());
} }
@Test @Test
@ -72,17 +73,17 @@ public class TestPlacementConstraints {
targetNotIn(NODE, nodeAttribute("java", "1.8")); targetNotIn(NODE, nodeAttribute("java", "1.8"));
SingleConstraint sConstraint = (SingleConstraint) constraintExpr; SingleConstraint sConstraint = (SingleConstraint) constraintExpr;
Assert.assertEquals(NODE, sConstraint.getScope()); assertEquals(NODE, sConstraint.getScope());
Assert.assertEquals(0, sConstraint.getMinCardinality()); assertEquals(0, sConstraint.getMinCardinality());
Assert.assertEquals(0, sConstraint.getMaxCardinality()); assertEquals(0, sConstraint.getMaxCardinality());
Assert.assertEquals(1, sConstraint.getTargetExpressions().size()); assertEquals(1, sConstraint.getTargetExpressions().size());
TargetExpression tExpr = TargetExpression tExpr =
sConstraint.getTargetExpressions().iterator().next(); sConstraint.getTargetExpressions().iterator().next();
Assert.assertEquals("java", tExpr.getTargetKey()); assertEquals("java", tExpr.getTargetKey());
Assert.assertEquals(TargetType.NODE_ATTRIBUTE, tExpr.getTargetType()); assertEquals(TargetType.NODE_ATTRIBUTE, tExpr.getTargetType());
Assert.assertEquals(1, tExpr.getTargetValues().size()); assertEquals(1, tExpr.getTargetValues().size());
Assert.assertEquals("1.8", tExpr.getTargetValues().iterator().next()); assertEquals("1.8", tExpr.getTargetValues().iterator().next());
} }
@Test @Test
@ -93,17 +94,17 @@ public class TestPlacementConstraints {
targetCardinality(RACK, 2, 10, allocationTag("zk"))); targetCardinality(RACK, 2, 10, allocationTag("zk")));
And andExpr = (And) constraintExpr; And andExpr = (And) constraintExpr;
Assert.assertEquals(3, andExpr.getChildren().size()); assertEquals(3, andExpr.getChildren().size());
SingleConstraint sConstr = (SingleConstraint) andExpr.getChildren().get(0); SingleConstraint sConstr = (SingleConstraint) andExpr.getChildren().get(0);
TargetExpression tExpr = sConstr.getTargetExpressions().iterator().next(); TargetExpression tExpr = sConstr.getTargetExpressions().iterator().next();
Assert.assertEquals("spark", tExpr.getTargetValues().iterator().next()); assertEquals("spark", tExpr.getTargetValues().iterator().next());
sConstr = (SingleConstraint) andExpr.getChildren().get(1); sConstr = (SingleConstraint) andExpr.getChildren().get(1);
Assert.assertEquals(0, sConstr.getMinCardinality()); assertEquals(0, sConstr.getMinCardinality());
Assert.assertEquals(3, sConstr.getMaxCardinality()); assertEquals(3, sConstr.getMaxCardinality());
sConstr = (SingleConstraint) andExpr.getChildren().get(2); sConstr = (SingleConstraint) andExpr.getChildren().get(2);
Assert.assertEquals(2, sConstr.getMinCardinality()); assertEquals(2, sConstr.getMinCardinality());
Assert.assertEquals(10, sConstr.getMaxCardinality()); assertEquals(10, sConstr.getMaxCardinality());
} }
} }

View File

@ -22,74 +22,77 @@ import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import org.apache.hadoop.yarn.api.protocolrecords.ResourceTypes; import org.apache.hadoop.yarn.api.protocolrecords.ResourceTypes;
import org.apache.hadoop.yarn.api.records.ResourceInformation; import org.apache.hadoop.yarn.api.records.ResourceInformation;
import org.junit.Assert; import org.junit.jupiter.api.Test;
import org.junit.Test;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotEquals;
import static org.junit.jupiter.api.Assertions.fail;
/** /**
* Test class to verify various resource informations in a given resource. * Test class to verify various resource informations in a given resource.
*/ */
public class TestResourceInformation { class TestResourceInformation {
@Test @Test
public void testName() { void testName() {
String name = "yarn.io/test"; String name = "yarn.io/test";
ResourceInformation ri = ResourceInformation.newInstance(name); ResourceInformation ri = ResourceInformation.newInstance(name);
Assert.assertEquals("Resource name incorrect", name, ri.getName()); assertEquals(name, ri.getName(), "Resource name incorrect");
} }
@Test @Test
public void testUnits() { void testUnits() {
String name = "yarn.io/test"; String name = "yarn.io/test";
String units = "m"; String units = "m";
ResourceInformation ri = ResourceInformation.newInstance(name, units); ResourceInformation ri = ResourceInformation.newInstance(name, units);
Assert.assertEquals("Resource name incorrect", name, ri.getName()); assertEquals(name, ri.getName(), "Resource name incorrect");
Assert.assertEquals("Resource units incorrect", units, ri.getUnits()); assertEquals(units, ri.getUnits(), "Resource units incorrect");
units = "z"; units = "z";
try { try {
ResourceInformation.newInstance(name, units).setUnits(units); ResourceInformation.newInstance(name, units).setUnits(units);
Assert.fail(units + "is not a valid unit"); fail(units + "is not a valid unit");
} catch (IllegalArgumentException ie) { } catch (IllegalArgumentException ie) {
// do nothing // do nothing
} }
} }
@Test @Test
public void testValue() { void testValue() {
String name = "yarn.io/test"; String name = "yarn.io/test";
long value = 1L; long value = 1L;
ResourceInformation ri = ResourceInformation.newInstance(name, value); ResourceInformation ri = ResourceInformation.newInstance(name, value);
Assert.assertEquals("Resource name incorrect", name, ri.getName()); assertEquals(name, ri.getName(), "Resource name incorrect");
Assert.assertEquals("Resource value incorrect", value, ri.getValue()); assertEquals(value, ri.getValue(), "Resource value incorrect");
} }
@Test @Test
public void testResourceInformation() { void testResourceInformation() {
String name = "yarn.io/test"; String name = "yarn.io/test";
long value = 1L; long value = 1L;
String units = "m"; String units = "m";
ResourceInformation ri = ResourceInformation ri =
ResourceInformation.newInstance(name, units, value); ResourceInformation.newInstance(name, units, value);
Assert.assertEquals("Resource name incorrect", name, ri.getName()); assertEquals(name, ri.getName(), "Resource name incorrect");
Assert.assertEquals("Resource value incorrect", value, ri.getValue()); assertEquals(value, ri.getValue(), "Resource value incorrect");
Assert.assertEquals("Resource units incorrect", units, ri.getUnits()); assertEquals(units, ri.getUnits(), "Resource units incorrect");
} }
@Test @Test
public void testEqualsWithTagsAndAttributes() { void testEqualsWithTagsAndAttributes() {
// Same tags but different order // Same tags but different order
ResourceInformation ri01 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri01 = ResourceInformation.newInstance("r1", "M", 100,
ResourceTypes.COUNTABLE, 0, 100, ResourceTypes.COUNTABLE, 0, 100,
ImmutableSet.of("A", "B"), null); ImmutableSet.of("A", "B"), null);
ResourceInformation ri02 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri02 = ResourceInformation.newInstance("r1", "M", 100,
ResourceTypes.COUNTABLE, 0, 100, ImmutableSet.of("B", "A"), null); ResourceTypes.COUNTABLE, 0, 100, ImmutableSet.of("B", "A"), null);
Assert.assertEquals(ri01, ri02); assertEquals(ri01, ri02);
// Different tags // Different tags
ResourceInformation ri11 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri11 = ResourceInformation.newInstance("r1", "M", 100,
ResourceTypes.COUNTABLE, 0, 100, null, null); ResourceTypes.COUNTABLE, 0, 100, null, null);
ResourceInformation ri12 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri12 = ResourceInformation.newInstance("r1", "M", 100,
ResourceTypes.COUNTABLE, 0, 100, ImmutableSet.of("B", "A"), null); ResourceTypes.COUNTABLE, 0, 100, ImmutableSet.of("B", "A"), null);
Assert.assertNotEquals(ri11, ri12); assertNotEquals(ri11, ri12);
// Different attributes // Different attributes
ResourceInformation ri21 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri21 = ResourceInformation.newInstance("r1", "M", 100,
@ -98,20 +101,20 @@ public class TestResourceInformation {
ResourceInformation ri22 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri22 = ResourceInformation.newInstance("r1", "M", 100,
ResourceTypes.COUNTABLE, 0, 100, null, ResourceTypes.COUNTABLE, 0, 100, null,
ImmutableMap.of("A", "A1", "B", "B2")); ImmutableMap.of("A", "A1", "B", "B2"));
Assert.assertNotEquals(ri21, ri22); assertNotEquals(ri21, ri22);
// No tags or attributes // No tags or attributes
ResourceInformation ri31 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri31 = ResourceInformation.newInstance("r1", "M", 100,
ResourceTypes.COUNTABLE, 0, 100, null, null); ResourceTypes.COUNTABLE, 0, 100, null, null);
ResourceInformation ri32 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri32 = ResourceInformation.newInstance("r1", "M", 100,
ResourceTypes.COUNTABLE, 0, 100, null, null); ResourceTypes.COUNTABLE, 0, 100, null, null);
Assert.assertEquals(ri31, ri32); assertEquals(ri31, ri32);
// Null tags/attributes same as empty ones // Null tags/attributes same as empty ones
ResourceInformation ri41 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri41 = ResourceInformation.newInstance("r1", "M", 100,
ResourceTypes.COUNTABLE, 0, 100, ImmutableSet.of(), null); ResourceTypes.COUNTABLE, 0, 100, ImmutableSet.of(), null);
ResourceInformation ri42 = ResourceInformation.newInstance("r1", "M", 100, ResourceInformation ri42 = ResourceInformation.newInstance("r1", "M", 100,
ResourceTypes.COUNTABLE, 0, 100, null, ImmutableMap.of()); ResourceTypes.COUNTABLE, 0, 100, null, ImmutableMap.of());
Assert.assertEquals(ri41, ri42); assertEquals(ri41, ri42);
} }
} }

View File

@ -18,121 +18,132 @@
package org.apache.hadoop.yarn.util; package org.apache.hadoop.yarn.util;
import org.junit.Assert; import org.junit.jupiter.api.Test;
import org.junit.Test;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.fail;
/** /**
* Test class to handle all test cases needed to verify basic unit conversion * Test class to handle all test cases needed to verify basic unit conversion
* scenarios. * scenarios.
*/ */
public class TestUnitsConversionUtil { class TestUnitsConversionUtil {
@Test @Test
public void testUnitsConversion() { void testUnitsConversion() {
int value = 5; int value = 5;
String fromUnit = ""; String fromUnit = "";
long test = value; long test = value;
Assert.assertEquals("pico test failed", assertEquals(value * 1000L * 1000L * 1000L * 1000L,
value * 1000L * 1000L * 1000L * 1000L, UnitsConversionUtil.convert(fromUnit, "p", test),
UnitsConversionUtil.convert(fromUnit, "p", test)); "pico test failed");
Assert.assertEquals("nano test failed", assertEquals(value * 1000L * 1000L * 1000L,
value * 1000L * 1000L * 1000L, UnitsConversionUtil.convert(fromUnit, "n", test),
UnitsConversionUtil.convert(fromUnit, "n", test)); "nano test failed");
Assert assertEquals(value * 1000L * 1000L,
.assertEquals("micro test failed", value * 1000L * 1000L, UnitsConversionUtil.convert(fromUnit, "u", test),
UnitsConversionUtil.convert(fromUnit, "u", test)); "micro test failed");
Assert.assertEquals("milli test failed", value * 1000L, assertEquals(value * 1000L,
UnitsConversionUtil.convert(fromUnit, "m", test)); UnitsConversionUtil.convert(fromUnit, "m", test),
"milli test failed");
test = value * 1000L * 1000L * 1000L * 1000L * 1000L; test = value * 1000L * 1000L * 1000L * 1000L * 1000L;
fromUnit = ""; fromUnit = "";
Assert.assertEquals("kilo test failed", test / 1000L, assertEquals(test / 1000L,
UnitsConversionUtil.convert(fromUnit, "k", test)); UnitsConversionUtil.convert(fromUnit, "k", test),
"kilo test failed");
Assert assertEquals(test / (1000L * 1000L),
.assertEquals("mega test failed", test / (1000L * 1000L), UnitsConversionUtil.convert(fromUnit, "M", test),
UnitsConversionUtil.convert(fromUnit, "M", test)); "mega test failed");
Assert.assertEquals("giga test failed", assertEquals(test / (1000L * 1000L * 1000L),
test / (1000L * 1000L * 1000L), UnitsConversionUtil.convert(fromUnit, "G", test),
UnitsConversionUtil.convert(fromUnit, "G", test)); "giga test failed");
Assert.assertEquals("tera test failed", assertEquals(test / (1000L * 1000L * 1000L * 1000L),
test / (1000L * 1000L * 1000L * 1000L), UnitsConversionUtil.convert(fromUnit, "T", test),
UnitsConversionUtil.convert(fromUnit, "T", test)); "tera test failed");
Assert.assertEquals("peta test failed", assertEquals(test / (1000L * 1000L * 1000L * 1000L * 1000L),
test / (1000L * 1000L * 1000L * 1000L * 1000L), UnitsConversionUtil.convert(fromUnit, "P", test),
UnitsConversionUtil.convert(fromUnit, "P", test)); "peta test failed");
Assert.assertEquals("nano to pico test failed", value * 1000L, assertEquals(value * 1000L,
UnitsConversionUtil.convert("n", "p", value)); UnitsConversionUtil.convert("n", "p", value),
"nano to pico test failed");
Assert.assertEquals("mega to giga test failed", value, assertEquals(value,
UnitsConversionUtil.convert("M", "G", value * 1000L)); UnitsConversionUtil.convert("M", "G", value * 1000L),
"mega to giga test failed");
Assert.assertEquals("Mi to Gi test failed", value, assertEquals(value,
UnitsConversionUtil.convert("Mi", "Gi", value * 1024L)); UnitsConversionUtil.convert("Mi", "Gi", value * 1024L),
"Mi to Gi test failed");
Assert.assertEquals("Mi to Ki test failed", value * 1024, assertEquals(value * 1024,
UnitsConversionUtil.convert("Mi", "Ki", value)); UnitsConversionUtil.convert("Mi", "Ki", value),
"Mi to Ki test failed");
Assert.assertEquals("Ki to base units test failed", 5 * 1024, assertEquals(5 * 1024,
UnitsConversionUtil.convert("Ki", "", 5)); UnitsConversionUtil.convert("Ki", "", 5),
"Ki to base units test failed");
Assert.assertEquals("Mi to k test failed", 1073741, assertEquals(1073741,
UnitsConversionUtil.convert("Mi", "k", 1024)); UnitsConversionUtil.convert("Mi", "k", 1024),
"Mi to k test failed");
Assert.assertEquals("M to Mi test failed", 953, assertEquals(953,
UnitsConversionUtil.convert("M", "Mi", 1000)); UnitsConversionUtil.convert("M", "Mi", 1000),
"M to Mi test failed");
} }
@Test @Test
public void testOverflow() { void testOverflow() {
long test = 5 * 1000L * 1000L * 1000L * 1000L * 1000L; long test = 5 * 1000L * 1000L * 1000L * 1000L * 1000L;
try { try {
UnitsConversionUtil.convert("P", "p", test); UnitsConversionUtil.convert("P", "p", test);
Assert.fail("this operation should result in an overflow"); fail("this operation should result in an overflow");
} catch (IllegalArgumentException ie) { } catch (IllegalArgumentException ie) {
// do nothing // do nothing
} }
try { try {
UnitsConversionUtil.convert("m", "p", Long.MAX_VALUE - 1); UnitsConversionUtil.convert("m", "p", Long.MAX_VALUE - 1);
Assert.fail("this operation should result in an overflow"); fail("this operation should result in an overflow");
} catch (IllegalArgumentException ie) { } catch (IllegalArgumentException ie) {
// do nothing // do nothing
} }
} }
@Test @Test
public void testCompare() { void testCompare() {
String unitA = "P"; String unitA = "P";
long valueA = 1; long valueA = 1;
String unitB = "p"; String unitB = "p";
long valueB = 2; long valueB = 2;
Assert.assertEquals(1, assertEquals(1,
UnitsConversionUtil.compare(unitA, valueA, unitB, valueB)); UnitsConversionUtil.compare(unitA, valueA, unitB, valueB));
Assert.assertEquals(-1, assertEquals(-1,
UnitsConversionUtil.compare(unitB, valueB, unitA, valueA)); UnitsConversionUtil.compare(unitB, valueB, unitA, valueA));
Assert.assertEquals(0, assertEquals(0,
UnitsConversionUtil.compare(unitA, valueA, unitA, valueA)); UnitsConversionUtil.compare(unitA, valueA, unitA, valueA));
Assert.assertEquals(-1, assertEquals(-1,
UnitsConversionUtil.compare(unitA, valueA, unitA, valueB)); UnitsConversionUtil.compare(unitA, valueA, unitA, valueB));
Assert.assertEquals(1, assertEquals(1,
UnitsConversionUtil.compare(unitA, valueB, unitA, valueA)); UnitsConversionUtil.compare(unitA, valueB, unitA, valueA));
unitB = "T"; unitB = "T";
Assert.assertEquals(1, assertEquals(1,
UnitsConversionUtil.compare(unitA, valueA, unitB, valueB)); UnitsConversionUtil.compare(unitA, valueA, unitB, valueB));
Assert.assertEquals(-1, assertEquals(-1,
UnitsConversionUtil.compare(unitB, valueB, unitA, valueA)); UnitsConversionUtil.compare(unitB, valueB, unitA, valueA));
Assert.assertEquals(0, assertEquals(0,
UnitsConversionUtil.compare(unitA, valueA, unitB, 1000L)); UnitsConversionUtil.compare(unitA, valueA, unitB, 1000L));
unitA = "p"; unitA = "p";
unitB = "n"; unitB = "n";
Assert.assertEquals(-1, assertEquals(-1,
UnitsConversionUtil.compare(unitA, valueA, unitB, valueB)); UnitsConversionUtil.compare(unitA, valueA, unitB, valueB));
Assert.assertEquals(1, assertEquals(1,
UnitsConversionUtil.compare(unitB, valueB, unitA, valueA)); UnitsConversionUtil.compare(unitB, valueB, unitA, valueA));
Assert.assertEquals(0, assertEquals(0,
UnitsConversionUtil.compare(unitA, 1000L, unitB, valueA)); UnitsConversionUtil.compare(unitA, 1000L, unitB, valueA));
} }