use of com.android.internal.util.StateMachine.LogRec in project android_frameworks_base by ResurrectionRemix.
the class StateMachineTest method testStateMachineSharedThread.
@MediumTest
public void testStateMachineSharedThread() throws Exception {
if (DBG)
tlog("testStateMachineSharedThread E");
// Create and start the handler thread
HandlerThread smThread = new HandlerThread("testStateMachineSharedThread");
smThread.start();
// Create the state machines
StateMachineSharedThread[] sms = new StateMachineSharedThread[10];
for (int i = 0; i < sms.length; i++) {
sms[i] = new StateMachineSharedThread("smSharedThread", smThread.getLooper(), sms.length);
sms[i].start();
}
synchronized (waitObject) {
// Send messages to each of the state machines
for (StateMachineSharedThread sm : sms) {
for (int i = 1; i <= 4; i++) {
sm.sendMessage(i);
}
}
// Wait for the last state machine to notify its done
try {
waitObject.wait();
} catch (InterruptedException e) {
tloge("testStateMachineSharedThread: exception while waiting " + e.getMessage());
}
}
for (StateMachineSharedThread sm : sms) {
assertEquals(4, sm.getLogRecCount());
for (int i = 0; i < sm.getLogRecSize(); i++) {
LogRec lr = sm.getLogRec(i);
assertEquals(i + 1, lr.getWhat());
assertEquals(sm.mS1, lr.getState());
assertEquals(sm.mS1, lr.getOriginalState());
}
}
if (DBG)
tlog("testStateMachineSharedThread X");
}
use of com.android.internal.util.StateMachine.LogRec in project android_frameworks_base by ResurrectionRemix.
the class StateMachineTest method testStateMachine5.
@MediumTest
public void testStateMachine5() throws Exception {
StateMachine5 sm5 = new StateMachine5("sm5");
sm5.start();
if (sm5.isDbg())
tlog("testStateMachine5 E");
synchronized (sm5) {
// Send 6 messages
sm5.sendMessage(TEST_CMD_1);
sm5.sendMessage(TEST_CMD_2);
sm5.sendMessage(TEST_CMD_3);
sm5.sendMessage(TEST_CMD_4);
sm5.sendMessage(TEST_CMD_5);
sm5.sendMessage(TEST_CMD_6);
try {
// wait for the messages to be handled
sm5.wait();
} catch (InterruptedException e) {
tloge("testStateMachine5: exception while waiting " + e.getMessage());
}
}
assertEquals(6, sm5.getLogRecSize());
assertEquals(1, sm5.mParentState1EnterCount);
assertEquals(1, sm5.mParentState1ExitCount);
assertEquals(1, sm5.mChildState1EnterCount);
assertEquals(1, sm5.mChildState1ExitCount);
assertEquals(1, sm5.mChildState2EnterCount);
assertEquals(1, sm5.mChildState2ExitCount);
assertEquals(2, sm5.mParentState2EnterCount);
assertEquals(2, sm5.mParentState2ExitCount);
assertEquals(1, sm5.mChildState3EnterCount);
assertEquals(1, sm5.mChildState3ExitCount);
assertEquals(2, sm5.mChildState4EnterCount);
assertEquals(2, sm5.mChildState4ExitCount);
assertEquals(1, sm5.mChildState5EnterCount);
assertEquals(1, sm5.mChildState5ExitCount);
LogRec lr;
lr = sm5.getLogRec(0);
assertEquals(TEST_CMD_1, lr.getWhat());
assertEquals(sm5.mChildState1, lr.getState());
assertEquals(sm5.mChildState1, lr.getOriginalState());
lr = sm5.getLogRec(1);
assertEquals(TEST_CMD_2, lr.getWhat());
assertEquals(sm5.mChildState2, lr.getState());
assertEquals(sm5.mChildState2, lr.getOriginalState());
lr = sm5.getLogRec(2);
assertEquals(TEST_CMD_3, lr.getWhat());
assertEquals(sm5.mChildState5, lr.getState());
assertEquals(sm5.mChildState5, lr.getOriginalState());
lr = sm5.getLogRec(3);
assertEquals(TEST_CMD_4, lr.getWhat());
assertEquals(sm5.mChildState3, lr.getState());
assertEquals(sm5.mChildState3, lr.getOriginalState());
lr = sm5.getLogRec(4);
assertEquals(TEST_CMD_5, lr.getWhat());
assertEquals(sm5.mChildState4, lr.getState());
assertEquals(sm5.mChildState4, lr.getOriginalState());
lr = sm5.getLogRec(5);
assertEquals(TEST_CMD_6, lr.getWhat());
assertEquals(sm5.mParentState2, lr.getState());
assertEquals(sm5.mParentState2, lr.getOriginalState());
if (sm5.isDbg())
tlog("testStateMachine5 X");
}
use of com.android.internal.util.StateMachine.LogRec in project android_frameworks_base by ResurrectionRemix.
the class StateMachineTest method testStateMachine3.
@MediumTest
public void testStateMachine3() throws Exception {
StateMachine3 sm3 = new StateMachine3("sm3");
sm3.start();
if (sm3.isDbg())
tlog("testStateMachine3 E");
synchronized (sm3) {
// Send two messages
sm3.sendMessage(TEST_CMD_1);
sm3.sendMessage(TEST_CMD_2);
try {
// wait for the messages to be handled
sm3.wait();
} catch (InterruptedException e) {
tloge("testStateMachine3: exception while waiting " + e.getMessage());
}
}
assertEquals(2, sm3.getLogRecSize());
LogRec lr;
lr = sm3.getLogRec(0);
assertEquals(TEST_CMD_1, lr.getWhat());
assertEquals(sm3.mParentState, lr.getState());
assertEquals(sm3.mChildState, lr.getOriginalState());
lr = sm3.getLogRec(1);
assertEquals(TEST_CMD_2, lr.getWhat());
assertEquals(sm3.mParentState, lr.getState());
assertEquals(sm3.mChildState, lr.getOriginalState());
if (sm3.isDbg())
tlog("testStateMachine3 X");
}
use of com.android.internal.util.StateMachine.LogRec in project android_frameworks_base by DirtyUnicorns.
the class StateMachineTest method testStateMachine0.
@SmallTest
public void testStateMachine0() throws Exception {
//if (WAIT_FOR_DEBUGGER) Debug.waitForDebugger();
StateMachine0 sm0 = new StateMachine0("sm0");
sm0.start();
if (sm0.isDbg())
tlog("testStateMachine0 E");
synchronized (sm0) {
// Send 6 messages
for (int i = 1; i <= 6; i++) {
sm0.sendMessage(sm0.obtainMessage(i));
}
try {
// wait for the messages to be handled
sm0.wait();
} catch (InterruptedException e) {
tloge("testStateMachine0: exception while waiting " + e.getMessage());
}
}
assertEquals(6, sm0.getLogRecCount());
assertEquals(3, sm0.getLogRecSize());
dumpLogRecs(sm0);
LogRec lr;
lr = sm0.getLogRec(0);
assertEquals(TEST_CMD_4, lr.getWhat());
assertEquals(sm0.mS1, lr.getState());
assertEquals(sm0.mS1, lr.getOriginalState());
lr = sm0.getLogRec(1);
assertEquals(TEST_CMD_5, lr.getWhat());
assertEquals(sm0.mS1, lr.getState());
assertEquals(sm0.mS1, lr.getOriginalState());
lr = sm0.getLogRec(2);
assertEquals(TEST_CMD_6, lr.getWhat());
assertEquals(sm0.mS1, lr.getState());
assertEquals(sm0.mS1, lr.getOriginalState());
if (sm0.isDbg())
tlog("testStateMachine0 X");
}
use of com.android.internal.util.StateMachine.LogRec in project android_frameworks_base by DirtyUnicorns.
the class StateMachineTest method dumpLogRecs.
private void dumpLogRecs(Collection<LogRec> clr) {
int size = clr.size();
tlog("size=" + size);
for (LogRec lr : clr) {
tlog(lr.toString());
}
}
Aggregations