Skip to content

Commit

Permalink
TECH: pass SystemLanguage instance through Device class
Browse files Browse the repository at this point in the history
  • Loading branch information
Nikitae57 committed May 15, 2024
1 parent 40b6cdd commit 33393dc
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -18,4 +18,14 @@ interface Language {
*/
@MainThread
fun switchInApp(locale: Locale)

/**
* Changes locale for Android OS Settings.
* Under the hood grants CHANGE_CONFIGURATION permission
* (without this permission, it's impossible to change system language)
*
* @throws Throwable if something went wrong
*/
@MainThread
fun switchInSystem(locale: Locale)
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import android.os.LocaleList
import androidx.appcompat.app.AppCompatDelegate
import androidx.core.os.ConfigurationCompat
import androidx.core.os.LocaleListCompat
import com.kaspersky.kaspresso.docloc.SystemLanguage
import com.kaspersky.kaspresso.logger.UiTestLogger
import java.util.Locale

Expand All @@ -18,6 +19,7 @@ import java.util.Locale
class LanguageImpl(
private val logger: UiTestLogger,
private val instrumentation: Instrumentation,
private val systemLanguage: SystemLanguage,
) : Language {

override fun switchInApp(locale: Locale) {
Expand Down Expand Up @@ -45,6 +47,8 @@ class LanguageImpl(
}
}

override fun switchInSystem(locale: Locale) = systemLanguage.switch(locale)

private fun getCurrentLocale(): Locale? =
ConfigurationCompat.getLocales(instrumentation.targetContext.resources.configuration).get(0)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ import com.kaspersky.kaspresso.device.video.VideosImpl
import com.kaspersky.kaspresso.device.video.recorder.VideoRecorderImpl
import com.kaspersky.kaspresso.device.viewhierarchy.ViewHierarchyDumper
import com.kaspersky.kaspresso.device.viewhierarchy.ViewHierarchyDumperImpl
import com.kaspersky.kaspresso.docloc.SystemLanguage
import com.kaspersky.kaspresso.failure.LoggingFailureHandler
import com.kaspersky.kaspresso.files.dirs.DefaultDirsProvider
import com.kaspersky.kaspresso.files.dirs.DirsProvider
Expand Down Expand Up @@ -742,7 +743,10 @@ data class Kaspresso(
instrumentalDependencyProviderFactory.getComponentProvider<ExploitImpl>(instrumentation),
adbServer
)
if (!::language.isInitialized) language = LanguageImpl(libLogger, instrumentation)
if (!::language.isInitialized) {
val systemLanguage = SystemLanguage(instrumentation.targetContext, testLogger, hackPermissions)
language = LanguageImpl(libLogger, instrumentation, systemLanguage)
}
if (!::logcat.isInitialized) logcat = LogcatImpl(libLogger, adbServer)

if (!::flakySafetyParams.isInitialized) flakySafetyParams = FlakySafetyParams.default()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import androidx.test.rule.GrantPermissionRule
import com.kaspersky.kaspressample.MainActivity
import com.kaspersky.kaspressample.screen.ChangeLocaleScreen
import com.kaspersky.kaspressample.screen.MainScreen
import com.kaspersky.kaspresso.docloc.SystemLanguage
import com.kaspersky.kaspresso.testcases.api.testcase.TestCase
import org.junit.Rule
import org.junit.Test
Expand All @@ -24,20 +23,19 @@ class ChangeSystemLanguageMidTestCase : TestCase() {

@Test
fun checkLocaleChangeMidTest() = run {
val systemLanguage = SystemLanguage(device.targetContext, testLogger, device.hackPermissions)
step("Open change locale screen") {
MainScreen {
changeLocaleButton { click() }
}
}
step("Check EN locale text") {
systemLanguage.switch(Locale.ENGLISH)
device.language.switchInSystem(Locale.ENGLISH)
ChangeLocaleScreen {
text { containsText("123") }
}
}
step("Check RU locale text") {
systemLanguage.switch(Locale.forLanguageTag("RU"))
device.language.switchInSystem(Locale.forLanguageTag("RU"))
ChangeLocaleScreen {
text { containsText("321") }
}
Expand Down

0 comments on commit 33393dc

Please sign in to comment.