Remove .orig file committed by mistake
This commit is contained in:
parent
37b060852c
commit
7403bcc809
|
@ -1,176 +0,0 @@
|
|||
//
|
||||
// TestDbBuilder.swift
|
||||
// ZcashLightClientKitTests
|
||||
//
|
||||
// Created by Francisco Gindre on 10/14/19.
|
||||
// Copyright © 2019 Electric Coin Company. All rights reserved.
|
||||
//
|
||||
|
||||
import Foundation
|
||||
import SQLite
|
||||
@testable import ZcashLightClientKit
|
||||
|
||||
struct TestDbHandle {
|
||||
var originalDb: URL
|
||||
var readWriteDb: URL
|
||||
|
||||
init(originalDb: URL) {
|
||||
self.originalDb = originalDb
|
||||
// avoid files clashing because crashing tests failed to remove previous ones by incrementally changing the filename
|
||||
self.readWriteDb = FileManager.default.temporaryDirectory
|
||||
.appendingPathComponent(
|
||||
self.originalDb.lastPathComponent.appending("_\(Date().timeIntervalSince1970)")
|
||||
)
|
||||
}
|
||||
|
||||
func setUp() throws {
|
||||
try FileManager.default.copyItem(at: originalDb, to: readWriteDb)
|
||||
}
|
||||
|
||||
func dispose() {
|
||||
try? FileManager.default.removeItem(at: readWriteDb)
|
||||
}
|
||||
|
||||
func connectionProvider(readwrite: Bool = true) -> ConnectionProvider {
|
||||
SimpleConnectionProvider(path: self.readWriteDb.absoluteString, readonly: !readwrite)
|
||||
}
|
||||
}
|
||||
|
||||
// This requires reference semantics, an enum cannot be used
|
||||
// swiftlint:disable:next convenience_type
|
||||
class TestDbBuilder {
|
||||
enum TestBuilderError: Error {
|
||||
case generalError
|
||||
}
|
||||
|
||||
static func inMemoryCompactBlockStorage() throws -> CompactBlockStorage {
|
||||
let compactBlockDao = CompactBlockStorage(connectionProvider: try InMemoryDbProvider())
|
||||
try compactBlockDao.createTable()
|
||||
|
||||
return compactBlockDao
|
||||
}
|
||||
|
||||
static func diskCompactBlockStorage(at url: URL) throws -> CompactBlockStorage {
|
||||
let compactBlockDao = CompactBlockStorage(connectionProvider: SimpleConnectionProvider(path: url.absoluteString))
|
||||
try compactBlockDao.createTable()
|
||||
|
||||
return compactBlockDao
|
||||
}
|
||||
|
||||
static func pendingTransactionsDbURL() throws -> URL {
|
||||
try __documentsDirectory().appendingPathComponent("pending.db")
|
||||
}
|
||||
|
||||
static func prePopulatedCacheDbURL() -> URL? {
|
||||
Bundle.module.url(forResource: "cache", withExtension: "db")
|
||||
}
|
||||
|
||||
static func prePopulatedDataDbURL() -> URL? {
|
||||
Bundle.module.url(forResource: "test_data", withExtension: "db")
|
||||
}
|
||||
<<<<<<< Updated upstream
|
||||
|
||||
static func prePopulatedMainnetDataDbURL() -> URL? {
|
||||
Bundle.module.url(forResource: "ZcashSdk_Data", withExtension: "db")
|
||||
}
|
||||
|
||||
static func prepopulatedDataDbProvider() throws -> ConnectionProvider? {
|
||||
guard let url = prePopulatedMainnetDataDbURL() else { return nil }
|
||||
let provider = SimpleConnectionProvider(path: url.absoluteString, readonly: true)
|
||||
let initResult = try ZcashRustBackend.initDataDb(dbData: url, seed: nil, networkType: NetworkType.testnet)
|
||||
=======
|
||||
|
||||
static func prePopulatedMainnetDataDbURL() -> URL? {
|
||||
Bundle.module.url(forResource: "darkside_data", withExtension: "db")
|
||||
}
|
||||
|
||||
static func prepopulatedDataDbProvider() throws -> ConnectionProvider? {
|
||||
guard let url = prePopulatedMainnetDataDbURL() else { return nil }
|
||||
|
||||
let provider = SimpleConnectionProvider(path: url.absoluteString, readonly: true)
|
||||
|
||||
let initResult = try ZcashRustBackend.initDataDb(
|
||||
dbData: url,
|
||||
seed: TestSeed().seed(),
|
||||
networkType: .mainnet
|
||||
)
|
||||
|
||||
>>>>>>> Stashed changes
|
||||
switch (initResult) {
|
||||
case .success: return provider
|
||||
case .seedRequired:
|
||||
throw StorageError.migrationFailedWithMessage(message: "Seed value required to initialize the wallet database")
|
||||
}
|
||||
}
|
||||
|
||||
static func transactionRepository() throws -> TransactionRepository? {
|
||||
guard let provider = try prepopulatedDataDbProvider() else { return nil }
|
||||
|
||||
return TransactionSQLDAO(dbProvider: provider)
|
||||
}
|
||||
|
||||
static func sentNotesRepository() throws -> SentNotesRepository? {
|
||||
guard let provider = try prepopulatedDataDbProvider() else { return nil }
|
||||
return SentNotesSQLDAO(dbProvider: provider)
|
||||
}
|
||||
|
||||
static func receivedNotesRepository() throws -> ReceivedNoteRepository? {
|
||||
guard let provider = try prepopulatedDataDbProvider() else { return nil }
|
||||
return ReceivedNotesSQLDAO(dbProvider: provider)
|
||||
}
|
||||
|
||||
static func seed(db: CompactBlockRepository, with blockRange: CompactBlockRange) async throws {
|
||||
guard let blocks = StubBlockCreator.createBlockRange(blockRange) else {
|
||||
throw TestBuilderError.generalError
|
||||
}
|
||||
|
||||
try await db.write(blocks: blocks)
|
||||
}
|
||||
}
|
||||
|
||||
struct InMemoryDbProvider: ConnectionProvider {
|
||||
var readonly: Bool
|
||||
var conn: Connection
|
||||
|
||||
init(readonly: Bool = false) throws {
|
||||
self.readonly = readonly
|
||||
self.conn = try Connection(.inMemory, readonly: readonly)
|
||||
}
|
||||
|
||||
func connection() throws -> Connection {
|
||||
self.conn
|
||||
}
|
||||
}
|
||||
|
||||
enum StubBlockCreator {
|
||||
static func createRandomDataBlock(with height: BlockHeight) -> ZcashCompactBlock? {
|
||||
guard let data = randomData(ofLength: 100) else {
|
||||
LoggerProxy.debug("error creating stub block")
|
||||
return nil
|
||||
}
|
||||
return ZcashCompactBlock(height: height, data: data)
|
||||
}
|
||||
|
||||
static func createBlockRange(_ range: CompactBlockRange) -> [ZcashCompactBlock]? {
|
||||
var blocks: [ZcashCompactBlock] = []
|
||||
for height in range {
|
||||
guard let block = createRandomDataBlock(with: height) else {
|
||||
return nil
|
||||
}
|
||||
blocks.append(block)
|
||||
}
|
||||
|
||||
return blocks
|
||||
}
|
||||
|
||||
static func randomData(ofLength length: Int) -> Data? {
|
||||
var bytes = [UInt8](repeating: 0, count: length)
|
||||
let status = SecRandomCopyBytes(kSecRandomDefault, length, &bytes)
|
||||
if status == errSecSuccess {
|
||||
return Data(bytes: &bytes, count: bytes.count)
|
||||
}
|
||||
LoggerProxy.debug("Status \(status)")
|
||||
|
||||
return nil
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue