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

Sitio alternativo a Cuevana: Moviezet

Sitio alternativo a Cuevana: Moviezet : Nadie se quiere enfrentar al monstruo Cuevana , tan popular por estos días que es casi imposible ver tu serie favorita o tu película sin tener problema de saturación de tráfico. Pero hay proyectos muy sanos y prometedores, sobre todo porque están basados como una muy buena alternativa . Señores estamos hablando obviamente de un sitio alternativo a Cuevana, llamado Moviezet. Como bien dijimos, Moviezet es una excelente alternativa a Cuevana, ya que podremos ver películas y series de forma gratuita sin necesidad de que existan cortes – al mejor estilo Megavideo – y que podremos tener un seguimiento, es decir, si miramos una serie, podremos ver toda la lista con los capítulos disponibles. Lo que tiene de novedoso este sitio web Moviezet , es que tiene películas y series que quizá en Cuevana no se puedan conseguir, pero atención, que puede suceder lo mismo, pero al revés. Entonces aquí intervenimos nosotros y te daremos un sabio consejo, para no

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