Signal-iOS/SignalServiceKit/tests/Storage/SSKSignedPreKeyStoreTest.swift
Jordan Rose 7448b377fb Parameterize the 1:1 stores by identity (ACI or PNI)
This allows two stores to coexist in the database. Note that
everything *using* the stores will still always use the ACI stores at
this point.
2022-03-16 14:31:06 -07:00

90 lines
3.9 KiB
Swift

//
// Copyright (c) 2022 Open Whisper Systems. All rights reserved.
//
import Foundation
import XCTest
@testable import SignalServiceKit
private extension SSKSignedPreKeyStore {
func loadSignedPreKey(_ id: Int32) -> SignedPreKeyRecord? {
return self.databaseStorage.read { transaction in
loadSignedPreKey(id, transaction: transaction)
}
}
var countSignedPreKeys: Int {
return self.databaseStorage.read { transaction in
loadSignedPreKeys(with: transaction).count
}
}
}
class SSKSignedPreKeyStoreTest: SSKBaseTestSwift {
func testPniStoreIsSeparate() {
let aciStore = signalProtocolStore(for: .aci).signedPreKeyStore
let pniStore = signalProtocolStore(for: .pni).signedPreKeyStore
XCTAssertEqual(0, aciStore.countSignedPreKeys)
XCTAssertEqual(0, pniStore.countSignedPreKeys)
let days: Int32 = 3
let lastPreKeyId = days
for i in 0...days { // 4 signed keys are generated, one per day from now until 3 days ago.
let secondsAgo = TimeInterval(i - days) * kDayInterval
assert(secondsAgo <= 0, "Time in past must be negative")
let generatedAt = Date(timeIntervalSinceNow: secondsAgo)
let record = SignedPreKeyRecord(id: i,
keyPair: Curve25519.generateKeyPair(),
signature: Data(),
generatedAt: generatedAt)
self.databaseStorage.write { transaction in
aciStore.storeSignedPreKey(i, signedPreKeyRecord: record, transaction: transaction)
}
}
XCTAssertEqual(4, aciStore.countSignedPreKeys)
XCTAssertNotNil(aciStore.loadSignedPreKey(lastPreKeyId))
for i in 0...days { // 4 signed keys are generated, one per day from now until 3 days ago.
let secondsAgo = TimeInterval(i - days) * kDayInterval
assert(secondsAgo <= 0, "Time in past must be negative")
let generatedAt = Date(timeIntervalSinceNow: secondsAgo)
let record = SignedPreKeyRecord(id: i,
keyPair: Curve25519.generateKeyPair(),
signature: Data(),
generatedAt: generatedAt)
self.databaseStorage.write { transaction in
pniStore.storeSignedPreKey(i, signedPreKeyRecord: record, transaction: transaction)
}
}
XCTAssertEqual(4, pniStore.countSignedPreKeys)
XCTAssertNotNil(pniStore.loadSignedPreKey(lastPreKeyId))
self.databaseStorage.write { transaction in
aciStore.removeSignedPreKey(lastPreKeyId, transaction: transaction)
}
XCTAssertNil(aciStore.loadSignedPreKey(lastPreKeyId))
XCTAssertNotNil(pniStore.loadSignedPreKey(lastPreKeyId))
}
func testGenerateWithCorrectSignature() {
let aciIdentity = identityManager.generateNewIdentityKey(for: .aci)
let aciStore = signalProtocolStore(for: .aci).signedPreKeyStore
let aciRecord = aciStore.generateRandomSignedRecord()
let aciPublicKey = aciIdentity.identityKeyPair.publicKey
XCTAssert(try! aciPublicKey.verifySignature(message: aciRecord.keyPair.identityKeyPair.publicKey.serialize(),
signature: aciRecord.signature))
let pniIdentity = identityManager.generateNewIdentityKey(for: .pni)
let pniStore = signalProtocolStore(for: .pni).signedPreKeyStore
let pniRecord = pniStore.generateRandomSignedRecord()
let pniPublicKey = pniIdentity.identityKeyPair.publicKey
XCTAssert(try! pniPublicKey.verifySignature(message: pniRecord.keyPair.identityKeyPair.publicKey.serialize(),
signature: pniRecord.signature))
}
}