fix test post rebase
This commit is contained in:
parent
59afe434f8
commit
b4f7e1381d
@ -18,7 +18,6 @@ package org.matrix.android.sdk.internal.crypto.crosssigning
|
|||||||
|
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4
|
import androidx.test.ext.junit.runners.AndroidJUnit4
|
||||||
import androidx.test.filters.LargeTest
|
import androidx.test.filters.LargeTest
|
||||||
import org.amshove.kluent.shouldBeEqualTo
|
|
||||||
import org.junit.Assert.assertEquals
|
import org.junit.Assert.assertEquals
|
||||||
import org.junit.Assert.assertFalse
|
import org.junit.Assert.assertFalse
|
||||||
import org.junit.Assert.assertNotNull
|
import org.junit.Assert.assertNotNull
|
||||||
@ -34,7 +33,6 @@ import org.matrix.android.sdk.api.auth.UIABaseAuth
|
|||||||
import org.matrix.android.sdk.api.auth.UserInteractiveAuthInterceptor
|
import org.matrix.android.sdk.api.auth.UserInteractiveAuthInterceptor
|
||||||
import org.matrix.android.sdk.api.auth.UserPasswordAuth
|
import org.matrix.android.sdk.api.auth.UserPasswordAuth
|
||||||
import org.matrix.android.sdk.api.auth.registration.RegistrationFlowResponse
|
import org.matrix.android.sdk.api.auth.registration.RegistrationFlowResponse
|
||||||
import org.matrix.android.sdk.api.session.crypto.crosssigning.UserTrustResult
|
|
||||||
import org.matrix.android.sdk.api.session.crypto.crosssigning.isCrossSignedVerified
|
import org.matrix.android.sdk.api.session.crypto.crosssigning.isCrossSignedVerified
|
||||||
import org.matrix.android.sdk.api.session.crypto.crosssigning.isVerified
|
import org.matrix.android.sdk.api.session.crypto.crosssigning.isVerified
|
||||||
import org.matrix.android.sdk.api.session.crypto.model.CryptoDeviceInfo
|
import org.matrix.android.sdk.api.session.crypto.model.CryptoDeviceInfo
|
||||||
@ -43,6 +41,7 @@ import org.matrix.android.sdk.common.CommonTestHelper.Companion.runCryptoTest
|
|||||||
import org.matrix.android.sdk.common.CommonTestHelper.Companion.runSessionTest
|
import org.matrix.android.sdk.common.CommonTestHelper.Companion.runSessionTest
|
||||||
import org.matrix.android.sdk.common.SessionTestParams
|
import org.matrix.android.sdk.common.SessionTestParams
|
||||||
import org.matrix.android.sdk.common.TestConstants
|
import org.matrix.android.sdk.common.TestConstants
|
||||||
|
import timber.log.Timber
|
||||||
import kotlin.coroutines.Continuation
|
import kotlin.coroutines.Continuation
|
||||||
import kotlin.coroutines.resume
|
import kotlin.coroutines.resume
|
||||||
|
|
||||||
@ -231,14 +230,14 @@ class XSigningTest : InstrumentedTest {
|
|||||||
password = TestConstants.PASSWORD
|
password = TestConstants.PASSWORD
|
||||||
)
|
)
|
||||||
|
|
||||||
testHelper.doSync<Unit> {
|
testHelper.waitForCallback<Unit> {
|
||||||
aliceSession.cryptoService().crossSigningService().initializeCrossSigning(object : UserInteractiveAuthInterceptor {
|
aliceSession.cryptoService().crossSigningService().initializeCrossSigning(object : UserInteractiveAuthInterceptor {
|
||||||
override fun performStage(flowResponse: RegistrationFlowResponse, errCode: String?, promise: Continuation<UIABaseAuth>) {
|
override fun performStage(flowResponse: RegistrationFlowResponse, errCode: String?, promise: Continuation<UIABaseAuth>) {
|
||||||
promise.resume(aliceAuthParams)
|
promise.resume(aliceAuthParams)
|
||||||
}
|
}
|
||||||
}, it)
|
}, it)
|
||||||
}
|
}
|
||||||
testHelper.doSync<Unit> {
|
testHelper.waitForCallback<Unit> {
|
||||||
bobSession.cryptoService().crossSigningService().initializeCrossSigning(object : UserInteractiveAuthInterceptor {
|
bobSession.cryptoService().crossSigningService().initializeCrossSigning(object : UserInteractiveAuthInterceptor {
|
||||||
override fun performStage(flowResponse: RegistrationFlowResponse, errCode: String?, promise: Continuation<UIABaseAuth>) {
|
override fun performStage(flowResponse: RegistrationFlowResponse, errCode: String?, promise: Continuation<UIABaseAuth>) {
|
||||||
promise.resume(bobAuthParams)
|
promise.resume(bobAuthParams)
|
||||||
@ -248,26 +247,27 @@ class XSigningTest : InstrumentedTest {
|
|||||||
|
|
||||||
cryptoTestHelper.verifySASCrossSign(aliceSession, bobSession, cryptoTestData.roomId)
|
cryptoTestHelper.verifySASCrossSign(aliceSession, bobSession, cryptoTestData.roomId)
|
||||||
|
|
||||||
testHelper.waitWithLatch {
|
testHelper.retryPeriodically {
|
||||||
testHelper.retryPeriodicallyWithLatch(it) {
|
aliceSession.cryptoService().crossSigningService().isUserTrusted(bobSession.myUserId)
|
||||||
aliceSession.cryptoService().crossSigningService().isUserTrusted(bobSession.myUserId)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
aliceSession.cryptoService().crossSigningService().checkUserTrust(bobSession.myUserId).let {
|
testHelper.retryPeriodically {
|
||||||
assertTrue(it is UserTrustResult.Success)
|
aliceSession.cryptoService().crossSigningService().checkUserTrust(bobSession.myUserId).isVerified()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
aliceSession.cryptoService()
|
||||||
// Ensure also that bob device is trusted
|
// Ensure also that bob device is trusted
|
||||||
aliceSession.cryptoService().getUserDevices(bobSession.myUserId).first().let { bobDeviceAlicePoc ->
|
testHelper.retryPeriodically {
|
||||||
bobDeviceAlicePoc.trustLevel!!.crossSigningVerified shouldBeEqualTo true
|
val deviceInfo = aliceSession.cryptoService().getUserDevices(bobSession.myUserId).firstOrNull()
|
||||||
|
Timber.v("#TEST device:${deviceInfo?.shortDebugString()} trust ${deviceInfo?.trustLevel}")
|
||||||
|
deviceInfo?.trustLevel?.crossSigningVerified == true
|
||||||
}
|
}
|
||||||
|
|
||||||
val currentBobMSK = aliceSession.cryptoService().crossSigningService()
|
val currentBobMSK = aliceSession.cryptoService().crossSigningService()
|
||||||
.getUserCrossSigningKeys(bobSession.myUserId)!!
|
.getUserCrossSigningKeys(bobSession.myUserId)!!
|
||||||
.masterKey()!!.unpaddedBase64PublicKey!!
|
.masterKey()!!.unpaddedBase64PublicKey!!
|
||||||
|
|
||||||
testHelper.doSync<Unit> {
|
testHelper.waitForCallback<Unit> {
|
||||||
bobSession.cryptoService().crossSigningService().initializeCrossSigning(object : UserInteractiveAuthInterceptor {
|
bobSession.cryptoService().crossSigningService().initializeCrossSigning(object : UserInteractiveAuthInterceptor {
|
||||||
override fun performStage(flowResponse: RegistrationFlowResponse, errCode: String?, promise: Continuation<UIABaseAuth>) {
|
override fun performStage(flowResponse: RegistrationFlowResponse, errCode: String?, promise: Continuation<UIABaseAuth>) {
|
||||||
promise.resume(bobAuthParams)
|
promise.resume(bobAuthParams)
|
||||||
@ -275,50 +275,42 @@ class XSigningTest : InstrumentedTest {
|
|||||||
}, it)
|
}, it)
|
||||||
}
|
}
|
||||||
|
|
||||||
testHelper.waitWithLatch {
|
testHelper.retryPeriodically {
|
||||||
testHelper.retryPeriodicallyWithLatch(it) {
|
val newBobMsk = aliceSession.cryptoService().crossSigningService()
|
||||||
val newBobMsk = aliceSession.cryptoService().crossSigningService()
|
.getUserCrossSigningKeys(bobSession.myUserId)
|
||||||
.getUserCrossSigningKeys(bobSession.myUserId)
|
?.masterKey()?.unpaddedBase64PublicKey
|
||||||
?.masterKey()?.unpaddedBase64PublicKey
|
newBobMsk != null && newBobMsk != currentBobMSK
|
||||||
newBobMsk != null && newBobMsk != currentBobMSK
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// trick to force event to sync
|
// trick to force event to sync
|
||||||
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userIsTyping()
|
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userIsTyping()
|
||||||
|
|
||||||
// assert that bob is not trusted anymore from alice s
|
// assert that bob is not trusted anymore from alice s
|
||||||
testHelper.waitWithLatch {
|
testHelper.retryPeriodically {
|
||||||
testHelper.retryPeriodicallyWithLatch(it) {
|
val trust = aliceSession.cryptoService().crossSigningService().checkUserTrust(bobSession.myUserId)
|
||||||
val trust = aliceSession.cryptoService().crossSigningService().checkUserTrust(bobSession.myUserId)
|
!trust.isVerified()
|
||||||
!trust.isVerified()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// trick to force event to sync
|
// trick to force event to sync
|
||||||
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userStopsTyping()
|
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userStopsTyping()
|
||||||
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userIsTyping()
|
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userIsTyping()
|
||||||
|
|
||||||
testHelper.waitWithLatch {
|
testHelper.retryPeriodically {
|
||||||
testHelper.retryPeriodicallyWithLatch(it) {
|
val info = aliceSession.cryptoService().crossSigningService().getUserCrossSigningKeys(bobSession.myUserId)
|
||||||
val info = aliceSession.cryptoService().crossSigningService().getUserCrossSigningKeys(bobSession.myUserId)
|
info?.wasTrustedOnce == true
|
||||||
info?.wasTrustedOnce == true
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// trick to force event to sync
|
// trick to force event to sync
|
||||||
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userStopsTyping()
|
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userStopsTyping()
|
||||||
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userIsTyping()
|
bobSession.roomService().getRoom(cryptoTestData.roomId)!!.typingService().userIsTyping()
|
||||||
|
|
||||||
testHelper.waitWithLatch {
|
testHelper.retryPeriodically {
|
||||||
testHelper.retryPeriodicallyWithLatch(it) {
|
!aliceSession.cryptoService().crossSigningService().isUserTrusted(bobSession.myUserId)
|
||||||
!aliceSession.cryptoService().crossSigningService().isUserTrusted(bobSession.myUserId)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ensure also that bob device are not trusted
|
// Ensure also that bob device are not trusted
|
||||||
aliceSession.cryptoService().getUserDevices(bobSession.myUserId).first().let { bobDeviceAlicePoc ->
|
testHelper.retryPeriodically {
|
||||||
bobDeviceAlicePoc.trustLevel!!.crossSigningVerified shouldBeEqualTo false
|
aliceSession.cryptoService().getUserDevices(bobSession.myUserId).first().trustLevel?.crossSigningVerified != true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -588,7 +588,6 @@ internal class DefaultCrossSigningService @Inject constructor(
|
|||||||
}
|
}
|
||||||
|
|
||||||
cryptoStore.setUserKeysAsTrusted(otherUserId, true)
|
cryptoStore.setUserKeysAsTrusted(otherUserId, true)
|
||||||
// TODO update local copy with new signature directly here? kind of local echo of trust?
|
|
||||||
|
|
||||||
Timber.d("## CrossSigning - Upload signature of $otherUserId MSK signed by USK")
|
Timber.d("## CrossSigning - Upload signature of $otherUserId MSK signed by USK")
|
||||||
val uploadQuery = UploadSignatureQueryBuilder()
|
val uploadQuery = UploadSignatureQueryBuilder()
|
||||||
@ -598,6 +597,13 @@ internal class DefaultCrossSigningService @Inject constructor(
|
|||||||
this.executionThread = TaskThread.CRYPTO
|
this.executionThread = TaskThread.CRYPTO
|
||||||
this.callback = callback
|
this.callback = callback
|
||||||
}.executeBy(taskExecutor)
|
}.executeBy(taskExecutor)
|
||||||
|
|
||||||
|
// Local echo for device cross trust, to avoid having to wait for a notification of key change
|
||||||
|
cryptoStore.getUserDeviceList(otherUserId)?.forEach { device ->
|
||||||
|
val updatedTrust = checkDeviceTrust(device.userId, device.deviceId, device.trustLevel?.isLocallyVerified() ?: false)
|
||||||
|
Timber.v("## CrossSigning - update trust for device ${device.deviceId} of user $otherUserId , verified=$updatedTrust")
|
||||||
|
cryptoStore.setDeviceTrust(device.userId, device.deviceId, updatedTrust.isCrossSignedVerified(), updatedTrust.isLocallyVerified())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user