Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Detecting limited network connectivity in Android?

There are a number of questions regarding how to detect network connectivity in Android. https://stackoverflow.com/a/4239019/90236 provides a very detailed answer and https://stackoverflow.com/a/8548926/90236 shows methods to identify the type of network to which one is connected.

We detect network connectivity using code similar to those answers like:

private boolean isNetworkAvailable() {
    ConnectivityManager connectivityManager 
          = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
    NetworkInfo activeNetworkInfo = connectivityManager.getActiveNetworkInfo();
    return activeNetworkInfo != null && activeNetworkInfo.isConnected();
}

This lets us warn a user if they are offline. However, it doesn't help us identify if a user has limited connectivity. There are conditions of limited connectivity that have caused users to complain. These include:

  1. Users are connected to a home wifi network but the cable modem or Internet service is unavailable.

  2. Users are in a hotel or coffee shop and successfully connect to a wifi network, but the network requires that they login or agree to terms of service before they are given full network access.

In both of these situations our isNetworkAvailable() test returns true. The OS tells us we are connected to a network. However, the user does not have usable Internet connectivity.

Is there a good way to determine that the user has a fully functioning network connection?

I'm considering calling a lightweight web service to verify their connectivity and warn the user if the app doesn't get a valid return from the service. Is this overkill? or have others had to resort to similar techniques?

like image 224
Michael Levy Avatar asked Jul 23 '13 22:07

Michael Levy


1 Answers

Is there a good way to determine that the user has a fully functioning network connection?

Try downloading something from somewhere. Ideally, the "somewhere" is your own server, to test connectivity between the device and your server.

Alas, there are no doesTehConnexionSuck() or iCanHazBandwidth() methods on ConnectivityManager. :-)

Is this overkill?

In the spirit of "Goldilocks and the Three Bears", I'd describe that as justrightkill.

We have to do the same sorts of shenanigans in Web apps too.

like image 169
CommonsWare Avatar answered Oct 02 '22 05:10

CommonsWare