YARN-10256. Refactor TestContainerSchedulerQueuing.testContainerUpdateExecTypeGuaranteedToOpportunistic (Ahmed Hussein via jeagles)
Signed-off-by: Jonathan Eagles <jeagles@gmail.com>
(cherry picked from commit f5081a9a5d
)
This commit is contained in:
parent
d451c9e2a4
commit
b23a585cb1
|
@ -28,7 +28,6 @@ import java.util.Map;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.concurrent.ConcurrentMap;
|
import java.util.concurrent.ConcurrentMap;
|
||||||
|
|
||||||
import com.google.common.base.Supplier;
|
|
||||||
import org.apache.hadoop.fs.UnsupportedFileSystemException;
|
import org.apache.hadoop.fs.UnsupportedFileSystemException;
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.apache.hadoop.test.GenericTestUtils;
|
import org.apache.hadoop.test.GenericTestUtils;
|
||||||
|
@ -1266,37 +1265,24 @@ public class TestContainerSchedulerQueuing extends BaseContainerManagerTest {
|
||||||
1, updateResponse.getSuccessfullyUpdatedContainers().size());
|
1, updateResponse.getSuccessfullyUpdatedContainers().size());
|
||||||
Assert.assertTrue(updateResponse.getFailedRequests().isEmpty());
|
Assert.assertTrue(updateResponse.getFailedRequests().isEmpty());
|
||||||
|
|
||||||
GetContainerStatusesRequest statRequest =
|
final GetContainerStatusesRequest statRequest =
|
||||||
GetContainerStatusesRequest.newInstance(Collections.singletonList(cId));
|
GetContainerStatusesRequest.newInstance(
|
||||||
GenericTestUtils.waitFor(
|
Collections.singletonList(cId));
|
||||||
new Supplier<Boolean>() {
|
final org.apache.hadoop.yarn.api.records.ContainerState expectedState =
|
||||||
@Override
|
org.apache.hadoop.yarn.api.records.ContainerState.RUNNING;
|
||||||
public Boolean get() {
|
|
||||||
try {
|
|
||||||
List<ContainerStatus> containerStatuses = containerManager
|
|
||||||
.getContainerStatuses(statRequest).getContainerStatuses();
|
|
||||||
Assert.assertEquals(1, containerStatuses.size());
|
|
||||||
|
|
||||||
ContainerStatus status = containerStatuses.get(0);
|
GenericTestUtils.waitFor(() -> {
|
||||||
Assert.assertEquals(
|
List<ContainerStatus> containerStatuses;
|
||||||
org.apache.hadoop.yarn.api.records.ContainerState.RUNNING,
|
try {
|
||||||
status.getState());
|
containerStatuses = containerManager
|
||||||
|
.getContainerStatuses(statRequest).getContainerStatuses();
|
||||||
return status.getExecutionType() == ExecutionType.OPPORTUNISTIC;
|
} catch (YarnException | IOException e) {
|
||||||
} catch (Exception ex) {
|
return false;
|
||||||
throw new RuntimeException(ex);
|
}
|
||||||
}
|
Assert.assertEquals(1, containerStatuses.size());
|
||||||
}
|
ContainerStatus status = containerStatuses.get(0);
|
||||||
}, 100, 10000);
|
return (status.getState() == expectedState
|
||||||
List<ContainerStatus> containerStatuses = containerManager
|
&& status.getExecutionType() == ExecutionType.OPPORTUNISTIC);
|
||||||
.getContainerStatuses(statRequest).getContainerStatuses();
|
}, 20, 10000);
|
||||||
Assert.assertEquals(1, containerStatuses.size());
|
|
||||||
for (ContainerStatus status : containerStatuses) {
|
|
||||||
Assert.assertEquals(
|
|
||||||
org.apache.hadoop.yarn.api.records.ContainerState.RUNNING,
|
|
||||||
status.getState());
|
|
||||||
Assert
|
|
||||||
.assertEquals(ExecutionType.OPPORTUNISTIC, status.getExecutionType());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue