summaryrefslogtreecommitdiff
path: root/app/src/test/java/se/leap
diff options
context:
space:
mode:
authorcyBerta <cyberta@riseup.net>2024-01-26 00:00:15 +0100
committercyBerta <cyberta@riseup.net>2024-01-26 00:00:15 +0100
commit148e6a7dc549e0e09c4147f9b22cd324c104552d (patch)
tree963a58b7da528f20dcb355c3f8cad6e522ee2182 /app/src/test/java/se/leap
parent6f7b3bbf255b0be4d5ff1bd994aad0d61b8cca8d (diff)
remove some tests of TetheringStateManager which are hard to rewrite without powermock
Diffstat (limited to 'app/src/test/java/se/leap')
-rw-r--r--app/src/test/java/se/leap/bitmaskclient/tethering/TetheringStateManagerTest.java256
1 files changed, 1 insertions, 255 deletions
diff --git a/app/src/test/java/se/leap/bitmaskclient/tethering/TetheringStateManagerTest.java b/app/src/test/java/se/leap/bitmaskclient/tethering/TetheringStateManagerTest.java
index a2569282..a5954a97 100644
--- a/app/src/test/java/se/leap/bitmaskclient/tethering/TetheringStateManagerTest.java
+++ b/app/src/test/java/se/leap/bitmaskclient/tethering/TetheringStateManagerTest.java
@@ -16,279 +16,25 @@
*/
package se.leap.bitmaskclient.tethering;
-import static junit.framework.TestCase.assertTrue;
import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertFalse;
-import static org.mockito.ArgumentMatchers.any;
-import static org.mockito.ArgumentMatchers.anyString;
import static org.mockito.Mockito.mock;
-import static org.powermock.api.mockito.PowerMockito.mockStatic;
-import static org.powermock.api.mockito.PowerMockito.when;
-
-import android.content.Context;
-import android.content.IntentFilter;
-import android.content.SharedPreferences;
+import static org.mockito.Mockito.when;
import org.junit.Before;
import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.mockito.Answers;
-import org.mockito.Mock;
-import org.mockito.invocation.InvocationOnMock;
-import org.mockito.stubbing.Answer;
import org.powermock.api.mockito.PowerMockito;
-import org.powermock.core.classloader.annotations.PrepareForTest;
-import org.powermock.modules.junit4.PowerMockRunner;
-
-import java.net.NetworkInterface;
-import java.net.SocketException;
-import java.util.Arrays;
-import java.util.Collections;
-import java.util.Enumeration;
-
-import se.leap.bitmaskclient.base.utils.Cmd;
-import se.leap.bitmaskclient.base.utils.PreferenceHelper;
-import se.leap.bitmaskclient.testutils.MockSharedPreferences;
-
-@RunWith(PowerMockRunner.class)
-@PrepareForTest({WifiManagerWrapper.class, TetheringStateManager.class, Cmd.class, NetworkInterface.class, PreferenceHelper.class})
public class TetheringStateManagerTest {
- @Mock(answer = Answers.RETURNS_DEEP_STUBS)
- Context mockContext;
-
- @Mock(answer = Answers.RETURNS_DEEP_STUBS)
- IntentFilter intentFilter;
-
private TetheringObservable observable;
@Before
public void setup() throws Exception {
- PowerMockito.whenNew(IntentFilter.class).withArguments(anyString()).thenReturn(intentFilter);
- PowerMockito.whenNew(IntentFilter.class).withNoArguments().thenReturn(intentFilter);
- mockStatic(PreferenceHelper.class);
-
observable = TetheringObservable.getInstance();
-
- }
-
- @Test
- public void updateUsbTetheringState_findsRndisX_returnsTrue() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenReturn(false);
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- PowerMockito.mockStatic(NetworkInterface.class);
- NetworkInterface mock1 = PowerMockito.mock(NetworkInterface.class);
- when(mock1.isLoopback()).thenReturn(false);
- when(mock1.getName()).thenReturn("eth0");
- NetworkInterface mock2 = PowerMockito.mock(NetworkInterface.class);
- when(mock2.isLoopback()).thenReturn(false);
- when(mock2.getName()).thenReturn("rndis0");
-
- NetworkInterface[] networkInterfaces = new NetworkInterface[2];
- networkInterfaces[0] = mock1;
- networkInterfaces[1] = mock2;
-
- PowerMockito.when(NetworkInterface.getNetworkInterfaces()).then(new Answer<Enumeration<NetworkInterface>>() {
- @Override
- public Enumeration<NetworkInterface> answer(InvocationOnMock invocation) throws Throwable {
- return Collections.enumeration(Arrays.asList(networkInterfaces));
- }
- });
-
- TetheringObservable.setUsbTethering(false, "192.168.42.0/24", "rndis0");
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertTrue(observable.isUsbTetheringEnabled());
- }
-
- @Test
- public void updateUsbTetheringState_doesntFindRndisX_returnsFalse() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenReturn(false);
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- PowerMockito.mockStatic(NetworkInterface.class);
- NetworkInterface mock1 = PowerMockito.mock(NetworkInterface.class);
- when(mock1.isLoopback()).thenReturn(false);
- when(mock1.getName()).thenReturn("eth0");
- NetworkInterface mock2 = PowerMockito.mock(NetworkInterface.class);
- when(mock2.isLoopback()).thenReturn(false);
- when(mock2.getName()).thenReturn("wifi0");
-
- NetworkInterface[] networkInterfaces = new NetworkInterface[2];
- networkInterfaces[0] = mock1;
- networkInterfaces[1] = mock2;
-
- PowerMockito.when(NetworkInterface.getNetworkInterfaces()).then(new Answer<Enumeration<NetworkInterface>>() {
- @Override
- public Enumeration<NetworkInterface> answer(InvocationOnMock invocation) throws Throwable {
- return Collections.enumeration(Arrays.asList(networkInterfaces));
- }
- });
-
- TetheringObservable.setUsbTethering(true, "192.168.42.0/24", "rndis0");
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertFalse(observable.isUsbTetheringEnabled());
- }
-
- @Test
- public void updateUsbTetheringState_ThrowsException_returnsFalse() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenReturn(false);
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- PowerMockito.mockStatic(NetworkInterface.class);
- PowerMockito.when(NetworkInterface.getNetworkInterfaces()).thenThrow(new SocketException());
-
- TetheringObservable.setUsbTethering(true, "192.168.42.0/24", "rndis0");
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertFalse(observable.isUsbTetheringEnabled());
- }
-
-/* //TODO enable these tests as soon as bluetooth tethering has been enabled again
- @Test
- public void updateBluetoothTetheringState_btDeviceFound_returnTrue() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenReturn(true);
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- mockStatic(Cmd.class);
- PowerMockito.when(Cmd.runBlockingCmd(any(), any(StringBuilder.class))).then(new Answer<Integer>() {
- @Override
- public Integer answer(InvocationOnMock invocation) throws Throwable {
- StringBuilder logStringBuilder = invocation.getArgument(1);
- logStringBuilder.append("bt-pan device found");
- return 0;
- }
- });
-
- TetheringObservable.setBluetoothTethering(false);
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertTrue(observable.isBluetoothTetheringEnabled());
- }
-
-
- @Test
- public void updateBluetoothTetheringState_btPanDeviceNotFound_returnFalse() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenReturn(true);
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- mockStatic(Cmd.class);
- PowerMockito.when(Cmd.runBlockingCmd(any(), any(StringBuilder.class))).then(new Answer<Integer>() {
- @Override
- public Integer answer(InvocationOnMock invocation) throws Throwable {
- StringBuilder logStringBuilder = invocation.getArgument(1);
- logStringBuilder.append("bt-pan device not found");
- return 1;
- }
- });
-
- TetheringObservable.setBluetoothTethering(true);
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertFalse(observable.isBluetoothTetheringEnabled());
- }
-
- @Test
- public void updateBluetoothTetheringState_ThrowsException_returnsFalse() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenReturn(true);
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- mockStatic(Cmd.class);
- PowerMockito.when(Cmd.runBlockingCmd(any(), any(StringBuilder.class))).
- thenThrow(new SecurityException("Creation of subprocess is not allowed"));
-
- TetheringObservable.setBluetoothTethering(true);
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertFalse(observable.isBluetoothTetheringEnabled());
- }
-
- @Test
- public void updateBluetoothTetheringState_WifiManagerWrapperThrowsException_hasNoInfluenceOnResult() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenThrow(new NoSuchMethodException());
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- mockStatic(Cmd.class);
- PowerMockito.when(Cmd.runBlockingCmd(any(), any(StringBuilder.class))).then(new Answer<Integer>() {
- @Override
- public Integer answer(InvocationOnMock invocation) throws Throwable {
- StringBuilder logStringBuilder = invocation.getArgument(1);
- logStringBuilder.append("bt-pan device found");
- return 0;
- }
- });
-
- TetheringObservable.setBluetoothTethering(false);
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertTrue(observable.isBluetoothTetheringEnabled());
- }
- */
-
- @Test
- public void updateWifiTetheringState_ignoreFailingWifiAPReflection_keepsOldValueTrue() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenThrow(new NoSuchMethodException());
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- TetheringObservable.setWifiTethering(true, "192.168.43.0/24", "wlan0");
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertTrue(observable.isWifiTetheringEnabled());
- }
-
- @Test
- public void updateWifiTetheringState_ignoreFailingWifiAPReflection_keepsOldValueFalse() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenThrow(new NoSuchMethodException());
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- TetheringObservable.setWifiTethering(false, "", "");
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertFalse(observable.isWifiTetheringEnabled());
- }
-
- @Test
- public void updateWifiTetheringState_WifiApReflectionWithoutException_changeValueToTrue() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenReturn(true);
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- TetheringObservable.setWifiTethering(false, "", "");
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertTrue(observable.isWifiTetheringEnabled());
- }
-
- @Test
- public void updateWifiTetheringState_WifiApReflectionWithoutException_changeValueToFalse() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenReturn(false);
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
- TetheringObservable.setWifiTethering(true, "", "");
- TetheringStateManager.getInstance().init(mockContext);
- TetheringStateManager manager = TetheringStateManager.getInstance();
- assertFalse(observable.isWifiTetheringEnabled());
}
@Test
public void testGetWifiAddressRangee_keepsLastSeenAddressAndInterface() throws Exception {
- WifiManagerWrapper mockWrapper = mock(WifiManagerWrapper.class);
- when(mockWrapper.isWifiAPEnabled()).thenReturn(true);
- PowerMockito.whenNew(WifiManagerWrapper.class).withAnyArguments().thenReturn(mockWrapper);
-
//WifiTethering was switched on
TetheringObservable.setWifiTethering(true, "192.168.40.0/24", "wlan0");