Probando paquetes en diferentes versiones de python con tox

Cuando creas un paquete para python y quieres testearlo sobre varias versiones, python2.7, python3.3, etc, es posible hacerlo creando manualmente varios entornos virtuales con virtualenv, uno para cada versión, o automatizar este proceso con tox.

Para instalar tox

pip install tox

Para utilizarlo es necesario crear un archivo de configuración tox.ini

[tox]
envlist = py26, py27
[testenv]
deps=nose
commands=nosetest

Y lanzar tox

tox

En el archivo tox.ini se especifican algunos paramétros como:

  • envlist describe los entornos a utilizar. tox interpreta py26 como python2.6 y py27 como python2.7.
  • deps, las dependencias a instalar en cada entorno.
  • commands comandos a utilizar en cada entorno después de instalar las dependencias.

Cada uno de los entornos creados es independiente entre ellos e independiente del entorno principal del sistema. Ellos son almacenados como entornos virtuales en un directorio llamado .tox, ubicado donde llamamos a tox, son creados la primera vez que tox es ejecutado y reutilizados la siguientes veces, por lo que la primera vez puede tomar un par de segundos más que las siguientes.

Normalmente, además de lanzar los test, me gusta verificar el code style, PEP8, por que lo que en el archivo tox.ini agrego un entorno donde no se ejecutan los test, solo se instala y ejecuta flake8 para verificar el code style.

[tox]
envlist = flake8, py27, py34

[testenv]
deps=nose
commands=nosetest

[testenv:flake8]
deps = flake8
commands = flake8

Referencias

Nodejs, express y Heroku

Este post va dedicado a todos los que aun no han probado servicios para alojar aplicaciones, como Heroku, y a los que quieren comenzar con nodejs en producción.

Cuando quieres levantar una aplicación tienes que considerar varios factores: programación, diseño, configuración del servidor, entre otras cosas.

Puedes asumir toda esa carga o buscar apoyo en servicios ya existentes y enfocarte en lo central: desarrollar tu aplicación.

En este post mostraré como crear una aplicación sencilla con nodejs que retorne un mensaje y como dejarla alojada en Heroku.

pre requisitos

  • nodejs y su gestionador de paquetes npm.
  • Crear una cuenta en Heroku
  • Instalar la gema heroku: gem install heroku
  • Tener algún conocimiento de git.

Si no quieres dedicar mucho tiempo a instalaciones o modificar tu sistema para este ejemplo, puedes usar un entorno de desarrollo en la nube, como nitrous.

Comenzando con nodejs

Primero crearemos un archivo llamado package.json, el cual almacenara información de tu aplicación, para facilitar la creación del mismo podemos usar el comando

npm init

npm preguntara algunas cosas como nombre de la aplicación, descripción, licencia, etc.

Sobre nodejs utilizaremos express

npm install express --save

El argumento --save dejará registrado el paquete instalado como una dependencia, de esta forma, si compartes la aplicación, para instalar las dependencias bastará con usar el comando npm install.

Al ser una aplicación simple que retorna un mensaje, basta con un pequeño script

// index.js
var express = require('express');
var app = express();

app.set('port', (process.env.PORT || 8080))

app.get('/', function(req, res){
  res.json({ mensaje: 'Un ejemplo de nodejs, express y Heroku'});
});

app.listen(app.get('port'));

Como un detalle preferí que el mensaje fuera retornado en JSON.

Verificamos que todo funcione como esperamos lanzando nuestra app

node index.js

Deberíamos poder ver el resultado en

http://localhost:8080

Si todo funciona bien hacemos un commit con nuestros archivos

git add index.js package.json
git commit -m "primer commit"

Subiendo todo a Heroku

Teniendo instalada la gema de Heroku, es necesario logearnos con nuestras credenciales

heroku login

Al subir la aplicación, Heroku debe poder determinar como iniciarla, esto se específica creando el archivo Procfile con la siguiente linea

web: node index.js

Y lo agregamos al repositorio

git add Procfile
git commit -m "Procfile agregado"

Sólo nos queda crear la app en heroku

heroku create

Lo cual mostrará la url donde estará alojada nuestra app y agregará el remoto heroku al repositorio local.

Ahora podemos subir los cambios a Heroku

git push heroku master

Cada vez que hagamos push a la rama master de Heroku, nuestros cambios serán publicados.

Más detalles se pueden encontrar en el sitio de Getting started de Heroku.

Un buen tutorial para continuar es Build a RESTful API Using Node and Express 4.

Referencias