Passa al contingut principal

Koalite: Depurar PhoneGap/Cordova en Android con adb

Por mucho que apliquemos buenas prácticas, escribamos tests unitarios y tratemos de hacer las cosas bien, antes o después llega un momento en que no nos va queda más remedio que mancharnos las manos y depurar las aplicaciones.


En el caso de aplicaciones desarrollados con PhoneGap/Cordova no es sencillo depurar la aplicación y tenemos que conformarnos con herramientas más básicas que las que solemos emplear en otros entornos.


Cuando estuve contando cómo crear un plugin para Cordova, decía que la arquitectura general de Cordova era algo así:


Arquitectura de PhoneGap/Cordova

Esto quiere decir que realmente para depurar una aplicación desarrollada Cordova tenemos que poder depurar dos cosas distintas, la parte nativa y la parte HTML/JS.


Depurando la parte nativa


La parte nativa es la que menos problemas supone a la hora de depurar. Primero, porque a menos que estés desarrollando un plugin, es poco probable que necesites depurar nada. Segundo, porque para depurarla puedes utilizar las herramientas propias de cada plataforma.


En el caso de Android, para depurar la parte nativa puedes utilizar las herramientas de depuración de Eclipse y el plugin para desarrollo en Android.


Depurando la parte Javascript


Por degracia para ti cuando te toque depurar, la mayor parte de la complejidad de una aplicación Cordova reside en el código Javascript.


En un PC hay herramientas muy buenas para depurar Javascript y, en general, sólo con los propias opciones de desarrollo incluidas en los navegadores suele bastar. Sin embargo, en un dispositivo Andriod esta parte es mucho más complicada de depurar que la parte nativa, y de hecho no conozco un depurador “de verdad” que lo permita, sólo herramientas que nos pueden ser más o menos útiles.


Ya hablé en una ocasión de weinre, un sistema que nos permite inspeccionar páginas HTML de forma remota y que puede resultar bastante práctico.


Otra opción es ir mostrando en consola mensajes que nos ayuden a trazar la aplicación. Es un sistema feo, manual, tedioso y arcaico, pero a veces poder escribir un console.log(‘ha pasado algo’) es mejor que nada. Por lo menos es más cómodo que ir escribiendo alerts.


La cuestión es, ¿cómo podemos ver lo que se escribe con console.log?


En el caso de Android, existe un log global del sistema, al estilo del /var/log/messages de cualquier distribución linux. Cordova utiliza ese log para ir almacenando tanto sus propios mensajes de funcionamiento, como los mensajes que podamos escribir desde javascript usando console.log.


Para consultar el log, podemos recurrir a la herramienta adb , que está incluida en el SDK de android y nos permite ver en tiempo real el log del dispositivo usando el siguiente comando:



adb logcat

Este comando accederá al teléfono que esté conectado (o al emulador) y mostrará en pantalla el log que se va generando en tiempo real:


LogCat



Como se puede ver, el log incluye todo lo que está pasando en el teléfono, lo que hace que sea un poco complicado de seguir. Aun así, en la zona marcada con el recuadro rojo aparece al parte específica de Cordova, avisando de un error en uno de los ficheros javascript de la aplicación.


Se puede obtener un log más limpio usando los filtros de adb logcat :



adb logcat Cordova:D DroidGap:D CordovaLog:D *:S

El formato de los filtros es origen:nivel. En este caso, estamos indicando que para los orígenes Cordova, DroidGap y CordovaLog se muestren todos los mensajes a partir de nivel D (DEBUG) y para el resto de logs (*), se silencien los mensajes (S). Con esto el log queda mucho más legible:




LogCat filtered

La línea marcada en rojo en la imagen anterior se corresponde con una llamada a console.log desde el código de nuestra aplicación.


Resumen


La depuración de aplicaciones desarrolladas con Cordova es un poco complicada. La parte nativa de la aplicación se puede depurar usando las herramientas normales de desarrollo para cada plataforma, pero la parte javascript requiere el uso de técnicas más enrevesadas o menos prácticas, con herramientas como weinre o el uso de adb y llamadas console.log como hemos visto en este post.



Compartir:

Facebook Twitter Email Linkedin Plusone

Posts relacionados:



  1. Extender PhoneGap/Cordova creando un plugin

  2. PhoneGap/Cordova por línea de comandos

  3. Acceso a recursos externos con PhoneGap/Cordova






via Planeta Código http://blog.koalite.com/2012/09/depurar-phonegapcordova-en-android-con-adb/?utm_source=feedburner&utm_medium=feed&utm_campaign=Feed%3A+KoalitesBlog+%28Koalite%29

Comentaris

Entrades populars d'aquest blog

10 alternativas a Cuevana para ver películas online

10 alternativas a Cuevana para ver películas online : Durante este último tiempo, en Cuevana se sucedieron varios “problemas” por los cuales hubo que ajustar algunas cosas antes de tiempo (como el rediseño del sitio), que dejaron a algunos usuarios ciertos problemas para acceder a las películas o series del portal. Pero realmente esto es algo que no incumbe a los usuarios y, como sabemos, existen muchas otras alternativas a Cuevana dando vueltas por Internet, que intentaremos presentar aquí mismo. Los sitios que repasaremos funcionan del mismo modo que Cuevana, mediante la instalación de un plugin que permite visualizar los videos de Megaupload o WUShare, entre otros servicios, en una calidad de imágen realmente excelente. Tal como sucede con el más popular servicio, todos ellos tienen publicidad que en algunos casos resulta insoportable, pero como dice Federico en DotPod “a caballo regalado no se le miran los dientes”. Alternativas a Cuevana 1. Moviezet Posiblemente el mejor clon d...

Learn Composition from the Photography of Henri Cartier-Bresson

“Do you see it?” This question is a photographic mantra. Myron Barnstone , my mentor, repeats this question every day with the hopes that we do “see it.” This obvious question reminds me that even though I have seen Cartier-Bresson’s prints and read his books, there are major parts of his work which remain hidden from public view. Beneath the surface of perfectly timed snap shots is a design sensibility that is rarely challenged by contemporary photographers. Henri Cartier-Bresson. © Martine Franck Words To Know 1:1.5 Ratio: The 35mm negative measures 36mm x 24mm. Mathematically it can be reduced to a 3:2 ratio. Reduced even further it will be referred to as the 1:1.5 Ratio or the 1.5 Rectangle. Eyes: The frame of an image is created by two vertical lines and two horizontal lines. The intersection of these lines is called an eye. The four corners of a negative can be called the “eyes.” This is extremely important because the diagonals connecting these lines will form the breakdown ...

Más de 50 de las mejores herramientas online para profesores

No es una exageración afirmar que hay ciento de aplicaciones educativas por ahí por la red, para todos los gustos y de todos los colores, por lo que es difícil tratar de recogerlas todas en un listado. Sin embargo, algunas destacan más que otras por su innovación y por su capacidad para conseguir adeptos, y esas son las que protagonizan la presente recopilación. Son 50 interesantes herramientas online basadas en las recopilaciones de EduArea , las muchas ya tratadas en Wwwhat’s new y las destacadas por la experiencia. 1. Dropbox : Un disco duro virtual con varios GB gratuitos y al que se accede desde casi cualquier dispositivo. Sin embargo, es muchísimo más que eso, de hecho ya comentamos 20 razones . 2. Google Drive : La evolución de Google Docs que suma a sus múltiples herramientas de creación de documentos, un considerable espacio virtual gratuito. 3. CloudMagic : Una extensión y una app multidispositivo para buscar información simultáneamente en Gmail, Twitter, Facebook, Evernote ...