Merge "Refactor ApnEditCarrierEnabled" into main

This commit is contained in:
Chaohui Wang
2024-06-19 05:21:24 +00:00
committed by Android (Google) Code Review
6 changed files with 153 additions and 63 deletions

View File

@@ -0,0 +1,109 @@
/*
* Copyright (C) 2024 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.settings.network.apn
import android.content.Context
import androidx.compose.runtime.CompositionLocalProvider
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.setValue
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.test.assertIsDisplayed
import androidx.compose.ui.test.assertIsEnabled
import androidx.compose.ui.test.assertIsNotEnabled
import androidx.compose.ui.test.assertIsOff
import androidx.compose.ui.test.assertIsOn
import androidx.compose.ui.test.junit4.ComposeTestRule
import androidx.compose.ui.test.junit4.createComposeRule
import androidx.compose.ui.test.onNodeWithText
import androidx.compose.ui.test.performClick
import androidx.test.core.app.ApplicationProvider
import androidx.test.ext.junit.runners.AndroidJUnit4
import com.android.settings.R
import org.junit.Before
import org.junit.Rule
import org.junit.Test
import org.junit.runner.RunWith
import org.mockito.kotlin.doReturn
import org.mockito.kotlin.spy
import org.mockito.kotlin.stub
@RunWith(AndroidJUnit4::class)
class ApnEditCarrierEnabledTest {
@get:Rule val composeTestRule = createComposeRule()
private val context: Context = spy(ApplicationProvider.getApplicationContext()) {}
private val resources = spy(context.resources) {}
@Before
fun setUp() {
context.stub { on { resources } doReturn resources }
}
@Test
fun carrierEnabled_displayed() {
composeTestRule.setContent { ApnEditCarrierEnabled(ApnData()) {} }
composeTestRule.onCarrierEnabled().assertIsDisplayed()
}
@Test
fun carrierEnabled_isChecked() {
val apnData = ApnData(carrierEnabled = true)
composeTestRule.setContent { ApnEditCarrierEnabled(apnData) {} }
composeTestRule.onCarrierEnabled().assertIsOn()
}
@Test
fun carrierEnabled_allowEdit_checkChanged() {
resources.stub { on { getBoolean(R.bool.config_allow_edit_carrier_enabled) } doReturn true }
var apnData by mutableStateOf(ApnData(carrierEnabled = true))
composeTestRule.setContent {
CompositionLocalProvider(LocalContext provides context) {
ApnEditCarrierEnabled(apnData) { apnData = apnData.copy(carrierEnabled = it) }
}
}
composeTestRule.onCarrierEnabled().performClick()
composeTestRule.onCarrierEnabled().assertIsEnabled().assertIsOff()
}
@Test
fun carrierEnabled_notAllowEdit_checkNotChanged() {
resources.stub {
on { getBoolean(R.bool.config_allow_edit_carrier_enabled) } doReturn false
}
var apnData by mutableStateOf(ApnData(carrierEnabled = true))
composeTestRule.setContent {
CompositionLocalProvider(LocalContext provides context) {
ApnEditCarrierEnabled(apnData) { apnData = apnData.copy(carrierEnabled = it) }
}
}
composeTestRule.onCarrierEnabled().performClick()
composeTestRule.onCarrierEnabled().assertIsNotEnabled().assertIsOn()
}
private fun ComposeTestRule.onCarrierEnabled() =
onNodeWithText(context.getString(R.string.carrier_enabled))
}

View File

@@ -21,24 +21,17 @@ import android.net.Uri
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.ui.test.assertIsDisplayed
import androidx.compose.ui.test.assertIsOff
import androidx.compose.ui.test.assertIsOn
import androidx.compose.ui.test.hasText
import androidx.compose.ui.test.isFocused
import androidx.compose.ui.test.junit4.createComposeRule
import androidx.compose.ui.test.onAllNodesWithText
import androidx.compose.ui.test.onChild
import androidx.compose.ui.test.onChildAt
import androidx.compose.ui.test.onLast
import androidx.compose.ui.test.onNodeWithText
import androidx.compose.ui.test.onRoot
import androidx.compose.ui.test.performClick
import androidx.compose.ui.test.performScrollToNode
import androidx.test.core.app.ApplicationProvider
import androidx.test.ext.junit.runners.AndroidJUnit4
import com.android.settings.R
import com.google.common.truth.Truth
import org.junit.Ignore
import org.junit.Rule
import org.junit.Test
import org.junit.runner.RunWith
@@ -55,7 +48,6 @@ class ApnEditPageProviderTest {
private val port = "port"
private val apnType = context.resources.getString(R.string.apn_type)
private val apnRoaming = "IPv4"
private val apnEnable = context.resources.getString(R.string.carrier_enabled)
private val apnProtocolOptions =
context.resources.getStringArray(R.array.apn_protocol_entries).toList()
private val passwordTitle = context.resources.getString(R.string.apn_password)
@@ -65,7 +57,6 @@ class ApnEditPageProviderTest {
port = port,
apnType = apnType,
apnRoaming = apnProtocolOptions.indexOf(apnRoaming),
apnEnable = true
)
private val apnData = mutableStateOf(
apnInit
@@ -133,39 +124,6 @@ class ApnEditPageProviderTest {
composeTestRule.onNodeWithText(apnRoaming, true).assertIsDisplayed()
}
@Ignore("b/342374681")
@Test
fun carrier_enabled_displayed() {
composeTestRule.setContent {
ApnPage(apnInit, remember { apnData }, uri)
}
composeTestRule.onRoot().onChild().onChildAt(0)
.performScrollToNode(hasText(apnEnable, true))
composeTestRule.onNodeWithText(apnEnable, true).assertIsDisplayed()
}
@Test
fun carrier_enabled_isChecked() {
composeTestRule.setContent {
ApnPage(apnInit, remember { apnData }, uri)
}
composeTestRule.onRoot().onChild().onChildAt(0)
.performScrollToNode(hasText(apnEnable, true))
composeTestRule.onNodeWithText(apnEnable, true).assertIsOn()
}
@Ignore("b/342374681")
@Test
fun carrier_enabled_checkChanged() {
composeTestRule.setContent {
ApnPage(apnInit, remember { apnData }, uri)
}
composeTestRule.onRoot().onChild().onChildAt(0)
.performScrollToNode(hasText(apnEnable, true))
composeTestRule.onNodeWithText(apnEnable, true).performClick()
composeTestRule.onNodeWithText(apnEnable, true).assertIsOff()
}
@Test
fun password_displayed() {
composeTestRule.setContent {