Merge "AOD: Fix WakeLock leak" into pi-dev
am: 888a82fdb3
Change-Id: I7c34e5f84dc66ea6373f80f2cf976cc07bcfec9a
This commit is contained in:
@@ -21,6 +21,7 @@ import android.util.Log;
|
||||
import android.view.Display;
|
||||
|
||||
import com.android.systemui.statusbar.phone.DozeParameters;
|
||||
import com.android.systemui.util.wakelock.SettableWakeLock;
|
||||
import com.android.systemui.util.wakelock.WakeLock;
|
||||
|
||||
/**
|
||||
@@ -43,15 +44,14 @@ public class DozeScreenState implements DozeMachine.Part {
|
||||
private final DozeParameters mParameters;
|
||||
|
||||
private int mPendingScreenState = Display.STATE_UNKNOWN;
|
||||
private boolean mWakeLockHeld;
|
||||
private WakeLock mWakeLock;
|
||||
private SettableWakeLock mWakeLock;
|
||||
|
||||
public DozeScreenState(DozeMachine.Service service, Handler handler,
|
||||
DozeParameters parameters, WakeLock wakeLock) {
|
||||
mDozeService = service;
|
||||
mHandler = handler;
|
||||
mParameters = parameters;
|
||||
mWakeLock = wakeLock;
|
||||
mWakeLock = new SettableWakeLock(wakeLock);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -64,6 +64,7 @@ public class DozeScreenState implements DozeMachine.Part {
|
||||
mHandler.removeCallbacks(mApplyPendingScreenState);
|
||||
|
||||
applyScreenState(screenState);
|
||||
mWakeLock.setAcquired(false);
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -84,9 +85,8 @@ public class DozeScreenState implements DozeMachine.Part {
|
||||
boolean shouldDelayTransition = newState == DozeMachine.State.DOZE_AOD
|
||||
&& mParameters.shouldControlScreenOff();
|
||||
|
||||
if (!mWakeLockHeld && shouldDelayTransition) {
|
||||
mWakeLockHeld = true;
|
||||
mWakeLock.acquire();
|
||||
if (shouldDelayTransition) {
|
||||
mWakeLock.setAcquired(true);
|
||||
}
|
||||
|
||||
if (!messagePending) {
|
||||
@@ -118,10 +118,7 @@ public class DozeScreenState implements DozeMachine.Part {
|
||||
if (DEBUG) Log.d(TAG, "setDozeScreenState(" + screenState + ")");
|
||||
mDozeService.setDozeScreenState(screenState);
|
||||
mPendingScreenState = Display.STATE_UNKNOWN;
|
||||
if (mWakeLockHeld) {
|
||||
mWakeLockHeld = false;
|
||||
mWakeLock.release();
|
||||
}
|
||||
mWakeLock.setAcquired(false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -25,8 +25,10 @@ import static com.android.systemui.doze.DozeMachine.State.INITIALIZED;
|
||||
import static com.android.systemui.doze.DozeMachine.State.UNINITIALIZED;
|
||||
import static com.android.systemui.utils.os.FakeHandler.Mode.QUEUEING;
|
||||
|
||||
import static org.hamcrest.Matchers.is;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertThat;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
import static org.mockito.Mockito.never;
|
||||
import static org.mockito.Mockito.reset;
|
||||
@@ -41,6 +43,7 @@ import android.view.Display;
|
||||
import com.android.systemui.SysuiTestCase;
|
||||
import com.android.systemui.statusbar.phone.DozeParameters;
|
||||
import com.android.systemui.util.wakelock.WakeLock;
|
||||
import com.android.systemui.util.wakelock.WakeLockFake;
|
||||
import com.android.systemui.utils.os.FakeHandler;
|
||||
|
||||
import org.junit.Before;
|
||||
@@ -58,8 +61,7 @@ public class DozeScreenStateTest extends SysuiTestCase {
|
||||
FakeHandler mHandlerFake;
|
||||
@Mock
|
||||
DozeParameters mDozeParameters;
|
||||
@Mock
|
||||
WakeLock mWakeLock;
|
||||
WakeLockFake mWakeLock;
|
||||
|
||||
@Before
|
||||
public void setUp() throws Exception {
|
||||
@@ -68,6 +70,7 @@ public class DozeScreenStateTest extends SysuiTestCase {
|
||||
when(mDozeParameters.getAlwaysOn()).thenReturn(true);
|
||||
mServiceFake = new DozeServiceFake();
|
||||
mHandlerFake = new FakeHandler(Looper.getMainLooper());
|
||||
mWakeLock = new WakeLockFake();
|
||||
mScreen = new DozeScreenState(mServiceFake, mHandlerFake, mDozeParameters, mWakeLock);
|
||||
}
|
||||
|
||||
@@ -158,14 +161,29 @@ public class DozeScreenStateTest extends SysuiTestCase {
|
||||
|
||||
mScreen.transitionTo(UNINITIALIZED, INITIALIZED);
|
||||
mHandlerFake.dispatchQueuedMessages();
|
||||
reset(mWakeLock);
|
||||
|
||||
mScreen.transitionTo(INITIALIZED, DOZE_AOD);
|
||||
verify(mWakeLock).acquire();
|
||||
verify(mWakeLock, never()).release();
|
||||
assertThat(mWakeLock.isHeld(), is(true));
|
||||
|
||||
mHandlerFake.dispatchQueuedMessages();
|
||||
verify(mWakeLock).release();
|
||||
assertThat(mWakeLock.isHeld(), is(false));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void test_releasesWakeLock_abortingLowPowerDelayed() {
|
||||
// Transition to low power mode will be delayed to let
|
||||
// animations play at 60 fps.
|
||||
when(mDozeParameters.shouldControlScreenOff()).thenReturn(true);
|
||||
mHandlerFake.setMode(QUEUEING);
|
||||
|
||||
mScreen.transitionTo(UNINITIALIZED, INITIALIZED);
|
||||
mHandlerFake.dispatchQueuedMessages();
|
||||
|
||||
mScreen.transitionTo(INITIALIZED, DOZE_AOD);
|
||||
assertThat(mWakeLock.isHeld(), is(true));
|
||||
mScreen.transitionTo(DOZE_AOD, FINISH);
|
||||
|
||||
assertThat(mWakeLock.isHeld(), is(false));
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user