[Photon] Android Particle app crash when loading wifi list (io.particle.android.app E/AndroidRuntime: FATAL EXCEPTION: ModernAsyncTask)

The Android Particle app has no issue detecting the Photon but when it try to load the wifi list, it will crash. Looking at the log, there seems to be a bug related to the Particle app. I have tried this app using Android 4.4.4, 6.0.1 and N Preview 3 - none worked. Here’s the stack trace.

05-27 14:53:13.730 27616-27663/io.particle.android.app E/AndroidRuntime: FATAL EXCEPTION: ModernAsyncTask #2
                                                                     Process: io.particle.android.app, PID: 27616
                                                                     java.lang.RuntimeException: An error occurred while executing doInBackground()
                                                                         at android.support.v4.content.ModernAsyncTask$3.done(ModernAsyncTask.java:142)
                                                                         at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
                                                                         at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
                                                                         at java.util.concurrent.FutureTask.run(FutureTask.java:242)
                                                                         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
                                                                         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
                                                                         at java.lang.Thread.run(Thread.java:841)
                                                                      Caused by: com.google.gson.JsonSyntaxException: com.google.gson.stream.MalformedJsonException: Unterminated object at line 2 column 906 path $.scans[13].ssid
                                                                         at com.google.gson.Gson.fromJson(Gson.java:829)
                                                                         at com.google.gson.Gson.fromJson(Gson.java:779)
                                                                         at com.google.gson.Gson.fromJson(Gson.java:728)
                                                                         at com.google.gson.Gson.fromJson(Gson.java:700)
                                                                         at io.particle.android.sdk.devicesetup.commands.CommandClient.readResponse(CommandClient.java:129)
                                                                         at io.particle.android.sdk.devicesetup.commands.CommandClient.sendAndMaybeReceive(CommandClient.java:83)
                                                                         at io.particle.android.sdk.devicesetup.commands.CommandClient.sendCommandAndReturnResponse(CommandClient.java:57)
                                                                         at io.particle.android.sdk.devicesetup.loaders.ScanApCommandLoader.loadInBackground(ScanApCommandLoader.java:65)
                                                                         at io.particle.android.sdk.devicesetup.loaders.ScanApCommandLoader.loadInBackground(ScanApCommandLoader.java:26)
                                                                         at android.support.v4.content.AsyncTaskLoader.onLoadInBackground(AsyncTaskLoader.java:296)
                                                                         at android.support.v4.content.AsyncTaskLoader$LoadTask.doInBackground(AsyncTaskLoader.java:54)
                                                                         at android.support.v4.content.AsyncTaskLoader$LoadTask.doInBackground(AsyncTaskLoader.java:42)
                                                                         at android.support.v4.content.ModernAsyncTask$2.call(ModernAsyncTask.java:128)
                                                                         at java.util.concurrent.FutureTask.run(FutureTask.java:237)
                                                                         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
                                                                         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
                                                                         at java.lang.Thread.run(Thread.java:841) 
                                                                      Caused by: com.google.gson.stream.MalformedJsonException: Unterminated object at line 2 column 906 path $.scans[13].ssid
                                                                         at com.google.gson.stream.JsonReader.syntaxError(JsonReader.java:1573)
                                                                         at com.google.gson.stream.JsonReader.doPeek(JsonReader.java:495)
                                                                         at com.google.gson.stream.JsonReader.hasNext(JsonReader.java:418)
                                                                         at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:211)
                                                                         at com.google.gson.internal.bind.TypeAdapterRuntimeTypeWrapper.read(TypeAdapterRuntimeTypeWrapper.java:40)
                                                                         at com.google.gson.internal.bind.ArrayTypeAdapter.read(ArrayTypeAdapter.java:72)
                                                                         at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.read(ReflectiveTypeAdapterFactory.java:117)
                                                                         at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:217)
                                                                         at com.google.gson.Gson.fromJson(Gson.java:814)
                                                                         at com.google.gson.Gson.fromJson(Gson.java:779) 
                                                                         at com.google.gson.Gson.fromJson(Gson.java:728) 
                                                                         at com.google.gson.Gson.fromJson(Gson.java:700) 
                                                                         at io.particle.android.sdk.devicesetup.commands.CommandClient.readResponse(CommandClient.java:129) 
                                                                         at io.particle.android.sdk.devicesetup.commands.CommandClient.sendAndMaybeReceive(CommandClient.java:83) 
                                                                         at io.particle.android.sdk.devicesetup.commands.CommandClient.sendCommandAndReturnResponse(CommandClient.java:57) 
                                                                         at io.particle.android.sdk.devicesetup.loaders.ScanApCommandLoader.loadInBackground(ScanApCommandLoader.java:65) 
                                                                         at io.particle.android.sdk.devicesetup.loaders.ScanApCommandLoader.loadInBackground(ScanApCommandLoader.java:26) 
                                                                         at android.support.v4.content.AsyncTaskLoader.onLoadInBackground(AsyncTaskLoader.java:296) 
                                                                         at android.support.v4.content.AsyncTaskLoader$LoadTask.doInBackground(AsyncTaskLoader.java:54) 
                                                                         at android.support.v4.content.AsyncTaskLoader$LoadTask.doInBackground(AsyncTaskLoader.java:42) 
                                                                         at android.support.v4.content.ModernAsyncTask$2.call(ModernAsyncTask.java:128) 
                                                                         at java.util.concurrent.FutureTask.run(FutureTask.java:237) 
                                                                         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
                                                                         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
                                                                         at java.lang.Thread.run(Thread.java:841)

Looks like we might be getting back bad wifi scan data from the device. Is this still happening?