YARN-7663. RMAppImpl:Invalid event: START at KILLED. Contributed by lujie

This commit is contained in:
Jason Lowe 2018-01-09 09:52:59 -06:00
parent b26e30ab16
commit ebff4decfe
2 changed files with 47 additions and 2 deletions

View File

@ -400,7 +400,7 @@ public class RMAppImpl implements RMApp, Recoverable {
EnumSet.of(RMAppEventType.APP_ACCEPTED, EnumSet.of(RMAppEventType.APP_ACCEPTED,
RMAppEventType.APP_REJECTED, RMAppEventType.KILL, RMAppEventType.APP_REJECTED, RMAppEventType.KILL,
RMAppEventType.ATTEMPT_FINISHED, RMAppEventType.ATTEMPT_FAILED, RMAppEventType.ATTEMPT_FINISHED, RMAppEventType.ATTEMPT_FAILED,
RMAppEventType.NODE_UPDATE)) RMAppEventType.NODE_UPDATE, RMAppEventType.START))
.installTopology(); .installTopology();
@ -894,7 +894,7 @@ public class RMAppImpl implements RMApp, Recoverable {
} catch (InvalidStateTransitionException e) { } catch (InvalidStateTransitionException e) {
LOG.error("App: " + appID LOG.error("App: " + appID
+ " can't handle this event at current state", e); + " can't handle this event at current state", e);
/* TODO fail the application on the failed transition */ onInvalidStateTransition(event.getType(), oldState);
} }
// Log at INFO if we're not recovering or not in a terminal state. // Log at INFO if we're not recovering or not in a terminal state.
@ -2048,4 +2048,14 @@ public class RMAppImpl implements RMApp, Recoverable {
public Map<String, String> getApplicationSchedulingEnvs() { public Map<String, String> getApplicationSchedulingEnvs() {
return this.applicationSchedulingEnvs; return this.applicationSchedulingEnvs;
} }
/**
* catch the InvalidStateTransition.
* @param state
* @param rmAppEventType
*/
protected void onInvalidStateTransition(RMAppEventType rmAppEventType,
RMAppState state){
/* TODO fail the application on the failed transition */
}
} }

View File

@ -1151,6 +1151,41 @@ public class TestRMAppTransitions {
verifyRMAppFieldsForFinalTransitions(application); verifyRMAppFieldsForFinalTransitions(application);
} }
@Test (timeout = 30000)
public void testAppStartAfterKilled() throws IOException {
LOG.info("--- START: testAppStartAfterKilled ---");
ApplicationId applicationId = MockApps.newAppID(appId++);
RMApp application = new RMAppImpl(applicationId, rmContext, conf, null,
null, null, new ApplicationSubmissionContextPBImpl(), null, null,
System.currentTimeMillis(), "YARN", null, null) {
@Override
protected void onInvalidStateTransition(RMAppEventType rmAppEventType,
RMAppState state) {
Assert.assertTrue("RMAppImpl: can't handle " + rmAppEventType
+ " at state " + state, false);
}
};
// NEW => KILLED event RMAppEventType.KILL
UserGroupInformation fooUser = UserGroupInformation.createUserForTesting(
"testAppStartAfterKilled", new String[] {"foo_group"});
RMAppEvent event = new RMAppKillByClientEvent(
applicationId, "Application killed by user.",
fooUser, Server.getRemoteIp());
application.handle(event);
rmDispatcher.await();
assertKilled(application);
// KILLED => KILLED event RMAppEventType.START
event = new RMAppFailedAttemptEvent(application.getApplicationId(),
RMAppEventType.START, "", false);
application.handle(event);
rmDispatcher.await();
assertTimesAtFinish(application);
assertAppState(RMAppState.KILLED, application);
}
@Test(timeout = 30000) @Test(timeout = 30000)
public void testAppsRecoveringStates() throws Exception { public void testAppsRecoveringStates() throws Exception {
RMState state = new RMState(); RMState state = new RMState();