mirror of
https://github.com/hmalik144/Weather-apps.git
synced 2025-12-10 02:05:20 +00:00
Instrumtation test fix (#36)
This commit is contained in:
@@ -92,8 +92,18 @@ open class BaseTest<A : Activity>(
|
|||||||
testApp.stubLocation(location, lat, long)
|
testApp.stubLocation(location, lat, long)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun clearLocation(location: String) {
|
||||||
|
testApp.removeLocation(location)
|
||||||
|
}
|
||||||
|
|
||||||
|
fun clearLocation(lat: Double, long: Double) {
|
||||||
|
testApp.removeLocation(lat, long)
|
||||||
|
}
|
||||||
|
|
||||||
fun clearPrefs() = prefs.clearPrefs()
|
fun clearPrefs() = prefs.clearPrefs()
|
||||||
|
|
||||||
|
fun clearDatabase() = testApp.clearDatabase()
|
||||||
|
|
||||||
fun getActivity() = testActivity
|
fun getActivity() = testActivity
|
||||||
|
|
||||||
@After
|
@After
|
||||||
|
|||||||
@@ -22,6 +22,16 @@ class MockLocationProvider : LocationProvider {
|
|||||||
|
|
||||||
fun addLocationToList(name: String, lat: Double, long: Double) {
|
fun addLocationToList(name: String, lat: Double, long: Double) {
|
||||||
val latLong = Pair(lat, long)
|
val latLong = Pair(lat, long)
|
||||||
feedMap.put(name, latLong)
|
feedMap[name] = latLong
|
||||||
|
}
|
||||||
|
|
||||||
|
fun removeLocationFromList(name: String) {
|
||||||
|
feedMap.remove(name)
|
||||||
|
}
|
||||||
|
|
||||||
|
fun removeLocationFromList(lat: Double, long: Double) {
|
||||||
|
feedMap.filterValues { it.first == lat && it.second == long }.keys.firstOrNull()?.let {
|
||||||
|
feedMap.remove(it)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -22,6 +22,13 @@ class SnapshotCaptureTest : BaseTest<MainActivity>(MainActivity::class.java) {
|
|||||||
clearPrefs()
|
clearPrefs()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun testFinished() {
|
||||||
|
super.testFinished()
|
||||||
|
clearLocation("London")
|
||||||
|
clearDatabase()
|
||||||
|
clearPrefs()
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun homeAndFurtherInfoPageCapture() {
|
fun homeAndFurtherInfoPageCapture() {
|
||||||
weatherScreen {
|
weatherScreen {
|
||||||
|
|||||||
@@ -14,9 +14,13 @@ import com.appttude.h_mal.atlas_weather.data.network.interceptors.QueryParamsInt
|
|||||||
import com.appttude.h_mal.atlas_weather.data.network.networkUtils.loggingInterceptor
|
import com.appttude.h_mal.atlas_weather.data.network.networkUtils.loggingInterceptor
|
||||||
import com.appttude.h_mal.atlas_weather.data.room.AppDatabase
|
import com.appttude.h_mal.atlas_weather.data.room.AppDatabase
|
||||||
import com.appttude.h_mal.atlas_weather.data.room.Converter
|
import com.appttude.h_mal.atlas_weather.data.room.Converter
|
||||||
|
import org.kodein.di.LazyKodein
|
||||||
import java.io.BufferedReader
|
import java.io.BufferedReader
|
||||||
|
|
||||||
class TestAppClass : MonoApp() {
|
class TestAppClass : AppClass() {
|
||||||
|
|
||||||
|
override val kodein: LazyKodein = super.kodein
|
||||||
|
|
||||||
private val idlingResources = CountingIdlingResource("Data_loader")
|
private val idlingResources = CountingIdlingResource("Data_loader")
|
||||||
private val mockingNetworkInterceptor = MockingNetworkInterceptor(idlingResources)
|
private val mockingNetworkInterceptor = MockingNetworkInterceptor(idlingResources)
|
||||||
|
|
||||||
@@ -64,4 +68,15 @@ class TestAppClass : MonoApp() {
|
|||||||
locationProvider.addLocationToList(location, lat, long)
|
locationProvider.addLocationToList(location, lat, long)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun removeLocation(location: String) {
|
||||||
|
locationProvider.removeLocationFromList(location)
|
||||||
|
}
|
||||||
|
|
||||||
|
fun removeLocation(lat: Double, long: Double) {
|
||||||
|
locationProvider.removeLocationFromList(lat, long)
|
||||||
|
}
|
||||||
|
|
||||||
|
fun clearDatabase() {
|
||||||
|
database.getWeatherDao().deleteAll()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -9,6 +9,7 @@ import com.appttude.h_mal.atlas_weather.utils.Stubs
|
|||||||
import com.appttude.h_mal.monoWeather.robot.furtherInfoScreen
|
import com.appttude.h_mal.monoWeather.robot.furtherInfoScreen
|
||||||
import com.appttude.h_mal.monoWeather.robot.settingsScreen
|
import com.appttude.h_mal.monoWeather.robot.settingsScreen
|
||||||
import com.appttude.h_mal.monoWeather.robot.weatherScreen
|
import com.appttude.h_mal.monoWeather.robot.weatherScreen
|
||||||
|
import org.junit.Ignore
|
||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
import tools.fastlane.screengrab.Screengrab
|
import tools.fastlane.screengrab.Screengrab
|
||||||
|
|
||||||
@@ -22,6 +23,12 @@ class SnapshotCaptureTest : BaseTest<MainActivity>(MainActivity::class.java) {
|
|||||||
clearPrefs()
|
clearPrefs()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun testFinished() {
|
||||||
|
super.testFinished()
|
||||||
|
clearLocation("London")
|
||||||
|
clearDatabase()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun homeAndFurtherInfoPageCapture() {
|
fun homeAndFurtherInfoPageCapture() {
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import com.appttude.h_mal.atlas_weather.utils.Stubs
|
|||||||
import com.appttude.h_mal.monoWeather.robot.furtherInfoScreen
|
import com.appttude.h_mal.monoWeather.robot.furtherInfoScreen
|
||||||
import com.appttude.h_mal.monoWeather.robot.settingsScreen
|
import com.appttude.h_mal.monoWeather.robot.settingsScreen
|
||||||
import com.appttude.h_mal.monoWeather.robot.weatherScreen
|
import com.appttude.h_mal.monoWeather.robot.weatherScreen
|
||||||
|
import okio.IOException
|
||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
import tools.fastlane.screengrab.Screengrab
|
import tools.fastlane.screengrab.Screengrab
|
||||||
|
|
||||||
@@ -40,7 +41,6 @@ class HomePageUITest : BaseTest<MainActivity>(MainActivity::class.java) {
|
|||||||
verifyMaxTemperature(12)
|
verifyMaxTemperature(12)
|
||||||
verifyAverageTemperature(9)
|
verifyAverageTemperature(9)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|||||||
@@ -0,0 +1,37 @@
|
|||||||
|
package com.appttude.h_mal.atlas_weather.application
|
||||||
|
|
||||||
|
|
||||||
|
import android.app.Application
|
||||||
|
import com.appttude.h_mal.atlas_weather.service.notification.NotificationHelper
|
||||||
|
import com.appttude.h_mal.atlas_weather.service.notification.NotificationService
|
||||||
|
import org.kodein.di.Kodein
|
||||||
|
import org.kodein.di.generic.bind
|
||||||
|
import org.kodein.di.generic.instance
|
||||||
|
import org.kodein.di.generic.provider
|
||||||
|
import org.kodein.di.generic.singleton
|
||||||
|
|
||||||
|
fun getFlavourModule(application: Application) = FlavourModule(application).build()
|
||||||
|
class FlavourModule(val application: Application) {
|
||||||
|
fun build() = Kodein.Module("Flavour") {
|
||||||
|
bind() from singleton {
|
||||||
|
NotificationHelper(
|
||||||
|
instance(),
|
||||||
|
instance(),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
bind() from singleton {
|
||||||
|
NotificationService(application)
|
||||||
|
}
|
||||||
|
|
||||||
|
bind() from provider {
|
||||||
|
ApplicationViewModelFactory(
|
||||||
|
application,
|
||||||
|
instance(),
|
||||||
|
instance(),
|
||||||
|
instance(),
|
||||||
|
instance()
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -15,16 +15,16 @@ import androidx.navigation.ui.onNavDestinationSelected
|
|||||||
import androidx.recyclerview.widget.RecyclerView
|
import androidx.recyclerview.widget.RecyclerView
|
||||||
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout
|
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout
|
||||||
import com.appttude.h_mal.atlas_weather.R
|
import com.appttude.h_mal.atlas_weather.R
|
||||||
import com.appttude.h_mal.atlas_weather.application.AtlasApp
|
|
||||||
import com.appttude.h_mal.atlas_weather.base.BaseFragment
|
import com.appttude.h_mal.atlas_weather.base.BaseFragment
|
||||||
import com.appttude.h_mal.atlas_weather.model.forecast.Forecast
|
import com.appttude.h_mal.atlas_weather.model.forecast.Forecast
|
||||||
import com.appttude.h_mal.atlas_weather.model.forecast.WeatherDisplay
|
import com.appttude.h_mal.atlas_weather.model.forecast.WeatherDisplay
|
||||||
|
import com.appttude.h_mal.atlas_weather.service.notification.NotificationService
|
||||||
import com.appttude.h_mal.atlas_weather.ui.dialog.PermissionsDeclarationDialog
|
import com.appttude.h_mal.atlas_weather.ui.dialog.PermissionsDeclarationDialog
|
||||||
import com.appttude.h_mal.atlas_weather.ui.home.adapter.WeatherRecyclerAdapter
|
import com.appttude.h_mal.atlas_weather.ui.home.adapter.WeatherRecyclerAdapter
|
||||||
import com.appttude.h_mal.atlas_weather.utils.displayToast
|
import com.appttude.h_mal.atlas_weather.utils.displayToast
|
||||||
import com.appttude.h_mal.atlas_weather.utils.navigateTo
|
import com.appttude.h_mal.atlas_weather.utils.navigateTo
|
||||||
import com.appttude.h_mal.atlas_weather.viewmodel.MainViewModel
|
import com.appttude.h_mal.atlas_weather.viewmodel.MainViewModel
|
||||||
|
import org.kodein.di.generic.instance
|
||||||
import permissions.dispatcher.NeedsPermission
|
import permissions.dispatcher.NeedsPermission
|
||||||
import permissions.dispatcher.OnNeverAskAgain
|
import permissions.dispatcher.OnNeverAskAgain
|
||||||
import permissions.dispatcher.OnPermissionDenied
|
import permissions.dispatcher.OnPermissionDenied
|
||||||
@@ -40,6 +40,8 @@ import permissions.dispatcher.RuntimePermissions
|
|||||||
@RuntimePermissions
|
@RuntimePermissions
|
||||||
class HomeFragment : BaseFragment<MainViewModel>(R.layout.fragment_home) {
|
class HomeFragment : BaseFragment<MainViewModel>(R.layout.fragment_home) {
|
||||||
|
|
||||||
|
private val notificationService by instance<NotificationService>()
|
||||||
|
|
||||||
private lateinit var recyclerAdapter: WeatherRecyclerAdapter
|
private lateinit var recyclerAdapter: WeatherRecyclerAdapter
|
||||||
private lateinit var swipeRefresh: SwipeRefreshLayout
|
private lateinit var swipeRefresh: SwipeRefreshLayout
|
||||||
|
|
||||||
@@ -100,7 +102,11 @@ class HomeFragment : BaseFragment<MainViewModel>(R.layout.fragment_home) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Deprecated("Deprecated in Java")
|
@Deprecated("Deprecated in Java")
|
||||||
override fun onRequestPermissionsResult(requestCode: Int, permissions: Array<String>, grantResults: IntArray) {
|
override fun onRequestPermissionsResult(
|
||||||
|
requestCode: Int,
|
||||||
|
permissions: Array<String>,
|
||||||
|
grantResults: IntArray
|
||||||
|
) {
|
||||||
super.onRequestPermissionsResult(requestCode, permissions, grantResults)
|
super.onRequestPermissionsResult(requestCode, permissions, grantResults)
|
||||||
// NOTE: delegate the permission handling to generated method
|
// NOTE: delegate the permission handling to generated method
|
||||||
onRequestPermissionsResult(requestCode, grantResults)
|
onRequestPermissionsResult(requestCode, grantResults)
|
||||||
@@ -110,7 +116,7 @@ class HomeFragment : BaseFragment<MainViewModel>(R.layout.fragment_home) {
|
|||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.TIRAMISU) {
|
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.TIRAMISU) {
|
||||||
sendNotification()
|
sendNotification()
|
||||||
} else {
|
} else {
|
||||||
(requireActivity().application as AtlasApp).scheduleNotifications()
|
notificationService.schedulePushNotifications()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -142,7 +148,7 @@ class HomeFragment : BaseFragment<MainViewModel>(R.layout.fragment_home) {
|
|||||||
@SuppressLint("MissingPermission")
|
@SuppressLint("MissingPermission")
|
||||||
@NeedsPermission(POST_NOTIFICATIONS)
|
@NeedsPermission(POST_NOTIFICATIONS)
|
||||||
fun sendNotification() {
|
fun sendNotification() {
|
||||||
(requireActivity().application as AtlasApp).scheduleNotifications()
|
notificationService.schedulePushNotifications()
|
||||||
}
|
}
|
||||||
|
|
||||||
@OnShowRationale(POST_NOTIFICATIONS)
|
@OnShowRationale(POST_NOTIFICATIONS)
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ import com.appttude.h_mal.atlas_weather.helper.ServicesHelper
|
|||||||
import com.google.gson.Gson
|
import com.google.gson.Gson
|
||||||
import org.kodein.di.Kodein
|
import org.kodein.di.Kodein
|
||||||
import org.kodein.di.KodeinAware
|
import org.kodein.di.KodeinAware
|
||||||
|
import org.kodein.di.KodeinContainer
|
||||||
import org.kodein.di.android.x.androidXModule
|
import org.kodein.di.android.x.androidXModule
|
||||||
import org.kodein.di.generic.bind
|
import org.kodein.di.generic.bind
|
||||||
import org.kodein.di.generic.instance
|
import org.kodein.di.generic.instance
|
||||||
@@ -22,7 +23,7 @@ abstract class BaseAppClass : Application(), KodeinAware {
|
|||||||
// Kodein aware to initialise the classes used for DI
|
// Kodein aware to initialise the classes used for DI
|
||||||
override val kodein = Kodein.lazy {
|
override val kodein = Kodein.lazy {
|
||||||
import(parentModule)
|
import(parentModule)
|
||||||
import(flavourModule)
|
import(getFlavourModule(application = this@BaseAppClass))
|
||||||
}
|
}
|
||||||
|
|
||||||
val parentModule = Kodein.Module("Parent Module", allowSilentOverride = true) {
|
val parentModule = Kodein.Module("Parent Module", allowSilentOverride = true) {
|
||||||
@@ -40,10 +41,6 @@ abstract class BaseAppClass : Application(), KodeinAware {
|
|||||||
bind() from singleton { WeatherSource(instance(), instance()) }
|
bind() from singleton { WeatherSource(instance(), instance()) }
|
||||||
}
|
}
|
||||||
|
|
||||||
open val flavourModule = Kodein.Module("Flavour") {
|
|
||||||
import(parentModule)
|
|
||||||
}
|
|
||||||
|
|
||||||
abstract fun createNetworkModule(): WeatherApi
|
abstract fun createNetworkModule(): WeatherApi
|
||||||
abstract fun createLocationModule(): LocationProvider
|
abstract fun createLocationModule(): LocationProvider
|
||||||
abstract fun createRoomDatabase(): AppDatabase
|
abstract fun createRoomDatabase(): AppDatabase
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
package com.appttude.h_mal.atlas_weather.data.room
|
package com.appttude.h_mal.atlas_weather.data.room
|
||||||
|
|
||||||
|
import androidx.annotation.VisibleForTesting
|
||||||
import androidx.lifecycle.LiveData
|
import androidx.lifecycle.LiveData
|
||||||
import androidx.room.Dao
|
import androidx.room.Dao
|
||||||
|
import androidx.room.Delete
|
||||||
import androidx.room.Insert
|
import androidx.room.Insert
|
||||||
import androidx.room.OnConflictStrategy
|
import androidx.room.OnConflictStrategy
|
||||||
import androidx.room.Query
|
import androidx.room.Query
|
||||||
@@ -32,4 +34,7 @@ interface WeatherDao {
|
|||||||
@Query("DELETE FROM EntityItem WHERE id = :userId")
|
@Query("DELETE FROM EntityItem WHERE id = :userId")
|
||||||
fun deleteEntry(userId: String): Int
|
fun deleteEntry(userId: String): Int
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
@Query("DELETE FROM EntityItem")
|
||||||
|
fun deleteAll(): Int
|
||||||
}
|
}
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
package com.appttude.h_mal.atlas_weather.application
|
||||||
|
|
||||||
|
|
||||||
|
import android.app.Application
|
||||||
|
import org.kodein.di.Kodein
|
||||||
|
import org.kodein.di.generic.bind
|
||||||
|
import org.kodein.di.generic.instance
|
||||||
|
import org.kodein.di.generic.provider
|
||||||
|
|
||||||
|
fun getFlavourModule(application: Application) = FlavourModule(application).build()
|
||||||
|
class FlavourModule(val application: Application) {
|
||||||
|
fun build() = Kodein.Module("Flavour") {
|
||||||
|
bind() from provider {
|
||||||
|
ApplicationViewModelFactory(
|
||||||
|
application,
|
||||||
|
instance(),
|
||||||
|
instance(),
|
||||||
|
instance(),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user