YARN-7511. NPE in ContainerLocalizer when localization failed for running container. Contributed by Tao Yang

(cherry picked from commit 83798f15f8)
This commit is contained in:
Jason Lowe 2018-03-02 09:59:46 -06:00
parent 5db733fb09
commit 7c224656ce
2 changed files with 30 additions and 0 deletions

View File

@ -136,6 +136,10 @@ public class ResourceSet {
} }
public void resourceLocalizationFailed(LocalResourceRequest request) { public void resourceLocalizationFailed(LocalResourceRequest request) {
// Skip null request when localization failed for running container
if (request == null) {
return;
}
pendingResources.remove(request); pendingResources.remove(request);
resourcesFailedToBeLocalized.add(request); resourcesFailedToBeLocalized.add(request);
} }

View File

@ -378,6 +378,27 @@ public class TestContainer {
} }
} }
@Test
@SuppressWarnings("unchecked")
public void testLocalizationFailureWhileRunning()
throws Exception {
WrappedContainer wc = null;
try {
wc = new WrappedContainer(6, 314159265358979L, 4344, "yak");
wc.initContainer();
wc.localizeResources();
wc.launchContainer();
reset(wc.localizerBus);
assertEquals(ContainerState.RUNNING, wc.c.getContainerState());
// Now in RUNNING, handle ContainerResourceFailedEvent, cause NPE before
wc.handleContainerResourceFailedEvent();
} finally {
if (wc != null) {
wc.finished();
}
}
}
@Test @Test
@SuppressWarnings("unchecked") // mocked generic @SuppressWarnings("unchecked") // mocked generic
public void testCleanupOnKillRequest() throws Exception { public void testCleanupOnKillRequest() throws Exception {
@ -1132,6 +1153,11 @@ public class TestContainer {
drainDispatcherEvents(); drainDispatcherEvents();
} }
public void handleContainerResourceFailedEvent() {
c.handle(new ContainerResourceFailedEvent(cId, null, null));
drainDispatcherEvents();
}
// Localize resources // Localize resources
// Skip some resources so as to consider them failed // Skip some resources so as to consider them failed
public Map<Path, List<String>> doLocalizeResources( public Map<Path, List<String>> doLocalizeResources(