use of org.matrix.androidsdk.rest.model.MatrixError in project matrix-android-sdk by matrix-org.
the class CryptoTest method test11_testAliceAndBobInACryptedRoomBackPaginationFromMemoryStore.
@Test
public void test11_testAliceAndBobInACryptedRoomBackPaginationFromMemoryStore() throws Exception {
Log.e(LOG_TAG, "test11_testAliceAndBobInACryptedRoomBackPaginationFromMemoryStore");
Context context = InstrumentationRegistry.getContext();
final HashMap<String, Object> results = new HashMap();
doE2ETestWithAliceAndBobInARoomWithCryptedMessages(true);
Credentials bobCredentials = mBobSession.getCredentials();
mBobSession.clear(context);
Uri uri = Uri.parse(CryptoTestHelper.TESTS_HOME_SERVER_URL);
HomeServerConnectionConfig hs = new HomeServerConnectionConfig(uri);
hs.setCredentials(bobCredentials);
IMXStore store = new MXFileStore(hs, context);
final CountDownLatch lock1 = new CountDownLatch(2);
MXSession bobSession2 = new MXSession(hs, new MXDataHandler(store, bobCredentials), context);
MXEventListener eventListener = new MXEventListener() {
@Override
public void onInitialSyncComplete(String toToken) {
results.put("onInitialSyncComplete", "onInitialSyncComplete");
lock1.countDown();
}
@Override
public void onCryptoSyncComplete() {
results.put("onCryptoSyncComplete", "onCryptoSyncComplete");
lock1.countDown();
}
};
bobSession2.getDataHandler().addListener(eventListener);
bobSession2.getDataHandler().getStore().open();
bobSession2.startEventStream(null);
lock1.await(1000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("onInitialSyncComplete"));
assertTrue(results.containsKey("onCryptoSyncComplete"));
assertTrue(null != bobSession2.getCrypto());
Room roomFromBobPOV = bobSession2.getDataHandler().getRoom(mRoomId);
final CountDownLatch lock2 = new CountDownLatch(6);
final ArrayList<Event> receivedEvents = new ArrayList<>();
EventTimeline.EventTimelineListener eventTimelineListener = new EventTimeline.EventTimelineListener() {
public void onEvent(Event event, EventTimeline.Direction direction, RoomState roomState) {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
receivedEvents.add(event);
lock2.countDown();
}
}
};
roomFromBobPOV.getLiveTimeLine().addEventTimelineListener(eventTimelineListener);
roomFromBobPOV.getLiveTimeLine().backPaginate(new ApiCallback<Integer>() {
@Override
public void onSuccess(Integer info) {
results.put("backPaginate", "backPaginate");
lock2.countDown();
}
@Override
public void onNetworkError(Exception e) {
}
@Override
public void onMatrixError(MatrixError e) {
}
@Override
public void onUnexpectedError(Exception e) {
}
});
lock2.await(1000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("backPaginate"));
assertTrue(receivedEvents.size() + " instead of 5", 5 == receivedEvents.size());
checkEncryptedEvent(receivedEvents.get(0), mRoomId, messagesFromAlice.get(1), mAliceSession);
checkEncryptedEvent(receivedEvents.get(1), mRoomId, messagesFromBob.get(2), mBobSession);
checkEncryptedEvent(receivedEvents.get(2), mRoomId, messagesFromBob.get(1), mBobSession);
checkEncryptedEvent(receivedEvents.get(3), mRoomId, messagesFromBob.get(0), mBobSession);
checkEncryptedEvent(receivedEvents.get(4), mRoomId, messagesFromAlice.get(0), mAliceSession);
bobSession2.clear(context);
mAliceSession.clear(context);
}
use of org.matrix.androidsdk.rest.model.MatrixError in project matrix-android-sdk by matrix-org.
the class CryptoTest method test26_testBlackListUnverifiedDevices.
@Test
public // Check that the message can be decrypted by the Bob's device and the Sam's device
void test26_testBlackListUnverifiedDevices() throws Exception {
Log.e(LOG_TAG, "test26_testBlackListUnverifiedDevices");
Context context = InstrumentationRegistry.getContext();
final HashMap<String, Object> results = new HashMap<>();
doE2ETestWithAliceAndBobAndSamInARoom();
final String messageFromAlice = "Hello I'm Alice!";
Room roomFromBobPOV = mBobSession.getDataHandler().getRoom(mRoomId);
Room roomFromAlicePOV = mAliceSession.getDataHandler().getRoom(mRoomId);
Room roomFromSamPOV = mSamSession.getDataHandler().getRoom(mRoomId);
assertTrue(roomFromBobPOV.isEncrypted());
assertTrue(roomFromAlicePOV.isEncrypted());
assertTrue(roomFromSamPOV.isEncrypted());
final CountDownLatch lock1 = new CountDownLatch(1);
roomFromAlicePOV.sendEvent(buildTextEvent(messageFromAlice, mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock1.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock1.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
results.put("sendEventError", e);
lock1.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock1.countDown();
}
});
lock1.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("sendEventError"));
MXCryptoError error = (MXCryptoError) results.get("sendEventError");
assertTrue(TextUtils.equals(error.errcode, MXCryptoError.UNKNOWN_DEVICES_CODE));
MXUsersDevicesMap<MXDeviceInfo> unknownDevices = (MXUsersDevicesMap<MXDeviceInfo>) error.mExceptionData;
// only one bob device
List<String> deviceInfos = unknownDevices.getUserDeviceIds(mBobSession.getMyUserId());
assertTrue(1 == deviceInfos.size());
assertTrue(deviceInfos.contains(mBobSession.getCrypto().getMyDevice().deviceId));
// only one Sam device
deviceInfos = unknownDevices.getUserDeviceIds(mSamSession.getMyUserId());
assertTrue(1 == deviceInfos.size());
assertTrue(deviceInfos.contains(mSamSession.getCrypto().getMyDevice().deviceId));
final CountDownLatch lock2 = new CountDownLatch(1);
mAliceSession.getCrypto().setDevicesKnown(Arrays.asList(mBobSession.getCrypto().getMyDevice(), mSamSession.getCrypto().getMyDevice()), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setDevicesKnown", "setDevicesKnown");
lock2.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock2.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock2.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock2.countDown();
}
});
lock2.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setDevicesKnown"));
final CountDownLatch lock3 = new CountDownLatch(5);
MXEventListener eventListenerBob1 = new MXEventListener() {
@Override
public void onLiveEvent(Event event, RoomState roomState) {
try {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
if (checkEncryptedEvent(event, mRoomId, messageFromAlice, mAliceSession)) {
results.put("onLiveEventBob1", "onLiveEvent");
lock3.countDown();
}
}
} catch (Exception e) {
}
}
};
MXEventListener eventListenerSam1 = new MXEventListener() {
@Override
public void onLiveEvent(Event event, RoomState roomState) {
try {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
if (checkEncryptedEvent(event, mRoomId, messageFromAlice, mAliceSession)) {
results.put("onLiveEventSam1", "onLiveEvent");
lock3.countDown();
}
}
} catch (Exception e) {
}
}
};
mBobSession.getDataHandler().addListener(new MXEventListener() {
@Override
public void onToDeviceEvent(Event event) {
results.put("onToDeviceEventBob", event);
lock3.countDown();
}
});
mSamSession.getDataHandler().addListener(new MXEventListener() {
@Override
public void onToDeviceEvent(Event event) {
results.put("onToDeviceEventSam", event);
lock3.countDown();
}
});
roomFromBobPOV.addEventListener(eventListenerBob1);
roomFromSamPOV.addEventListener(eventListenerSam1);
roomFromAlicePOV.sendEvent(buildTextEvent(messageFromAlice, mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock3.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock3.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock3.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock3.countDown();
}
});
lock3.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("onToDeviceEventBob"));
assertTrue(results.containsKey("onToDeviceEventSam"));
assertTrue(results.containsKey("onLiveEventBob1"));
assertTrue(results.containsKey("onLiveEventSam1"));
roomFromBobPOV.removeEventListener(eventListenerBob1);
roomFromSamPOV.removeEventListener(eventListenerSam1);
// play with the device black listing
final List<CountDownLatch> activeLock = new ArrayList<>();
final List<String> activeMessage = new ArrayList<>();
MXEventListener eventListenerBob2 = new MXEventListener() {
@Override
public void onLiveEvent(Event event, RoomState roomState) {
try {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
if (checkEncryptedEvent(event, mRoomId, activeMessage.get(0), mAliceSession)) {
results.put("eventListenerBob2", "onLiveEvent");
activeLock.get(0).countDown();
}
} else if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE_ENCRYPTED)) {
results.put("eventListenerEncyptedBob2", "onLiveEvent");
activeLock.get(0).countDown();
}
} catch (Exception e) {
}
}
};
MXEventListener eventListenerSam2 = new MXEventListener() {
@Override
public void onLiveEvent(Event event, RoomState roomState) {
try {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
if (checkEncryptedEvent(event, mRoomId, activeMessage.get(0), mAliceSession)) {
results.put("eventListenerSam2", "onLiveEvent");
activeLock.get(0).countDown();
}
} else if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE_ENCRYPTED)) {
results.put("eventListenerEncyptedSam2", "onLiveEvent");
activeLock.get(0).countDown();
}
} catch (Exception e) {
}
}
};
roomFromBobPOV.addEventListener(eventListenerBob2);
roomFromSamPOV.addEventListener(eventListenerSam2);
final CountDownLatch lock4 = new CountDownLatch(1);
mAliceSession.getCrypto().setGlobalBlacklistUnverifiedDevices(true, new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setGlobalBlacklistUnverifiedDevicesTrue", "setGlobalBlacklistUnverifiedDevices");
lock4.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock4.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock4.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock4.countDown();
}
});
lock4.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setGlobalBlacklistUnverifiedDevicesTrue"));
// ensure that there is no received message
results.clear();
final CountDownLatch lock5 = new CountDownLatch(3);
activeLock.clear();
activeLock.add(lock5);
activeMessage.clear();
activeMessage.add("message 1");
roomFromAlicePOV.sendEvent(buildTextEvent(activeMessage.get(0), mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock5.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock5.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock5.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock5.countDown();
}
});
lock5.await(3000, TimeUnit.MILLISECONDS);
assertTrue(!results.containsKey("eventListenerBob2"));
assertTrue(!results.containsKey("eventListenerSam2"));
assertTrue(results.containsKey("eventListenerEncyptedBob2"));
assertTrue(results.containsKey("eventListenerEncyptedSam2"));
final CountDownLatch lock6 = new CountDownLatch(1);
mAliceSession.getCrypto().setGlobalBlacklistUnverifiedDevices(false, new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setGlobalBlacklistUnverifiedDevicesfalse", "setGlobalBlacklistUnverifiedDevices");
lock6.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock6.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock6.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock6.countDown();
}
});
lock6.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setGlobalBlacklistUnverifiedDevicesfalse"));
// ensure that the messages are received
results.clear();
final CountDownLatch lock7 = new CountDownLatch(3);
activeLock.clear();
activeLock.add(lock7);
activeMessage.clear();
activeMessage.add("message 2");
roomFromAlicePOV.sendEvent(buildTextEvent(activeMessage.get(0), mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock7.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock7.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock7.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock7.countDown();
}
});
lock7.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("eventListenerBob2"));
assertTrue(results.containsKey("eventListenerSam2"));
assertTrue(!results.containsKey("eventListenerEncyptedBob2"));
assertTrue(!results.containsKey("eventListenerEncyptedSam2"));
// verify the bob device
final CountDownLatch lock8 = new CountDownLatch(3);
mAliceSession.getCrypto().setDeviceVerification(MXDeviceInfo.DEVICE_VERIFICATION_VERIFIED, mBobSession.getCrypto().getMyDevice().deviceId, mBobSession.getMyUserId(), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setDeviceVerificationBob", "setDeviceVerificationBob");
lock8.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock8.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock8.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock8.countDown();
}
});
lock8.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setDeviceVerificationBob"));
final CountDownLatch lock9 = new CountDownLatch(3);
mAliceSession.getCrypto().setRoomBlacklistUnverifiedDevices(roomFromAlicePOV.getRoomId(), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setRoomBlacklistUnverifiedDevices", "setRoomBlacklistUnverifiedDevices");
lock9.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock9.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock9.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock9.countDown();
}
});
lock9.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setRoomBlacklistUnverifiedDevices"));
// ensure that the messages are received
results.clear();
final CountDownLatch lock10 = new CountDownLatch(3);
activeLock.clear();
activeLock.add(lock10);
activeMessage.clear();
activeMessage.add("message 3");
roomFromAlicePOV.sendEvent(buildTextEvent(activeMessage.get(0), mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock10.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock10.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock10.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock10.countDown();
}
});
lock10.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("eventListenerBob2"));
assertTrue(!results.containsKey("eventListenerSam2"));
assertTrue(!results.containsKey("eventListenerEncyptedBob2"));
assertTrue(results.containsKey("eventListenerEncyptedSam2"));
final CountDownLatch lock11 = new CountDownLatch(3);
mAliceSession.getCrypto().setRoomUnblacklistUnverifiedDevices(roomFromAlicePOV.getRoomId(), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setRoomUnblacklistUnverifiedDevices", "setRoomUnblacklistUnverifiedDevices");
lock11.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock11.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock11.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock11.countDown();
}
});
lock11.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setRoomUnblacklistUnverifiedDevices"));
// ensure that the messages are received
results.clear();
final CountDownLatch lock12 = new CountDownLatch(3);
activeLock.clear();
activeLock.add(lock12);
activeMessage.clear();
activeMessage.add("message 3");
roomFromAlicePOV.sendEvent(buildTextEvent(activeMessage.get(0), mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock12.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock12.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock12.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock12.countDown();
}
});
lock12.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("eventListenerBob2"));
assertTrue(results.containsKey("eventListenerSam2"));
assertTrue(!results.containsKey("eventListenerEncyptedBob2"));
assertTrue(!results.containsKey("eventListenerEncyptedSam2"));
mBobSession.clear(context);
}
use of org.matrix.androidsdk.rest.model.MatrixError in project matrix-android-sdk by matrix-org.
the class CryptoTest method test01_testCryptoNoDeviceId.
@Test
public void test01_testCryptoNoDeviceId() throws Exception {
Log.e(LOG_TAG, "test01_testCryptoNoDeviceId");
Context context = InstrumentationRegistry.getContext();
final HashMap<String, Object> results = new HashMap<>();
createBobAccount();
assertTrue(null == mBobSession.getCrypto());
mBobSession.getCredentials().deviceId = null;
final CountDownLatch lock1 = new CountDownLatch(1);
mBobSession.enableCrypto(true, new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("enableCrypto", "enableCrypto");
lock1.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock1.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock1.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock1.countDown();
}
});
lock1.await(1000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("enableCrypto"));
assertTrue(null != mBobSession.getCrypto());
assertTrue(null != mBobSession.getCredentials().deviceId);
mBobSession.clear(context);
}
use of org.matrix.androidsdk.rest.model.MatrixError in project matrix-android-sdk by matrix-org.
the class CryptoTest method test23_testFirstMessageSentWhileSessionWasPaused.
@Test
public void test23_testFirstMessageSentWhileSessionWasPaused() throws Exception {
Log.e(LOG_TAG, "test23_testFirstMessageSentWhileSessionWasPaused");
Context context = InstrumentationRegistry.getContext();
final String messageFromAlice = "Hello I'm Alice!";
final HashMap<String, Object> results = new HashMap<>();
doE2ETestWithAliceAndBobInARoom(true);
mBobSession.getCrypto().setWarnOnUnknownDevices(false);
mAliceSession.getCrypto().setWarnOnUnknownDevices(false);
final Room roomFromBobPOV = mBobSession.getDataHandler().getRoom(mRoomId);
final Room roomFromAlicePOV = mAliceSession.getDataHandler().getRoom(mRoomId);
assertTrue(roomFromBobPOV.isEncrypted());
assertTrue(roomFromAlicePOV.isEncrypted());
mBobSession.pauseEventStream();
// wait that the bob session is really suspended
SystemClock.sleep(30000);
final CountDownLatch lock0 = new CountDownLatch(1);
roomFromAlicePOV.sendEvent(buildTextEvent(messageFromAlice, mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("sendEvent", "sendEvent");
lock0.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock0.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock0.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock0.countDown();
}
});
lock0.await(2000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("sendEvent"));
final CountDownLatch lock2 = new CountDownLatch(2);
MXEventListener eventListener = new MXEventListener() {
@Override
public void onLiveEvent(Event event, RoomState roomState) {
try {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
if (checkEncryptedEvent(event, mRoomId, messageFromAlice, mAliceSession)) {
results.put("onLiveEvent", "onLiveEvent");
lock2.countDown();
}
}
} catch (Exception e) {
}
}
};
roomFromBobPOV.addEventListener(eventListener);
mBobSession.getDataHandler().addListener(new MXEventListener() {
@Override
public void onToDeviceEvent(Event event) {
results.put("onToDeviceEvent", event);
lock2.countDown();
}
});
mBobSession.resumeEventStream();
lock2.await(10000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("onToDeviceEvent"));
assertTrue(results.containsKey("onLiveEvent"));
mBobSession.clear(context);
mAliceSession.clear(context);
}
use of org.matrix.androidsdk.rest.model.MatrixError in project matrix-android-sdk by matrix-org.
the class CryptoTest method test18_testAliceAndBobWithNewDevice.
@Test
public void test18_testAliceAndBobWithNewDevice() throws Exception {
Log.e(LOG_TAG, "test18_testAliceAndBobWithNewDevice");
Context context = InstrumentationRegistry.getContext();
final HashMap<String, Object> results = new HashMap<>();
doE2ETestWithAliceAndBobInARoom(true);
mBobSession.getCrypto().setWarnOnUnknownDevices(false);
mAliceSession.getCrypto().setWarnOnUnknownDevices(false);
final Room roomFromBobPOV = mBobSession.getDataHandler().getRoom(mRoomId);
final Room roomFromAlicePOV = mAliceSession.getDataHandler().getRoom(mRoomId);
String bobDeviceId1 = mBobSession.getCredentials().deviceId;
assertTrue(roomFromBobPOV.isEncrypted());
assertTrue(roomFromAlicePOV.isEncrypted());
final CountDownLatch lock1 = new CountDownLatch(2);
MXEventListener bobEventListener = new MXEventListener() {
@Override
public void onToDeviceEvent(Event event) {
if (!results.containsKey("onToDeviceEvent")) {
results.put("onToDeviceEvent", event);
lock1.countDown();
}
}
};
mBobSession.getDataHandler().addListener(bobEventListener);
final ArrayList<Event> receivedEvents = new ArrayList<>();
EventTimeline.EventTimelineListener eventTimelineListener = new EventTimeline.EventTimelineListener() {
public void onEvent(Event event, EventTimeline.Direction direction, RoomState roomState) {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
receivedEvents.add(event);
lock1.countDown();
}
}
};
roomFromBobPOV.getLiveTimeLine().addEventTimelineListener(eventTimelineListener);
String aliceMessage1 = "Hello I'm Alice!";
roomFromAlicePOV.sendEvent(buildTextEvent(aliceMessage1, mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
}
@Override
public void onNetworkError(Exception e) {
}
@Override
public void onMatrixError(MatrixError e) {
}
@Override
public void onUnexpectedError(Exception e) {
}
});
lock1.await(2000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("onToDeviceEvent"));
assertTrue(1 == receivedEvents.size());
Event event = receivedEvents.get(0);
assertTrue(checkEncryptedEvent(event, mRoomId, aliceMessage1, mAliceSession));
// logout
final CountDownLatch lock2 = new CountDownLatch(1);
String bobId = mBobSession.getCredentials().userId;
mBobSession.logout(context, new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("logout", "logout");
lock2.countDown();
}
@Override
public void onNetworkError(Exception e) {
}
@Override
public void onMatrixError(MatrixError e) {
}
@Override
public void onUnexpectedError(Exception e) {
}
});
lock2.await(1000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("logout"));
final CountDownLatch lock3 = new CountDownLatch(1);
MXEventListener aliceEventListener = new MXEventListener() {
@Override
public void onToDeviceEvent(Event event) {
if (!results.containsKey("onToDeviceEvent2")) {
results.put("onToDeviceEvent2", event);
lock3.countDown();
}
}
};
mAliceSession.getDataHandler().addListener(aliceEventListener);
// login with a new device id
MXSession bobSession2 = CryptoTestHelper.logAccountAndSync(context, bobId, MXTESTS_BOB_PWD);
String bobDeviceId2 = bobSession2.getCredentials().deviceId;
assertTrue(!TextUtils.equals(bobDeviceId2, bobDeviceId1));
// before sending a message, wait that the device event is received.
lock3.await(10000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("onToDeviceEvent2"));
SystemClock.sleep(1000);
final Room roomFromBobPOV2 = bobSession2.getDataHandler().getRoom(mRoomId);
assertTrue(null != roomFromBobPOV2);
final ArrayList<Event> receivedEvents4 = new ArrayList<>();
final CountDownLatch lock4 = new CountDownLatch(1);
EventTimeline.EventTimelineListener eventTimelineListener4 = new EventTimeline.EventTimelineListener() {
public void onEvent(Event event, EventTimeline.Direction direction, RoomState roomState) {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
receivedEvents4.add(event);
lock4.countDown();
} else {
results.put("event4", event.getType() + "");
lock4.countDown();
}
}
};
roomFromBobPOV2.getLiveTimeLine().addEventTimelineListener(eventTimelineListener4);
String aliceMessage2 = "Hello I'm still Alice!";
roomFromAlicePOV.sendEvent(buildTextEvent(aliceMessage2, mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
}
@Override
public void onNetworkError(Exception e) {
}
@Override
public void onMatrixError(MatrixError e) {
}
@Override
public void onUnexpectedError(Exception e) {
}
});
lock4.await(5000, TimeUnit.MILLISECONDS);
assertTrue("received event of type " + results.get("event4"), 1 == receivedEvents4.size());
event = receivedEvents4.get(0);
assertTrue(checkEncryptedEvent(event, mRoomId, aliceMessage2, mAliceSession));
}
Aggregations