LuceneBankingPersistence now only opens index directory for writing when persisting account transactions. Should fix exception that a second DocumentsWriter got instantiated on resume on Android
This commit is contained in:
parent
3f2a1fec95
commit
3829abe120
|
@ -104,7 +104,7 @@ class BankingModule(internal val mainActivity: AppCompatActivity) {
|
||||||
@Provides
|
@Provides
|
||||||
@Singleton
|
@Singleton
|
||||||
fun provideBankingPersistence(@Named(IndexFolderKey) indexFolder: File, @Named(DatabaseFolderKey) databaseFolder: File, serializer: ISerializer) : IBankingPersistence {
|
fun provideBankingPersistence(@Named(IndexFolderKey) indexFolder: File, @Named(DatabaseFolderKey) databaseFolder: File, serializer: ISerializer) : IBankingPersistence {
|
||||||
return LuceneBankingPersistence(databaseFolder, indexFolder, serializer)
|
return LuceneBankingPersistence(indexFolder, databaseFolder, serializer)
|
||||||
}
|
}
|
||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
|
|
|
@ -19,28 +19,21 @@ import net.dankito.utils.lucene.index.DocumentsWriter
|
||||||
import net.dankito.utils.lucene.index.FieldBuilder
|
import net.dankito.utils.lucene.index.FieldBuilder
|
||||||
import net.dankito.utils.serialization.ISerializer
|
import net.dankito.utils.serialization.ISerializer
|
||||||
import net.dankito.utils.serialization.JacksonJsonSerializer
|
import net.dankito.utils.serialization.JacksonJsonSerializer
|
||||||
import java.io.Closeable
|
|
||||||
import java.io.File
|
import java.io.File
|
||||||
|
|
||||||
|
|
||||||
open class LuceneBankingPersistence(
|
open class LuceneBankingPersistence(
|
||||||
|
protected val indexFolder: File,
|
||||||
databaseFolder: File,
|
databaseFolder: File,
|
||||||
indexFolder: File,
|
|
||||||
serializer: ISerializer = JacksonJsonSerializer()
|
serializer: ISerializer = JacksonJsonSerializer()
|
||||||
) : BankingPersistenceJson(File(databaseFolder, "accounts.json"), serializer), IBankingPersistence, Closeable {
|
) : BankingPersistenceJson(File(databaseFolder, "accounts.json"), serializer), IBankingPersistence {
|
||||||
|
|
||||||
|
|
||||||
protected val fields = FieldBuilder()
|
protected val fields = FieldBuilder()
|
||||||
|
|
||||||
protected val writer = DocumentsWriter(LuceneConfig.getAccountTransactionsIndexFolder(indexFolder))
|
|
||||||
|
|
||||||
|
|
||||||
override fun close() {
|
|
||||||
writer.close()
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
override fun saveOrUpdateAccountTransactions(bankAccount: BankAccount, transactions: List<AccountTransaction>) {
|
override fun saveOrUpdateAccountTransactions(bankAccount: BankAccount, transactions: List<AccountTransaction>) {
|
||||||
|
DocumentsWriter(LuceneConfig.getAccountTransactionsIndexFolder(indexFolder)).use { writer ->
|
||||||
transactions.forEach { transaction ->
|
transactions.forEach { transaction ->
|
||||||
writer.updateDocumentForNonNullFields(IdFieldName, transaction.id,
|
writer.updateDocumentForNonNullFields(IdFieldName, transaction.id,
|
||||||
fields.keywordField(BankAccountIdFieldName, bankAccount.id),
|
fields.keywordField(BankAccountIdFieldName, bankAccount.id),
|
||||||
|
@ -61,5 +54,6 @@ open class LuceneBankingPersistence(
|
||||||
|
|
||||||
writer.flushChangesToDisk()
|
writer.flushChangesToDisk()
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -45,7 +45,7 @@ class LuceneRemitteeSearcherTest {
|
||||||
|
|
||||||
private val fileUtils = FileUtils()
|
private val fileUtils = FileUtils()
|
||||||
|
|
||||||
private val bankingPersistence = LuceneBankingPersistence(databaseFolder, indexFolder)
|
private val bankingPersistence = LuceneBankingPersistence(indexFolder, databaseFolder)
|
||||||
|
|
||||||
private val underTest = LuceneRemitteeSearcher(indexFolder)
|
private val underTest = LuceneRemitteeSearcher(indexFolder)
|
||||||
|
|
||||||
|
@ -57,8 +57,6 @@ class LuceneRemitteeSearcherTest {
|
||||||
|
|
||||||
@After
|
@After
|
||||||
fun tearDown() {
|
fun tearDown() {
|
||||||
bankingPersistence.close()
|
|
||||||
|
|
||||||
clearDataFolder()
|
clearDataFolder()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue