El objetivo de este proyecto es realizar una prueba técnica en una aplicación web Ruby on Rails con una arquitectura similar a la de https://savy.co.
Para empezar a trabajar el ejercicio haz un fork de este repositorio en tu cuenta de github como se indica en este link
Si ya tienes configurado un ambiente de desarrollo de Ruby on Rails puedes saltarte este paso,de lo contrario puedes elegir entre realizar el desarroll en un ambiente Cloud, o instalar localmente las dependencias del proyecto.
Para comenzar a trabajar en el ejercicio sin realizar la instalación local del ambiente de Ruby on Rails, se recomienda usar Cloud 9 IDE.
Una vez hayas hecho el fork del proyecto en tu github, podrás entrar a Cloud 9 y sincronizar el respositorio con el ambiente de desarrollo virtual.
Seguir las instrucciones de este link (https://gorails.com/setup/ubuntu/18.10)
Seguir las instrucciones de este link (https://gorails.com/setup/osx/10.13-high-sierra)
-
Instalar ruby: windows
-
Desde la consola de comandos en modo administrador instalar bundler:
gem install bundler
-
Desde la consola de comandos en modo administrador instalar bundler:
gem install rails 5.2.1
-
Instalar SQLLite3 siguiendo estas indicaciones (https://www.tutorialspoint.com/sqlite/sqlite_installation.htm)
El proyecto de pruebas se entrega en estado funcional, con datos iniciales y con sus respectivas pruebas unitarias, de integración y de sistema.
Para iniciar el proyecto se deben seguir los siguientes pasos:
-
Descargar el código
git clone https://github.com/usuario-github/xavy.git
-
Crear la base de datos
rails db:create
-
Ejecutar las migraciones
rails db:migrate
-
Cargar los datos de prueba
rails db:seed
-
Ejecutar la aplicación
rails server
-
Entrar a http://localhost:3000 para ver la aplicación
-
Entrar a http://localhost:3000/admin para ver el panel de administrador
Comandos adicionales:
- Ejecutar las pruebas unitarias
rails test
- Abrir la consola de rails (permite ejecutar comandos usando las clases definidas dentro del proyecto)
rails console
PD: Antes de ejecutar las pruebas unitarias se debe crear/actualizar la base de datos de pruebas
rails db:create RAILS_ENV=test
rails db:migrate RAILS_ENV=test
Nota respecto a la base de datos: El proyecto está configurado para usar la base de datos sqlite3 ya que es la base de datos que requiere menos configuración. Si prefieres trabajar con alguna de las otras bases de datos disponibles en Rails, recuerda cambiar el archivo config/database.yml
y actualizar el Gemfile
para usar la librería correcta:
Ejemplo: Gemfile
# Reemplazar sqlite3 por pg
gem 'pg'
#gem 'sqlite3', git: "https://github.com/larskanis/sqlite3-ruby", branch: "add-gemspec"
Ejemplo: database.yml usando postgresql.
# config/database.yml
default: &default
adapter: postgresql
encoding: unicode
pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
development:
<<: *default
database: savy_development
# The specified database role being used to connect to postgres.
# To create additional roles in postgres see `$ createuser --help`.
# When left blank, postgres will use the default role. This is
# the same name as the operating system user that initialized the database.
#username: savy
# The password associated with the postgres role (username).
#password:
test:
<<: *default
database: savy_test
production:
<<: *default
database: savy_production
username: deploy
password: <%= ENV['SAVY_DATABASE_PASSWORD'] %>
Xavy.com es un directorio de centros de Fitness and Wellness. La aplicación está estructurada en dos partes. Una parte pública donde de pueden consultar los distintos centros con sus respectivas actividades y una parte para que los administradores de la aplicación puedan actualizar la información de los centros.
Por petición de nuestros usuarios, se quiere permitir que los centros deportivos puedan seleccionar entre las dificultadoes (bajo, medio, alto para cada) de las actividades. Igualmente los usuarios deben poder consultar la dificultad de cada actividad desde el directorio.
Igualmente se quiere poder "taggear" las distintas actividades con una o más categorías para que los usuarios puedan poner en contexto los nombres de las distintas actividades que ofrecen loscentros. Estas categorías se deben crear a través de la interfaz del administrador y se deben poder asignar a las actividades.
El desarrollo de los requerimientos es libre. No hay marcas de #TODO, ni sitos específicos donde se debe escribir el código. Cada persona está en libertad de desarrollar la solución que le parezca apropiada. Lo importante es la justificación. Si se considera necesario se permite agregar librerías tanto en ruby como en javascript para completar el ejercicio.
El código del ejercicio se debe sincronizar con la copia personal del proyecto en github y enviar el link a sistemas(at)savy.co.
Opcionalmente se puede hacer un despliegue (gratuito) a heroku e inlcuir la URL del proyecto par que sea más fácil revisarlo.