YARN-5354. TestDistributedShell.checkTimelineV2 fails randomly for concurrent tests. (Sangjin Lee via Varun Saxena).

This commit is contained in:
Varun Saxena 2016-07-12 20:41:52 +05:30
parent 819224dcf9
commit a3ac1c1943

View File

@ -83,7 +83,6 @@
import org.apache.hadoop.yarn.server.timelineservice.collector.PerNodeTimelineCollectorsAuxService; import org.apache.hadoop.yarn.server.timelineservice.collector.PerNodeTimelineCollectorsAuxService;
import org.apache.hadoop.yarn.server.timelineservice.storage.FileSystemTimelineWriterImpl; import org.apache.hadoop.yarn.server.timelineservice.storage.FileSystemTimelineWriterImpl;
import org.apache.hadoop.yarn.server.utils.BuilderUtils; import org.apache.hadoop.yarn.server.utils.BuilderUtils;
import org.apache.hadoop.yarn.util.ConverterUtils;
import org.apache.hadoop.yarn.util.LinuxResourceCalculatorPlugin; import org.apache.hadoop.yarn.util.LinuxResourceCalculatorPlugin;
import org.apache.hadoop.yarn.util.ProcfsBasedProcessTree; import org.apache.hadoop.yarn.util.ProcfsBasedProcessTree;
import org.apache.hadoop.yarn.util.timeline.TimelineUtils; import org.apache.hadoop.yarn.util.timeline.TimelineUtils;
@ -92,6 +91,7 @@
import org.junit.Before; import org.junit.Before;
import org.junit.Rule; import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import org.junit.rules.TemporaryFolder;
import org.junit.rules.Timeout; import org.junit.rules.Timeout;
public class TestDistributedShell { public class TestDistributedShell {
@ -104,6 +104,8 @@ public class TestDistributedShell {
private FileSystem fs = null; private FileSystem fs = null;
private TimelineWriter spyTimelineWriter; private TimelineWriter spyTimelineWriter;
protected YarnConfiguration conf = null; protected YarnConfiguration conf = null;
// location of the filesystem timeline writer for timeline service v.2
private String timelineV2StorageDir = null;
private static final int NUM_NMS = 1; private static final int NUM_NMS = 1;
private static final float DEFAULT_TIMELINE_VERSION = 1.0f; private static final float DEFAULT_TIMELINE_VERSION = 1.0f;
private static final String TIMELINE_AUX_SERVICE_NAME = "timeline_collector"; private static final String TIMELINE_AUX_SERVICE_NAME = "timeline_collector";
@ -116,6 +118,8 @@ public class TestDistributedShell {
= new TimelineVersionWatcher(); = new TimelineVersionWatcher();
@Rule @Rule
public Timeout globalTimeout = new Timeout(90000); public Timeout globalTimeout = new Timeout(90000);
@Rule
public TemporaryFolder tmpFolder = new TemporaryFolder();
@Before @Before
public void setup() throws Exception { public void setup() throws Exception {
@ -188,6 +192,10 @@ private void setupInternal(int numNodeManager, float timelineVersion)
FileSystemTimelineWriterImpl.class, FileSystemTimelineWriterImpl.class,
org.apache.hadoop.yarn.server.timelineservice.storage. org.apache.hadoop.yarn.server.timelineservice.storage.
TimelineWriter.class); TimelineWriter.class);
timelineV2StorageDir = tmpFolder.newFolder().getAbsolutePath();
// set the file system timeline writer storage directory
conf.set(FileSystemTimelineWriterImpl.TIMELINE_SERVICE_STORAGE_DIR_ROOT,
timelineV2StorageDir);
} else { } else {
Assert.fail("Wrong timeline version number: " + timelineVersion); Assert.fail("Wrong timeline version number: " + timelineVersion);
} }
@ -259,7 +267,7 @@ public void tearDown() throws IOException {
.get("yarn.timeline-service.leveldb-timeline-store.path")), .get("yarn.timeline-service.leveldb-timeline-store.path")),
true); true);
} }
@Test @Test
public void testDSShellWithDomain() throws Exception { public void testDSShellWithDomain() throws Exception {
testDSShell(true); testDSShell(true);
@ -489,22 +497,23 @@ private void checkTimelineV1(boolean haveDomain) throws Exception {
private void checkTimelineV2(boolean haveDomain, ApplicationId appId, private void checkTimelineV2(boolean haveDomain, ApplicationId appId,
boolean defaultFlow, ApplicationReport appReport) throws Exception { boolean defaultFlow, ApplicationReport appReport) throws Exception {
LOG.info("Started checkTimelineV2 "); LOG.info("Started checkTimelineV2 ");
// For PoC check in /tmp/timeline_service_data YARN-3264 // For PoC check using the file-based timeline writer (YARN-3264)
String tmpRoot = String tmpRoot = timelineV2StorageDir + File.separator + "entities" +
FileSystemTimelineWriterImpl.DEFAULT_TIMELINE_SERVICE_STORAGE_DIR_ROOT File.separator;
+ "/entities/";
File tmpRootFolder = new File(tmpRoot); File tmpRootFolder = new File(tmpRoot);
try { try {
Assert.assertTrue(tmpRootFolder.isDirectory()); Assert.assertTrue(tmpRootFolder.isDirectory());
String basePath = tmpRoot + String basePath = tmpRoot +
YarnConfiguration.DEFAULT_RM_CLUSTER_ID + "/" + YarnConfiguration.DEFAULT_RM_CLUSTER_ID + File.separator +
UserGroupInformation.getCurrentUser().getShortUserName() + UserGroupInformation.getCurrentUser().getShortUserName() +
(defaultFlow ? (defaultFlow ?
"/" + appReport.getName() + "/" + File.separator + appReport.getName() + File.separator +
TimelineUtils.DEFAULT_FLOW_VERSION +"/" + TimelineUtils.DEFAULT_FLOW_VERSION + File.separator +
appReport.getStartTime() +"/" : appReport.getStartTime() + File.separator :
"/test_flow_name/test_flow_version/12345678/") + File.separator + "test_flow_name" + File.separator +
"test_flow_version" + File.separator + "12345678" +
File.separator) +
appId.toString(); appId.toString();
LOG.info("basePath: " + basePath); LOG.info("basePath: " + basePath);
// for this test, we expect DS_APP_ATTEMPT AND DS_CONTAINER dirs // for this test, we expect DS_APP_ATTEMPT AND DS_CONTAINER dirs
@ -616,7 +625,8 @@ private void checkTimelineV2(boolean haveDomain, ApplicationId appId,
private File verifyEntityTypeFileExists(String basePath, String entityType, private File verifyEntityTypeFileExists(String basePath, String entityType,
String entityfileName) { String entityfileName) {
String outputDirPathForEntity = basePath + "/" + entityType + "/"; String outputDirPathForEntity =
basePath + File.separator + entityType + File.separator;
File outputDirForEntity = new File(outputDirPathForEntity); File outputDirForEntity = new File(outputDirPathForEntity);
Assert.assertTrue(outputDirForEntity.isDirectory()); Assert.assertTrue(outputDirForEntity.isDirectory());