[tor-commits] [orbot/master] Fixes #366 Prevents multiple HostTests from running concurrently and closes any ongoing

n8fr8 at torproject.org n8fr8 at torproject.org
Mon Aug 24 21:02:52 UTC 2020


commit aa8a53258eb01a0f0467d5f6132f672655264bfc
Author: bim <dsnake at protonmail.com>
Date:   Sun Jul 19 14:22:12 2020 -0400

    Fixes #366 Prevents multiple HostTests from running concurrently and closes any ongoing
    network requests once the BridgeWizardActivity loses focus
---
 app/src/main/AndroidManifest.xml                   |  7 +++-
 .../ui/onboarding/BridgeWizardActivity.java        | 46 +++++++++++++++++-----
 2 files changed, 42 insertions(+), 11 deletions(-)

diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index 43109382..fa7a54d4 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -104,7 +104,10 @@
             android:name=".ui.onboarding.OnboardingActivity"
             android:configChanges="orientation|screenSize|screenLayout" />
 
-        <activity android:name=".ui.onboarding.BridgeWizardActivity" />
+        <activity
+            android:name=".ui.onboarding.BridgeWizardActivity"
+            android:configChanges="orientation|screenSize" />
+
         <activity
             android:name=".ui.onboarding.MoatActivity"
             android:windowSoftInputMode="stateHidden" />
@@ -172,4 +175,4 @@
 
     </application>
 
-</manifest>
\ No newline at end of file
+</manifest>
diff --git a/app/src/main/java/org/torproject/android/ui/onboarding/BridgeWizardActivity.java b/app/src/main/java/org/torproject/android/ui/onboarding/BridgeWizardActivity.java
index 3fae30d3..27f24164 100644
--- a/app/src/main/java/org/torproject/android/ui/onboarding/BridgeWizardActivity.java
+++ b/app/src/main/java/org/torproject/android/ui/onboarding/BridgeWizardActivity.java
@@ -8,6 +8,7 @@ import android.text.TextUtils;
 import android.util.Log;
 import android.view.MenuItem;
 import android.view.View;
+import android.widget.CompoundButton;
 import android.widget.RadioButton;
 import android.widget.TextView;
 
@@ -30,6 +31,8 @@ public class BridgeWizardActivity extends AppCompatActivity {
     private static int MOAT_REQUEST_CODE = 666;
 
     private static TextView mTvStatus;
+    private static HostTester runningHostTest;
+
     private RadioButton mBtDirect;
     private RadioButton mBtObfs4;
     private RadioButton mBtMeek;
@@ -71,23 +74,27 @@ public class BridgeWizardActivity extends AppCompatActivity {
         });
 
         mBtObfs4 = findViewById(R.id.btnBridgesObfs4);
-        mBtObfs4.setOnClickListener(v -> {
+        mBtObfs4.setOnCheckedChangeListener((buttonView, isChecked) -> {
+            if (!isChecked) return;
             Prefs.setBridgesList("obfs4");
             Prefs.putBridgesEnabled(true);
             testBridgeConnection();
         });
 
-
         mBtMeek = findViewById(R.id.btnBridgesMeek);
-        mBtMeek.setOnClickListener(v -> {
+        mBtMeek.setOnCheckedChangeListener((buttonView, isChecked) -> {
+            if (!isChecked) return;
             Prefs.setBridgesList("meek");
             Prefs.putBridgesEnabled(true);
             testBridgeConnection();
         });
 
-
         mBtCustom = findViewById(R.id.btnCustomBridges);
-        mBtCustom.setOnClickListener(view -> startActivity(new Intent(BridgeWizardActivity.this, CustomBridgesActivity.class)));
+        mBtCustom.setOnCheckedChangeListener((buttonView, isChecked) -> {
+            if (isChecked) return;
+            cancelHostTestIfRunning();
+            startActivity(new Intent(BridgeWizardActivity.this, CustomBridgesActivity.class));
+        });
     }
 
     @Override
@@ -130,15 +137,19 @@ public class BridgeWizardActivity extends AppCompatActivity {
 
 
     private void testBridgeConnection() {
+        cancelHostTestIfRunning();
+        HostTester hostTester = new HostTester();
         if (TextUtils.isEmpty(Prefs.getBridgesList()) || (!Prefs.bridgesEnabled())) {
-            new HostTester().execute("check.torproject.org", "443");
+            hostTester.execute("check.torproject.org", "443");
         } else if (Prefs.getBridgesList().equals("meek")) {
-            new HostTester().execute("meek.azureedge.net", "443", "d2cly7j4zqgua7.cloudfront.net", "443");
+            hostTester.execute("meek.azureedge.net", "443", "d2cly7j4zqgua7.cloudfront.net", "443");
         } else if (Prefs.getBridgesList().equals("obfs4")) {
-            new HostTester().execute("85.17.30.79", "443", "154.35.22.9", "443", "192.99.11.54", "443");
+            hostTester.execute("85.17.30.79", "443", "154.35.22.9", "443", "192.99.11.54", "443");
         } else {
+            hostTester = null;
             mTvStatus.setText("");
         }
+        if (hostTester != null) runningHostTest = hostTester;
     }
 
     private class HostTester extends AsyncTask<String, Void, Boolean> {
@@ -153,10 +164,10 @@ public class BridgeWizardActivity extends AppCompatActivity {
         protected Boolean doInBackground(String... host) {
             // Background Code
             for (int i = 0; i < host.length; i++) {
+                if (isCancelled()) return null;
                 String testHost = host[i];
                 i++; //move to the port
                 int testPort = Integer.parseInt(host[i]);
-
                 if (isHostReachable(testHost, testPort, 10000)) {
                     return true;
                 }
@@ -168,6 +179,7 @@ public class BridgeWizardActivity extends AppCompatActivity {
         @Override
         protected void onPostExecute(Boolean result) {
             // Post Code
+            runningHostTest = null;
             if (result) {
                 mTvStatus.setText(R.string.testing_bridges_success);
             } else {
@@ -184,6 +196,13 @@ public class BridgeWizardActivity extends AppCompatActivity {
         super.onSaveInstanceState(savedInstanceState);
     }
 
+    @Override
+    public void onDestroy() {
+        cancelHostTestIfRunning();
+        mTvStatus = null;
+        super.onDestroy();
+    }
+
     @SuppressWarnings("SameParameterValue")
     private static boolean isHostReachable(String serverAddress, int serverTCPport, int timeoutMS) {
         boolean connected = false;
@@ -216,4 +235,13 @@ public class BridgeWizardActivity extends AppCompatActivity {
             mBtCustom.setChecked(true);
         }
     }
+
+    private static void cancelHostTestIfRunning() {
+        if (runningHostTest != null) {
+            runningHostTest.cancel(true);
+            runningHostTest = null;
+        }
+    }
+
+
 }





More information about the tor-commits mailing list