[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