Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,16 @@ import androidx.compose.ui.test.assertIsDisplayed
import androidx.compose.ui.test.junit4.createComposeRule
import androidx.compose.ui.test.onAllNodesWithTag
import androidx.compose.ui.test.onAllNodesWithText
import androidx.compose.ui.test.doubleClick
import androidx.compose.ui.test.onNodeWithTag
import androidx.compose.ui.test.onNodeWithText
import androidx.compose.ui.test.performClick
import androidx.compose.ui.test.performTouchInput
import com.lu4p.fokuslauncher.data.model.FavoriteApp
import com.lu4p.fokuslauncher.data.model.HomeShortcut
import com.lu4p.fokuslauncher.data.model.WeatherData
import com.lu4p.fokuslauncher.ui.theme.FokusLauncherTheme
import org.junit.Assert.assertFalse
import org.junit.Assert.assertTrue
import org.junit.Rule
import org.junit.Test
Expand Down Expand Up @@ -311,4 +314,80 @@ class HomeScreenTest {

assertTrue(bottomShortcut >= bottomFavorite - 1f)
}

@Test
fun homeScreen_doubleTapToLock_triggersCallback() {
var doubleTapTriggered = false
composeTestRule.setContent {
FokusLauncherTheme {
HomeScreenContent(
uiState = HomeUiState(doubleTapEmptyLockEnabled = true),
clockUiState = clock(),
weatherUiState = weatherOff,
favorites = testFavorites,
rightSideShortcuts = testRightSideShortcuts,
onLabelClick = {},
onLabelLongPress = {},
onIconClick = {},
onDoubleTapEmptyLock = { doubleTapTriggered = true }
)
}
}

composeTestRule.onNodeWithTag("home_screen").performTouchInput {
doubleClick()
}
assertTrue(doubleTapTriggered)
}

@Test
fun homeScreen_doubleTapToLockDisabled_doesNotTriggerCallback() {
var doubleTapTriggered = false
composeTestRule.setContent {
FokusLauncherTheme {
HomeScreenContent(
uiState = HomeUiState(doubleTapEmptyLockEnabled = false),
clockUiState = clock(),
weatherUiState = weatherOff,
favorites = testFavorites,
rightSideShortcuts = testRightSideShortcuts,
onLabelClick = {},
onLabelLongPress = {},
onIconClick = {},
onDoubleTapEmptyLock = { doubleTapTriggered = true }
)
}
}

composeTestRule.onNodeWithTag("home_screen").performTouchInput {
doubleClick()
}
assertFalse(doubleTapTriggered)
}

@Test
fun homeScreen_doubleTapOnFavorite_doesNotTriggerLock() {
var doubleTapTriggered = false
composeTestRule.setContent {
FokusLauncherTheme {
HomeScreenContent(
uiState = HomeUiState(doubleTapEmptyLockEnabled = true),
clockUiState = clock(),
weatherUiState = weatherOff,
favorites = testFavorites,
rightSideShortcuts = testRightSideShortcuts,
onLabelClick = {},
onLabelLongPress = {},
onIconClick = {},
onDoubleTapEmptyLock = { doubleTapTriggered = true }
)
}
}

composeTestRule.onNodeWithText("Music").performTouchInput {
doubleClick()
}

assertFalse("Double tap should not be triggered on favorite", doubleTapTriggered)
}
}
30 changes: 8 additions & 22 deletions app/src/main/java/com/lu4p/fokuslauncher/ui/home/HomeScreen.kt
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,13 @@ fun HomeScreenContent(
indication = null,
interactionSource = noIndication,
onClick = { },
onLongClick = onHomeScreenLongPress
onLongClick = onHomeScreenLongPress,
onDoubleClick = if (doubleTapEmptyLockEnabled) {
{
play()
onDoubleTapEmptyLock()
}
} else null
)
.testTag("home_screen")
) {
Expand All @@ -238,27 +244,7 @@ fun HomeScreenContent(
outlined = uiState.usesPhotoWallpaper,
)

// Push favorites to the bottom; optional double-tap to lock on this empty band
if (doubleTapEmptyLockEnabled) {
val emptyTapSource = remember { MutableInteractionSource() }
Box(
modifier =
Modifier.weight(1f)
.fillMaxWidth()
.combinedClickable(
indication = null,
interactionSource = emptyTapSource,
onClick = {},
onLongClick = onHomeScreenLongPress,
onDoubleClick = {
play()
onDoubleTapEmptyLock()
},
)
)
} else {
Spacer(modifier = Modifier.weight(1f))
}
Spacer(modifier = Modifier.weight(1f))

HomeFavoritesSection(
homeAlignment = uiState.homeAlignment,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,13 @@ import com.lu4p.fokuslauncher.data.model.appMetadataKey
import com.lu4p.fokuslauncher.data.repository.AppRepository
import com.lu4p.fokuslauncher.data.repository.RemovedApp
import com.lu4p.fokuslauncher.data.repository.WeatherRepository
import com.lu4p.fokuslauncher.utils.LockScreenHelper
import io.mockk.coEvery
import io.mockk.coVerify
import io.mockk.every
import io.mockk.mockk
import io.mockk.mockkObject
import io.mockk.unmockkObject
import io.mockk.verify
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
Expand Down Expand Up @@ -655,4 +658,19 @@ class HomeViewModelTest {

verify { appRepository.launchApp("com.lu4p.music") }
}

@Test
fun `onDoubleTapEmptyLock calls lockScreenIfPossible when enabled`() {
mockkObject(LockScreenHelper)
every { LockScreenHelper.isLockAccessibilityServiceEnabled(any()) } returns true
every { LockScreenHelper.lockScreenIfPossible() } returns true
every { preferencesManager.doubleTapEmptyLockFlow } returns flowOf(true)

val viewModel = createViewModel()
viewModel.onDoubleTapEmptyLock()
testDispatcher.scheduler.runCurrent()

verify { LockScreenHelper.lockScreenIfPossible() }
unmockkObject(LockScreenHelper)
}
}
Loading