Instalar entorno para Tests Unitarios en cakePhp 2 (macosx)

 

cakePhp

Una peculiaridad de cakePhp2, es que Usa PhpUnit para la creación de test, y no viene instalada.

Al usar Mamp como servidor local, era algo complicado la instalación de PhpUnit en un projecto en cakePhp, encontré el siguiente Plugin que nos ayuda: https://github.com/Hyra/PHPUnit-Cake2 Gracías a Stef van den Ham.

Como instalar este vendor:

  1. Descargar el zip y descomprimirla en tu proyecto en la carpeta Plugin o bien ejecutar el siguiente código en tu proyecto “git clone https://github.com/Hyra/PHPUnit-Cake2 app/Plugin/Phpunit”
  2. Ejecutar el siguiente código en tu consola dentro de tu proyecto “cake Phpunit.Phpunit install”, si no tienes configurado en el path cake, puede ayudarte este video , recomendamos que se instale en la opción 1 “app/vendors”.
  3. En tu archivo bootstrap.php añade al final “CakePlugin::loadAll();” para que se carguen todos los plugins o bien “CakePlugin::load(‘Phpunit’);” para cargar solo el plugin phpunit.
  4. Con estos pasos ya tiene instalado el entorno de testing con phpUnit, que funcionará en otros sistemas operativos.

 

 

Sublime Text 2

 

Código, Herramientas

Ya llevo unos meses, con el editor de código Sublime Text 2, y me ha hecho olvidar el resto que he usado (Coda, Espresso, Komodo Edit, Eclipse).

Me gustaría comentar alguno de los plugins que estoy utilizando en Sublime, que recomiendo.

 

Zend Code
Plugin para escribir código Html de una manera rápida y eficaz.
http://code.google.com/p/zen-coding/downloads/list

 

Trailing spaces
Plugin en el que ves espacios en blanco que nos dejamos programando, y eliminarlos.
https://github.com/SublimeText/TrailingSpaces

 

Sublime Linter
Un de las características de este plugin , es localizar error en tu código, si hay algo que no has cerrado …
https://github.com/Kronuz/SublimeLinter

 

Package Control
El primer plugin a instalar, para poder instalar el resto de plugins con gran facilidad.
http://wbond.net/sublime_packages/package_control

Review del libro No Me Hagas Pensar

 

Libros

No me hagas pensar de Steve Krug es un buen libro para desarrolladores, diseñadores, ejecutivos, etc.. sobre usabilidad web.

Es cierto que muchos de los ejemplos en el libro son bastante antiguos, pero lo sorprendente es que a día de hoy son ejemplos válidos.

Es un libro que lleva la usabilidad web al público en general, cualquiera de los que nos dedicamos a la web, con un pelín de esfuerzo podemos llevarlo a acabo y conocer mejor el valor de la usabilidad. Mi problema normalmente no es que  me de cuenta, es que el cliente no me da tiempo para ello, o no quiere pagarlo, quizás es un buen libro para regalar a clientes.

Píldora – Traducción de fechas en cakephp 2.0.

 

cakePhp

Si usamos el Helper Form para construir nuestro formularios, cuando tenemos un campo fecha, los meses no salen en inglés. ¿Como traducir esto?

Primero fijarnos en el Helper Form, como están construidos los textos traducibles

__d('cake', 'January');

Viendo en el código vemos que el archivo que va a buscar las traducciones no es el default.po ( como en otras versiones de cakePhp, sino uno llamado cake.po, habría que crear este archivo con las traducciones de todos los meses o descargar el que tengo hecho.

El último paso para que esto funcione, es configurar el cakePhp para que el idioma definido sea castellano.

Para probar ponemos el siguiente código en el controlador que necesitemos esa traducción.

Configure::write('Config.language', 'spa');

Píldora – Usar paginación con varios modelos en cakephp.

 

cakePhp

A veces en cakePhp nos encontramos con que queremos usar varios modelos en un mismo controlador, y paginar los modelos.
y como es algo que me ha surgido varias veces, y siempre me tengo que para a pensar, lo dejo colgado en el blog, como una pequeña píldora.

Decimos que queremos usar dos modelos.

public $uses = array( 'User', 'Profile');

En lo que siempre fallo es que pongo $this->paginate(); pero si hay varios modelos tengo que decir que modelo quiero paginar, sino por defecto siempre será el primero en la array $uses.

un ejemplo:

public function Profile() {
		$this->Profile->recursive = -1;
		$this->set('profile', $this->paginate('Profile'));
}

Review del libro Diseño ágil con TDD

 

Libros

Me he leido el libro Diseño ágil con TDD. Me ha gustado mucho la primera parte del libro algo más teórica, hablando más sobre porqué usar tests, la segunda parte del libro más práctica para mi fue algo más aburrida ya que tenía experiencia en la creación de tests.

Es un libro recomendado para todos los programadores con un nivel medio /alto, Y que quieran mejorar en sus prácticas de programación.

Puedes encontrar este libro en su web oficial http://www.dirigidoportests.com/el-libro , gratuito en su edición online, también cuenta con una edición impresa.

Píldora – Usar helpers en cakePhp y pasar html.

 

Uncategorized

Voy a empezar a crear de vez en cuando posts muy cortos con un apunte una píldora, ya que ha veces me veo buscando como se hacía algo muy sencillo, que ya he hecho con anterioridad, y me pregunto porque no lo subí a mi blog.

Aquí va la primera. A veces en Cakephp nos vemos con la necesidad de pasar código html en un link o en un paginador .. usando los helpers de cake, necesitamos hacer escape, un ejemplo:

//paginación
echo $this->Paginator->prev('', array('escape' => false), null, array('class' => 'prev disabled'));
//link
echo $this->Html->link('', '/pages/home', array('escape' => false));

“deldan” Recomienda (22-01-12)

 

Recomienda

Formularios en HTML5

 

Código

Una de las mejoras en el nuevo Estandar HTML5 aún en desarrollo, está en los Formularios, es cierto que no todos los navegadores tiene la posibilidad de ejecutar correctamente todas las funciones de HTML5, pero es bueno empezar a usar muchas de sus funciones para los navegadores más modernos, nos ahorran mucho trabajo, y siempre hay herramientas como modernizr que nos ayudarán con los navegadores que no soportan HTML5.

Placeholder

Un nuevo atributo que sirve para poner texto dentro de un input cuando está vacío, y que al tabular o pulsar dentro del input desaparezca ese mismo texto, antes para hacer esto había que usar javascript.

<input type="text" placeholder="texto ejemplo">

Autofocus

Nos ayuda a definir que input va a quedar marcado, enfocado, cuando se cargue la página.

<input id="buscar" type="text" autofocus>

Required

Un nuevo atributo que apunta que campos tiene que estar rellenos antes de enviar el formulario, para hacer esto había que crear javascript algo largo dependiendo tipos de campos y las comprobaciones que hacíamos.

<input type="text" name="usr_name" required="required" />

Nuevos tipos de inputs

Tipo search, un input en el que el texto visualmente se le añade una x parar borrar el texto.

<input type="search" name="buscar" />

Tipo email, un input en el que el texto tiene que ser un email.

<input type="email" name="email" />

Tipo url, un input en el que el texto tiene que ser un url

<input type="url" name="miweb" />

Tipo number, con los atributos min, max, y step, nos ayuda a seleccionar un número.

<input type="number" max="10" min="0" step="2" name="minumero" />

Tipo range, similar a number con los mismos atributos, pero visualmente es similar a un slide.

<input type="range" max="10" min="0" step="2" name="minumero" />

En fechas hay varios date, mounth, week, time, datetime.