2018-06-13 12:29:16 +02:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* Copyright 2017 Paul Schaub
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
package org.jivesoftware.smackx.omemo;
|
|
|
|
|
2020-04-12 21:54:18 +02:00
|
|
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
|
|
|
import static org.junit.jupiter.api.Assertions.assertNotEquals;
|
2018-06-13 12:29:16 +02:00
|
|
|
|
|
|
|
import org.jivesoftware.smack.SmackException;
|
2019-10-24 15:45:08 +02:00
|
|
|
import org.jivesoftware.smack.XMPPConnection;
|
2018-06-13 12:29:16 +02:00
|
|
|
import org.jivesoftware.smack.XMPPException;
|
2019-10-24 15:45:08 +02:00
|
|
|
import org.jivesoftware.smack.packet.MessageBuilder;
|
|
|
|
|
2018-06-13 12:29:16 +02:00
|
|
|
import org.jivesoftware.smackx.omemo.element.OmemoBundleElement;
|
|
|
|
|
|
|
|
import org.igniterealtime.smack.inttest.SmackIntegrationTestEnvironment;
|
|
|
|
import org.igniterealtime.smack.inttest.TestNotPossibleException;
|
2020-04-12 21:54:18 +02:00
|
|
|
import org.igniterealtime.smack.inttest.annotations.SmackIntegrationTest;
|
2018-06-13 12:29:16 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Simple OMEMO message encryption integration test.
|
|
|
|
* During this test Alice sends an encrypted message to Bob. Bob decrypts it and sends a response to Alice.
|
|
|
|
* It is checked whether the messages can be decrypted, and if used up pre-keys result in renewed bundles.
|
|
|
|
*/
|
|
|
|
public class MessageEncryptionIntegrationTest extends AbstractTwoUsersOmemoIntegrationTest {
|
|
|
|
|
2020-04-04 13:03:31 +02:00
|
|
|
public MessageEncryptionIntegrationTest(SmackIntegrationTestEnvironment environment)
|
2018-06-13 12:29:16 +02:00
|
|
|
throws XMPPException.XMPPErrorException, SmackException.NotConnectedException, InterruptedException,
|
|
|
|
SmackException.NoResponseException, TestNotPossibleException {
|
|
|
|
super(environment);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This test checks whether the following actions are performed.
|
|
|
|
*
|
|
|
|
* Alice publishes bundle A1
|
|
|
|
* Bob publishes bundle B1
|
|
|
|
*
|
|
|
|
* Alice sends message to Bob (preKeyMessage)
|
|
|
|
* Bob publishes bundle B2
|
|
|
|
* Alice still has A1
|
|
|
|
*
|
|
|
|
* Bob responds to Alice (normal message)
|
|
|
|
* Alice still has A1
|
|
|
|
* Bob still has B2
|
2019-08-30 12:08:30 +02:00
|
|
|
* @throws Exception if an exception occurs.
|
2018-06-13 12:29:16 +02:00
|
|
|
*/
|
2019-08-06 08:23:10 +02:00
|
|
|
@SuppressWarnings("SynchronizeOnNonFinalField")
|
2018-06-13 12:29:16 +02:00
|
|
|
@SmackIntegrationTest
|
|
|
|
public void messageTest() throws Exception {
|
|
|
|
OmemoBundleElement a1 = alice.getOmemoService().getOmemoStoreBackend().packOmemoBundle(alice.getOwnDevice());
|
|
|
|
OmemoBundleElement b1 = bob.getOmemoService().getOmemoStoreBackend().packOmemoBundle(bob.getOwnDevice());
|
|
|
|
|
|
|
|
// Alice sends message(s) to bob
|
|
|
|
// PreKeyMessage A -> B
|
|
|
|
final String body1 = "One is greater than zero (for small values of zero).";
|
|
|
|
AbstractOmemoMessageListener.PreKeyMessageListener listener1 =
|
|
|
|
new AbstractOmemoMessageListener.PreKeyMessageListener(body1);
|
|
|
|
bob.addOmemoMessageListener(listener1);
|
|
|
|
OmemoMessage.Sent e1 = alice.encrypt(bob.getOwnJid(), body1);
|
2019-10-24 15:45:08 +02:00
|
|
|
|
|
|
|
XMPPConnection alicesConnection = alice.getConnection();
|
|
|
|
MessageBuilder messageBuilder = alicesConnection.getStanzaFactory().buildMessageStanza();
|
|
|
|
alicesConnection.sendStanza(e1.buildMessage(messageBuilder, bob.getOwnJid()));
|
2018-06-13 12:29:16 +02:00
|
|
|
listener1.getSyncPoint().waitForResult(10 * 1000);
|
|
|
|
bob.removeOmemoMessageListener(listener1);
|
|
|
|
|
|
|
|
OmemoBundleElement a1_ = alice.getOmemoService().getOmemoStoreBackend().packOmemoBundle(alice.getOwnDevice());
|
|
|
|
OmemoBundleElement b2;
|
|
|
|
|
2019-08-06 08:23:10 +02:00
|
|
|
synchronized (bob) { // Circumvent race condition where bundle gets replenished after getting stored in b2
|
2018-06-13 12:29:16 +02:00
|
|
|
b2 = bob.getOmemoService().getOmemoStoreBackend().packOmemoBundle(bob.getOwnDevice());
|
|
|
|
}
|
|
|
|
|
2020-04-12 21:54:18 +02:00
|
|
|
assertEquals(a1, a1_, "Alice sent bob a preKeyMessage, so her bundle MUST still be the same.");
|
|
|
|
assertNotEquals(b1, b2, "Bob just received a preKeyMessage from alice, so his bundle must have changed.");
|
2018-06-13 12:29:16 +02:00
|
|
|
|
|
|
|
// Message B -> A
|
|
|
|
final String body3 = "The german words for 'leek' and 'wimp' are the same.";
|
|
|
|
AbstractOmemoMessageListener.MessageListener listener3 =
|
|
|
|
new AbstractOmemoMessageListener.MessageListener(body3);
|
|
|
|
alice.addOmemoMessageListener(listener3);
|
|
|
|
OmemoMessage.Sent e3 = bob.encrypt(alice.getOwnJid(), body3);
|
2019-10-24 15:45:08 +02:00
|
|
|
XMPPConnection bobsConnection = bob.getConnection();
|
|
|
|
messageBuilder = bobsConnection.getStanzaFactory().buildMessageStanza();
|
|
|
|
bobsConnection.sendStanza(e3.buildMessage(messageBuilder, alice.getOwnJid()));
|
2018-06-13 12:29:16 +02:00
|
|
|
listener3.getSyncPoint().waitForResult(10 * 1000);
|
|
|
|
alice.removeOmemoMessageListener(listener3);
|
|
|
|
|
|
|
|
OmemoBundleElement a1__ = alice.getOmemoService().getOmemoStoreBackend().packOmemoBundle(alice.getOwnDevice());
|
|
|
|
OmemoBundleElement b2_ = bob.getOmemoService().getOmemoStoreBackend().packOmemoBundle(bob.getOwnDevice());
|
|
|
|
|
2020-04-12 21:54:18 +02:00
|
|
|
assertEquals(a1_, a1__, "Since alice initiated the session with bob, at no time he sent a preKeyMessage, " +
|
|
|
|
"so her bundle MUST still be the same.");
|
|
|
|
assertEquals(b2, b2_, "Bob changed his bundle earlier, but at this point his bundle must be equal to " +
|
|
|
|
"after the first change.");
|
2018-06-13 12:29:16 +02:00
|
|
|
}
|
|
|
|
}
|