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

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 ...

El meu editor de codi preferit el 2024, que això ja se sap que va canviant 😄

Visual Code Visual Code és un editor de codi font lleuger, però potent que s’executa al teu escriptori i està disponible per a Windows, macOS i Linux. Compta amb suport integrat per a JavaScript, TypeScript i Node.js i té un ric ecosistema d’extensions per a altres llenguatges i entorns d’execució (com C++, C#, Java, Python, PHP, Go, .NET).  És una eina ideal per a desenvolupar i depurar aplicacions web i en el núvol. Per què Visual Code? Visual Code té molts avantatges com a editor de codi font, com per exemple: És gratuït, ràpid i fàcil d’instal·lar i actualitzar. Té un ampli ecosistema d’extensions que et permeten afegir funcionalitats i personalitzar la teva experiència de desenvolupament. Té un suport integrat per a molts llenguatges i entorns d’execució, i et permet depurar i executar el teu codi des del mateix editor. Té una interfície senzilla i elegant, amb diferents temes i modes de visualització. Té un sistema de sincronització de configuracions que et permet guardar les...

Las Mejores Aplicaciones Gratis para iPad de 2012

Las Mejores Aplicaciones Gratis para iPad de 2012 : ¿No tienes ni un duro? No te preocupes, pues hoy os traemos una extensa selección de las mejores apps gratuitas que puedes conseguir en la App Store para que llenes tu iPad de calidad, sin gastar nada de nada.   ¿Estás buscando juegos o apps gratis para tu iPad? En la App Store hay más de 500,000 apps y juegos, y una gran cantidad de ellos está disponible de forma totalmente gratuita. Aquí vamos con la selección de las mejores Apps gratis para iPad (todos los modelos), organizada por categoría. ¿Estás preparado? Las Mejores Apps Gratis de Redes Sociales para iPad Nombre Facebook Gratis Categoría Redes sociales Facebook es la red social más famosa del mundo , con casi mil millones de usuarios. Su app para iPad ha tardado, pero aquí está. Nombre Twitter Gratis Categoría Redes sociales Twitter es la red de microblogging por excelencia. La forma más rápida y directa de informar y mantenerse informado de las cosa...