mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-12 02:03:55 +00:00
This is no longer testable =(
// FREEBIE
This commit is contained in:
parent
d280604f1f
commit
b7d4294314
@ -1,156 +0,0 @@
|
|||||||
package org.thoughtcrime.securesms.jobs;
|
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.thoughtcrime.securesms.BaseUnitTest;
|
|
||||||
import org.thoughtcrime.securesms.crypto.MasterSecret;
|
|
||||||
import org.thoughtcrime.securesms.dependencies.AxolotlStorageModule;
|
|
||||||
import org.whispersystems.libsignal.ecc.Curve;
|
|
||||||
import org.whispersystems.libsignal.state.SignedPreKeyRecord;
|
|
||||||
import org.whispersystems.libsignal.state.SignedPreKeyStore;
|
|
||||||
import org.whispersystems.signalservice.api.SignalServiceAccountManager;
|
|
||||||
import org.whispersystems.signalservice.api.push.SignedPreKeyEntity;
|
|
||||||
import org.whispersystems.signalservice.api.push.exceptions.PushNetworkException;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.LinkedList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import dagger.Module;
|
|
||||||
import dagger.ObjectGraph;
|
|
||||||
import dagger.Provides;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
import static org.mockito.Matchers.anyInt;
|
|
||||||
import static org.mockito.Matchers.eq;
|
|
||||||
import static org.mockito.Mockito.mock;
|
|
||||||
import static org.mockito.Mockito.never;
|
|
||||||
import static org.mockito.Mockito.times;
|
|
||||||
import static org.mockito.Mockito.verify;
|
|
||||||
import static org.mockito.Mockito.verifyNoMoreInteractions;
|
|
||||||
import static org.mockito.Mockito.when;
|
|
||||||
|
|
||||||
public class CleanPreKeysJobTest extends BaseUnitTest {
|
|
||||||
@Test
|
|
||||||
public void testSignedPreKeyRotationNotRegistered() throws IOException, MasterSecretJob.RequirementNotMetException {
|
|
||||||
SignalServiceAccountManager accountManager = mock(SignalServiceAccountManager.class);
|
|
||||||
SignedPreKeyStore signedPreKeyStore = mock(SignedPreKeyStore.class);
|
|
||||||
MasterSecret masterSecret = mock(MasterSecret.class);
|
|
||||||
when(accountManager.getSignedPreKey()).thenReturn(null);
|
|
||||||
|
|
||||||
CleanPreKeysJob cleanPreKeysJob = new CleanPreKeysJob(context);
|
|
||||||
|
|
||||||
ObjectGraph objectGraph = ObjectGraph.create(new TestModule(accountManager, signedPreKeyStore));
|
|
||||||
objectGraph.inject(cleanPreKeysJob);
|
|
||||||
|
|
||||||
cleanPreKeysJob.onRun(masterSecret);
|
|
||||||
|
|
||||||
verify(accountManager).getSignedPreKey();
|
|
||||||
verifyNoMoreInteractions(signedPreKeyStore);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testSignedPreKeyEviction() throws Exception {
|
|
||||||
SignedPreKeyStore signedPreKeyStore = mock(SignedPreKeyStore.class);
|
|
||||||
SignalServiceAccountManager accountManager = mock(SignalServiceAccountManager.class);
|
|
||||||
SignedPreKeyEntity currentSignedPreKeyEntity = mock(SignedPreKeyEntity.class);
|
|
||||||
MasterSecret masterSecret = mock(MasterSecret.class);
|
|
||||||
|
|
||||||
when(currentSignedPreKeyEntity.getKeyId()).thenReturn(3133);
|
|
||||||
when(accountManager.getSignedPreKey()).thenReturn(currentSignedPreKeyEntity);
|
|
||||||
|
|
||||||
final SignedPreKeyRecord currentRecord = new SignedPreKeyRecord(3133, System.currentTimeMillis(), Curve.generateKeyPair(), new byte[64]);
|
|
||||||
|
|
||||||
List<SignedPreKeyRecord> records = new LinkedList<SignedPreKeyRecord>() {{
|
|
||||||
add(new SignedPreKeyRecord(2, 11, Curve.generateKeyPair(), new byte[32]));
|
|
||||||
add(new SignedPreKeyRecord(4, System.currentTimeMillis() - 100, Curve.generateKeyPair(), new byte[64]));
|
|
||||||
add(currentRecord);
|
|
||||||
add(new SignedPreKeyRecord(3, System.currentTimeMillis() - 90, Curve.generateKeyPair(), new byte[64]));
|
|
||||||
add(new SignedPreKeyRecord(1, 10, Curve.generateKeyPair(), new byte[32]));
|
|
||||||
}};
|
|
||||||
|
|
||||||
when(signedPreKeyStore.loadSignedPreKeys()).thenReturn(records);
|
|
||||||
when(signedPreKeyStore.loadSignedPreKey(eq(3133))).thenReturn(currentRecord);
|
|
||||||
|
|
||||||
CleanPreKeysJob cleanPreKeysJob = new CleanPreKeysJob(context);
|
|
||||||
|
|
||||||
ObjectGraph objectGraph = ObjectGraph.create(new TestModule(accountManager, signedPreKeyStore));
|
|
||||||
objectGraph.inject(cleanPreKeysJob);
|
|
||||||
|
|
||||||
cleanPreKeysJob.onRun(masterSecret);
|
|
||||||
|
|
||||||
verify(signedPreKeyStore).removeSignedPreKey(eq(1));
|
|
||||||
verify(signedPreKeyStore, times(1)).removeSignedPreKey(anyInt());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testSignedPreKeyNoEviction() throws Exception {
|
|
||||||
SignedPreKeyStore signedPreKeyStore = mock(SignedPreKeyStore.class);
|
|
||||||
SignalServiceAccountManager accountManager = mock(SignalServiceAccountManager.class);
|
|
||||||
SignedPreKeyEntity currentSignedPreKeyEntity = mock(SignedPreKeyEntity.class);
|
|
||||||
|
|
||||||
when(currentSignedPreKeyEntity.getKeyId()).thenReturn(3133);
|
|
||||||
when(accountManager.getSignedPreKey()).thenReturn(currentSignedPreKeyEntity);
|
|
||||||
|
|
||||||
final SignedPreKeyRecord currentRecord = new SignedPreKeyRecord(3133, System.currentTimeMillis(), Curve.generateKeyPair(), new byte[64]);
|
|
||||||
|
|
||||||
List<SignedPreKeyRecord> records = new LinkedList<SignedPreKeyRecord>() {{
|
|
||||||
add(currentRecord);
|
|
||||||
}};
|
|
||||||
|
|
||||||
when(signedPreKeyStore.loadSignedPreKeys()).thenReturn(records);
|
|
||||||
when(signedPreKeyStore.loadSignedPreKey(eq(3133))).thenReturn(currentRecord);
|
|
||||||
|
|
||||||
CleanPreKeysJob cleanPreKeysJob = new CleanPreKeysJob(context);
|
|
||||||
|
|
||||||
ObjectGraph objectGraph = ObjectGraph.create(new TestModule(accountManager, signedPreKeyStore));
|
|
||||||
objectGraph.inject(cleanPreKeysJob);
|
|
||||||
|
|
||||||
verify(signedPreKeyStore, never()).removeSignedPreKey(anyInt());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testConnectionError() throws Exception {
|
|
||||||
SignedPreKeyStore signedPreKeyStore = mock(SignedPreKeyStore.class);
|
|
||||||
SignalServiceAccountManager accountManager = mock(SignalServiceAccountManager.class);
|
|
||||||
MasterSecret masterSecret = mock(MasterSecret.class);
|
|
||||||
|
|
||||||
when(accountManager.getSignedPreKey()).thenThrow(new PushNetworkException("Connectivity error!"));
|
|
||||||
|
|
||||||
CleanPreKeysJob cleanPreKeysJob = new CleanPreKeysJob(context);
|
|
||||||
|
|
||||||
ObjectGraph objectGraph = ObjectGraph.create(new TestModule(accountManager, signedPreKeyStore));
|
|
||||||
objectGraph.inject(cleanPreKeysJob);
|
|
||||||
|
|
||||||
try {
|
|
||||||
cleanPreKeysJob.onRun(masterSecret);
|
|
||||||
throw new AssertionError("should have failed!");
|
|
||||||
} catch (IOException e) {
|
|
||||||
assertTrue(cleanPreKeysJob.onShouldRetry(e));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Module(injects = {CleanPreKeysJob.class})
|
|
||||||
public static class TestModule {
|
|
||||||
private final SignalServiceAccountManager accountManager;
|
|
||||||
private final SignedPreKeyStore signedPreKeyStore;
|
|
||||||
|
|
||||||
private TestModule(SignalServiceAccountManager accountManager, SignedPreKeyStore signedPreKeyStore) {
|
|
||||||
this.accountManager = accountManager;
|
|
||||||
this.signedPreKeyStore = signedPreKeyStore;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Provides SignalServiceAccountManager provideTextSecureAccountManager() {
|
|
||||||
return accountManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Provides
|
|
||||||
AxolotlStorageModule.SignedPreKeyStoreFactory provideSignedPreKeyStore() {
|
|
||||||
return new AxolotlStorageModule.SignedPreKeyStoreFactory() {
|
|
||||||
@Override
|
|
||||||
public SignedPreKeyStore create() {
|
|
||||||
return signedPreKeyStore;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user