This commit is contained in:
parent
60c24fc75a
commit
a4636cc0c8
@ -5,12 +5,14 @@ import bou.amine.apps.readerforselfossv2.dao.ReaderForSelfossDB
|
||||
import bou.amine.apps.readerforselfossv2.model.SelfossModel
|
||||
import bou.amine.apps.readerforselfossv2.rest.SelfossApi
|
||||
import bou.amine.apps.readerforselfossv2.service.AppSettingsService
|
||||
import bou.amine.apps.readerforselfossv2.utils.ItemType
|
||||
import com.github.ln_12.library.ConnectivityStatus
|
||||
import io.mockk.*
|
||||
import kotlinx.coroutines.flow.MutableStateFlow
|
||||
import kotlinx.coroutines.runBlocking
|
||||
import kotlin.test.BeforeTest
|
||||
import kotlin.test.Test
|
||||
import kotlin.test.assertNotSame
|
||||
import kotlin.test.assertSame
|
||||
|
||||
class RepositoryTest() {
|
||||
@ -23,6 +25,7 @@ class RepositoryTest() {
|
||||
fun setup() {
|
||||
every { appSettingsService.getApiVersion() } returns 4
|
||||
every { appSettingsService.getBaseUrl() } returns "https://test.com/selfoss/"
|
||||
every { appSettingsService.isItemCachingEnabled() } returns false
|
||||
|
||||
every { connectivityStatus.isNetworkConnected } returns MutableStateFlow(true)
|
||||
|
||||
@ -52,6 +55,37 @@ class RepositoryTest() {
|
||||
val repository = Repository(api, appSettingsService, connectivityStatus, db)
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Get api 4 date with api 1 version stored`() {
|
||||
every { appSettingsService.getApiVersion() } returns 1
|
||||
coEvery { api.getItems(any(), any(), any(), any(), any(), any(), any()) } returns generateTestApiItem()
|
||||
every { appSettingsService.updateApiVersion(any()) } returns Unit
|
||||
|
||||
val repository = Repository(api, appSettingsService, connectivityStatus, db)
|
||||
runBlocking {
|
||||
repository.getNewerItems()
|
||||
}
|
||||
|
||||
assertSame(repository.items.size, 1)
|
||||
verify(exactly = 1) { appSettingsService.updateApiVersion(4) }
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Get api 1 date with api 4 version stored`() {
|
||||
every { appSettingsService.getApiVersion() } returns 4
|
||||
coEvery { api.version() } returns null
|
||||
val itemParameters = FakeItemParameters()
|
||||
itemParameters.datetime = "2021-04-23 11:45:32"
|
||||
coEvery { api.getItems(any(), any(), any(), any(), any(), any(), any()) } returns generateTestApiItem(itemParameters)
|
||||
|
||||
val repository = Repository(api, appSettingsService, connectivityStatus, db)
|
||||
runBlocking {
|
||||
repository.getNewerItems()
|
||||
}
|
||||
|
||||
assertSame(1, repository.items.size)
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Get newer items`() {
|
||||
coEvery { api.getItems(any(), any(), any(), any(), any(), any(), any()) } returns generateTestApiItem()
|
||||
@ -65,6 +99,98 @@ class RepositoryTest() {
|
||||
coVerify(exactly = 1) { api.getItems("unread", 0, null, null, null, null, any()) }
|
||||
verify(exactly = 0) { db.itemsQueries.items().executeAsList()}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Get all newer items`() {
|
||||
coEvery { api.getItems(any(), any(), any(), any(), any(), any(), any()) } returns generateTestApiItem()
|
||||
|
||||
val repository = Repository(api, appSettingsService, connectivityStatus, db)
|
||||
repository.displayedItems = ItemType.ALL
|
||||
runBlocking {
|
||||
repository.getNewerItems()
|
||||
}
|
||||
|
||||
assertSame(repository.items.size, 1)
|
||||
coVerify(exactly = 1) { api.getItems("all", 0, null, null, null, null, any()) }
|
||||
verify(exactly = 0) { db.itemsQueries.items().executeAsList()}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Get newer starred items`() {
|
||||
coEvery { api.getItems(any(), any(), any(), any(), any(), any(), any()) } returns generateTestApiItem()
|
||||
|
||||
val repository = Repository(api, appSettingsService, connectivityStatus, db)
|
||||
repository.displayedItems = ItemType.STARRED
|
||||
runBlocking {
|
||||
repository.getNewerItems()
|
||||
}
|
||||
|
||||
assertSame(repository.items.size, 1)
|
||||
coVerify(exactly = 1) { api.getItems("starred", 0, null, null, null, null, any()) }
|
||||
verify(exactly = 0) { db.itemsQueries.items().executeAsList()}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Get newer items without connectivity`() {
|
||||
every { connectivityStatus.isNetworkConnected } returns MutableStateFlow(false)
|
||||
every { appSettingsService.isItemCachingEnabled() } returns true
|
||||
|
||||
val repository = Repository(api, appSettingsService, connectivityStatus, db)
|
||||
runBlocking {
|
||||
repository.getNewerItems()
|
||||
}
|
||||
|
||||
assertSame(repository.items.size, 1)
|
||||
coVerify(exactly = 0) { api.getItems("unread", 0, null, null, null, null, any()) }
|
||||
verify(atLeast = 1) { db.itemsQueries.items().executeAsList()}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Get older items`() {
|
||||
coEvery { api.getItems(any(), any(), any(), any(), any(), any(), any()) } returns generateTestApiItem()
|
||||
|
||||
val repository = Repository(api, appSettingsService, connectivityStatus, db)
|
||||
repository.items = ArrayList(generateTestApiItem())
|
||||
runBlocking {
|
||||
repository.getOlderItems()
|
||||
}
|
||||
|
||||
assertSame(repository.items.size, 2)
|
||||
coVerify(exactly = 1) { api.getItems("unread", 1, null, null, null, null, any()) }
|
||||
verify(exactly = 0) { db.itemsQueries.items().executeAsList()}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Get all older items`() {
|
||||
coEvery { api.getItems(any(), any(), any(), any(), any(), any(), any()) } returns generateTestApiItem()
|
||||
|
||||
val repository = Repository(api, appSettingsService, connectivityStatus, db)
|
||||
repository.items = ArrayList(generateTestApiItem())
|
||||
repository.displayedItems = ItemType.ALL
|
||||
runBlocking {
|
||||
repository.getOlderItems()
|
||||
}
|
||||
|
||||
assertSame(repository.items.size, 2)
|
||||
coVerify(exactly = 1) { api.getItems("all", 1, null, null, null, null, any()) }
|
||||
verify(exactly = 0) { db.itemsQueries.items().executeAsList()}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Get older starred items`() {
|
||||
coEvery { api.getItems(any(), any(), any(), any(), any(), any(), any()) } returns generateTestApiItem()
|
||||
|
||||
val repository = Repository(api, appSettingsService, connectivityStatus, db)
|
||||
repository.displayedItems = ItemType.STARRED
|
||||
repository.items = ArrayList(generateTestApiItem())
|
||||
runBlocking {
|
||||
repository.getOlderItems()
|
||||
}
|
||||
|
||||
assertSame(repository.items.size, 2)
|
||||
coVerify(exactly = 1) { api.getItems("starred", 1, null, null, null, null, any()) }
|
||||
verify(exactly = 0) { db.itemsQueries.items().executeAsList()}
|
||||
}
|
||||
}
|
||||
|
||||
fun generateTestDBItems(item : FakeItemParameters = FakeItemParameters()) : List<ITEM> {
|
||||
@ -102,7 +228,7 @@ fun generateTestApiItem(item : FakeItemParameters = FakeItemParameters()) : List
|
||||
|
||||
class FakeItemParameters() {
|
||||
val id = "20"
|
||||
val datetime = "2022-09-09T03:32:01-04:00"
|
||||
var datetime = "2022-09-09T03:32:01-04:00"
|
||||
val title = "Etica della ricerca sotto i riflettori."
|
||||
val content = "<p><strong>Luigi Campanella, già Presidente SCI</strong></p>\n<p>L’etica della scienza è di certo ambito di cui continuiamo a scoprire nuovi aspetti e risvolti.</p>\n<p>L’ultimo è quello delle intelligenze artificiali capaci di creare opere complesse basate su immagini e parole memorizzate con il rischio di fake news e di contenuti disturbanti.</p>\n<p>Per evitare che ciò accada si sta procedendo filtrando secondo criteri di autocensura i dati da cui l’intelligenza artificiale parte.</p>\n<p>Comincia ad intravedersi un futuro prossimo di competizione fra autori umani ed artificiali nel quale sarà importante, quando i loro prodotti saranno indistinguibili, dichiararne l’origine.</p>\n<p>Come si comprende, si conferma che gli aspetti etici dell’innovazione e della ricerca si diversificato sempre di più.</p>\n<p>La biologia molecolare e la genetica già in passato hanno posto all’attenzione comune aspetti di etica della scienza che hanno indotto a nuove riflessioni circa i limiti delle ricerche.</p>\n<p>L’argomento, sempre attuale, torna sulle prime pagine a seguito della pubblicazione di una ricerca della Università di Cambridge che ha sviluppato una struttura cellulare di un topo con un cuore che batte regolarmente.</p>\n<img src=\"https://ilblogdellasci.files.wordpress.com/2022/09/image002-1.png?w=481\" alt=\"\" width=\"697\" height=\"430\" /><img src=\"https://ilblogdellasci.files.wordpress.com/2022/09/image003-1.png?w=906\" alt=\"\" /><p>Magdalena Zernicka-Goetz</p>\n<img src=\"https://ilblogdellasci.files.wordpress.com/2022/09/image004.jpg?w=474\" alt=\"\" width=\"622\" height=\"465\" /><p>Gianluca Amadei</p>\n<p>Del gruppo fa parte anche uno scienziato italiano Gianluca Amadei,che dinnanzi alle obiezioni di natura etica sulla realizzazione della vita artificiale si è affrettato a sostenere che non è creare nuove vite il fine primario della ricerca, ma quello di salvare quelle esistenti, di dare contributi essenziali alla medicina citando il caso del fallimento tuttora non interpretato di alcune gravidanze e di superare la sperimentazione animale, così contribuendo positivamente alla soluzione di un altro dilemma etico.</p>\n<p>L’embrione sintetico ha ovviamente come primo traguardo il contributo ai trapianti oggi drammaticamente carenti nell’offerta rispetto alla domanda, con attese fino a 4 anni per i trapianti di cuore ed a 2 anni per quelli di fegato. Il lavoro dovrebbe adesso continuare presso l’Ateneo di Padova per creare nuovi organi e nuovi farmaci.</p>"
|
||||
val unread = true
|
||||
|
Loading…
x
Reference in New Issue
Block a user