[fenix] No issue: Refactor errors to risk level conversion. (https://github.com/mozilla-mobile/fenix/pull/5710)
parent
506fdc79a8
commit
aa2d47a591
@ -0,0 +1,112 @@
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
package org.mozilla.fenix
|
||||
|
||||
import androidx.annotation.RawRes
|
||||
import assertk.assertThat
|
||||
import assertk.assertions.isEqualTo
|
||||
import io.mockk.mockk
|
||||
import kotlinx.coroutines.ObsoleteCoroutinesApi
|
||||
import mozilla.components.browser.errorpages.ErrorPages
|
||||
import mozilla.components.browser.errorpages.ErrorType
|
||||
import mozilla.components.concept.engine.request.RequestInterceptor
|
||||
import mozilla.components.support.test.robolectric.testContext
|
||||
import org.junit.Before
|
||||
import org.junit.Test
|
||||
import org.junit.runner.RunWith
|
||||
import org.robolectric.RobolectricTestRunner
|
||||
import org.robolectric.annotation.Config
|
||||
|
||||
@UseExperimental(ObsoleteCoroutinesApi::class)
|
||||
@RunWith(RobolectricTestRunner::class)
|
||||
@Config(application = TestApplication::class)
|
||||
class AppRequestInterceptorTest {
|
||||
|
||||
private lateinit var interceptor: RequestInterceptor
|
||||
|
||||
@Before
|
||||
fun setUp() {
|
||||
interceptor = AppRequestInterceptor(testContext)
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `onErrorRequest results in correct error page for low risk level error`() {
|
||||
setOf(
|
||||
ErrorType.UNKNOWN,
|
||||
ErrorType.ERROR_NET_INTERRUPT,
|
||||
ErrorType.ERROR_NET_TIMEOUT,
|
||||
ErrorType.ERROR_CONNECTION_REFUSED,
|
||||
ErrorType.ERROR_UNKNOWN_SOCKET_TYPE,
|
||||
ErrorType.ERROR_REDIRECT_LOOP,
|
||||
ErrorType.ERROR_OFFLINE,
|
||||
ErrorType.ERROR_NET_RESET,
|
||||
ErrorType.ERROR_UNSAFE_CONTENT_TYPE,
|
||||
ErrorType.ERROR_CORRUPTED_CONTENT,
|
||||
ErrorType.ERROR_CONTENT_CRASHED,
|
||||
ErrorType.ERROR_INVALID_CONTENT_ENCODING,
|
||||
ErrorType.ERROR_UNKNOWN_HOST,
|
||||
ErrorType.ERROR_MALFORMED_URI,
|
||||
ErrorType.ERROR_FILE_NOT_FOUND,
|
||||
ErrorType.ERROR_FILE_ACCESS_DENIED,
|
||||
ErrorType.ERROR_PROXY_CONNECTION_REFUSED,
|
||||
ErrorType.ERROR_UNKNOWN_PROXY_HOST,
|
||||
ErrorType.ERROR_UNKNOWN_PROTOCOL
|
||||
).forEach { error ->
|
||||
val actualPage = createActualErrorPage(error)
|
||||
val expectedPage = createExpectedErrorPage(
|
||||
error = error,
|
||||
html = R.raw.low_risk_error_pages,
|
||||
css = R.raw.low_and_medium_risk_error_style
|
||||
)
|
||||
|
||||
assertThat(actualPage).isEqualTo(expectedPage)
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `onErrorRequest results in correct error page for medium risk level error`() {
|
||||
setOf(
|
||||
ErrorType.ERROR_SECURITY_BAD_CERT,
|
||||
ErrorType.ERROR_SECURITY_SSL,
|
||||
ErrorType.ERROR_PORT_BLOCKED
|
||||
).forEach { error ->
|
||||
val actualPage = createActualErrorPage(error)
|
||||
val expectedPage = createExpectedErrorPage(
|
||||
error = error,
|
||||
html = R.raw.medium_and_high_risk_error_pages,
|
||||
css = R.raw.low_and_medium_risk_error_style
|
||||
)
|
||||
|
||||
assertThat(actualPage).isEqualTo(expectedPage)
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `onErrorRequest results in correct error page for high risk level error`() {
|
||||
setOf(
|
||||
ErrorType.ERROR_SAFEBROWSING_HARMFUL_URI,
|
||||
ErrorType.ERROR_SAFEBROWSING_MALWARE_URI,
|
||||
ErrorType.ERROR_SAFEBROWSING_PHISHING_URI,
|
||||
ErrorType.ERROR_SAFEBROWSING_UNWANTED_URI
|
||||
).forEach { error ->
|
||||
val actualPage = createActualErrorPage(error)
|
||||
val expectedPage = createExpectedErrorPage(
|
||||
error = error,
|
||||
html = R.raw.medium_and_high_risk_error_pages,
|
||||
css = R.raw.high_risk_error_style
|
||||
)
|
||||
|
||||
assertThat(actualPage).isEqualTo(expectedPage)
|
||||
}
|
||||
}
|
||||
|
||||
private fun createActualErrorPage(error: ErrorType): String {
|
||||
return interceptor.onErrorRequest(session = mockk(), errorType = error, uri = null)?.data!!
|
||||
}
|
||||
|
||||
private fun createExpectedErrorPage(error: ErrorType, @RawRes html: Int, @RawRes css: Int): String {
|
||||
return ErrorPages.createErrorPage(testContext, error, null, html, css)
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue