Bienvenido al primer proyecto del grupo Ruby on Rails en español
Para empezar solo recuerda:
Accedé al grupo en slack, puedes solicitar una invitación aquí.
Quienes no esten familiarizados con el uso de Git, pueden seguir las siguientes instrucciones para clonar el proyecto y poder contribuir al mismo
- Asegúrate de tener tú entorno de desarrollo con todas las configuraciones requeridas.
- Haz un fork del proyecto original y clona el proyecto desde tu terminal
git clone https://github.com/rubyespanol/Primer_Blog.git && cd Primer_Blog - Una vez allí, crea un nuevo branch con el nombre de la característica en la que desees trabajar con
git checkout -b mi-super-caracteristica - Empieza a trabajar en los cambios que desees realizar, y cuándo estes listo añade los archivos y crea el commit
git add -Agit commit -m "Creé una súper característica, espero les agrade" - Sube los archivos a tu nuevo branch con
git push origin nombre-de-tu-branch - Ahora puedes comparar los archivos y hacer un pull request a la rama dev
devdel repositorio original.
Happy coding!
##Testing
El framework de testing utilizado es RSpec y Capybara para los tests de aceptación.
- Navega al directorio raíz del proyecto
- Si es la primera vez que abres el proyecto, instala las gemas, crea la base de datos de testing y de desarrollo:
bundle install
rake db:create
rake db:create RAILS_ENV=test
- Y corre las migraciones:
rake db:migrate
rake db:migrate RAILS_ENV=test
- Siempre que hagas un cambio en la base de datos asegúrate de que corriste las migraciones en la base de datos de testing.
- Crea los tests de tu funcionalidad, luego crea la funcionalidad (TDD recomendado)
- La estructura de folders de testing es la siguiente:
spec
|----features
|----[modelo1]
|----create_spec.rb
|----destroy_spec.rb
|----edit_spec.rb
|----index_spec.rb
|----[mi_accion_personalizada]_spec.rb
|----[modelo2]
|----[modelo3]
|----[modeloN]
|----support #Helpers de los diferentes módelos (código reutilizable en todos los tests)
|----factories.rb #Fábricas de modelos para los tests
- Correr todos los tests
rspec
- Correr Un test suite en particular
rspec [ruta/suite/modeloN.rb]
- Correr un Test case en particular
rspec [ruta/suite/modeloN.rb:Número de la lídea en donde está el test case]
Ejemplo:
rspec spec/features/posts/create_spec.rb:6
- Una vez termines tu funcionalidad, asegúrate de que todoso los tests pasen en verde antes de hacer un PR.
##Versionamiento
Seguimos el estandar Semantic Versioning (en lo posible)
Dado un número de versión MAJOR.MINOR.PATCH, Incrementa:
- MAJOR cuando haces cambios incompatibles con la API actual.
- MINOR cuando se añaden nuevas funcionalidades compatibles con la API actual.
- PATCH cuando se corrigen bugs o se hacen ajustes a la versión actual
##Cambios
Ver el CHANGELOG.md