Skip to content

Latest commit

 

History

History
193 lines (150 loc) · 5.5 KB

README.md

File metadata and controls

193 lines (150 loc) · 5.5 KB

silmarails

Silmarails is a warehouse for templates and initial configurations for brand new rails project with the minimum needed for a quick development environment.

Pre requisites

So, there is no explicit pre requisite to install this gem and use it in your rails project. But I actually recommend to be running with rails ~> 4.2, ruby ~> 2.2, postgres (any version) aaaaaaand, if you are creating your project now, to create it with the following command:

rails new my_project -T -d postgresql

That's it!

Install

To intall this project, first, you need to add the following to your Gemfile:

gem 'silmarails'
gem 'kaminari'
gem 'responders'
gem 'simple_form'
# Uncomment this and remove bootstrap if you are using foundation
# gem 'foundation-rails'

group :test do
  gem "rspec"
  gem "rspec-rails"
  gem "capybara"
  gem "database_cleaner"
  gem 'factory_girl_rails'
end

source 'https://rails-assets.org' do
  gem 'rails-assets-bootstrap'
end

Then:

bundle install

The other gems are not hard dependencies, but we have some templates defined that need them to work correctly, please check their installation guides individually. If you are not so interested in reading everyone, here comes a list of commands you'll probably need to execute:

rails g kaminari:config
rails g rspec:install
rails g responders:install

# if you're using bootstrap
rails g kaminari:views bootstrap3
rails g simple_form:install --bootstrap

# if you're using foundation
rails g foundation:install
rails g kaminari:views foundation5
rails g simple_form:install --foundation

And finally:

# if you're using bootstrap
rails g silmarails:install --framework=bootstrap

# if you're using foundation
rails g silmarails:install --framework=foundation

This will copy all the default templates into your rails project, and may have conflicts with other gems. If so, just diff them and choose which one you prefer.

It's important to remember that this needs to be recopied everytime there is a update on them.

How to update

Well, that's a long story. Depends of course on how many things are you updating at once, but I would recommend update all of them separetedly. So:

bundle update silmarails

After that, you'll be able to just:

rails g silmarails:install

This, of course, can have changes dependeding on which is the update and take attention to your changes to the templates you've copied. Choose wisely if you want or not the new version. :stuck_out_and_tongue:

Recommended configuration

Follows some recommended configuration for your application if you are using silmarails:

<app/assets/stylesheets/application.css>
# add the following lines to ignore the scaffolds file and import the needed
# bootstrap (if you are not using foundation, of course)
 *= stub scaffolds
 *= require bootstrap

<app/assets/javascripts/application.js>
# add the following lines to import the needed bootstrap (if you are not using
# foundation, of course)
//= require bootstrap
//= require magic_view

# then, at the end of file, add the following line to init the magic_view code
//= require magic_view/init

<config/application.rb>
# add the following lines to configure the generators properly
    config.generators do |g|
      g.test_framework :rspec,
        fixtures: true,
        model_specs: false,
        helper_specs: false
      g.fixture_replacement :factory_girl
      g.factory_girl dir: "spec/factories"
    end

<spec/rails_helper.rb>
# uncomment the following line to require the needed support files (one of them
# is copied on the silmarails installations)
Dir[Rails.root.join('spec/support/**/*.rb')].each { |f| require f }

# then change the value of the following config to false (the raise of the code below
# is granting this will be always that way and explaining why it's needed, but
# I'm warning you one more tim: DO THIS AND DON'T REMOVE THAT RAISE!!!!!!)
  config.use_transactional_fixtures = false

# and finally add the following lines to configure the database cleaner for your
# rspec tests (put them inside the
  config.before(:suite) do
    # don't remove this raise for the sake of God!!!
    if config.use_transactional_fixtures?
      raise(<<-MSG)
        Delete line `config.use_transactional_fixtures = true` from rails_helper.rb
        (or set it to false) to prevent uncommitted transactions being used in
        JavaScript-dependent specs.

        During testing, the app-under-test that the browser driver connects to
        uses a different database connection to the database connection used by
        the spec. The app's database connection would not be able to access
        uncommitted transaction data setup over the spec's database connection.
      MSG
    end
    DatabaseCleaner.clean_with(:truncation)
  end

  config.before(:each) do
    DatabaseCleaner.strategy = :transaction
  end

  config.before(:each, type: :feature) do
    # :rack_test driver's Rack app under test shares database connection
    # with the specs, so continue to use transaction strategy for speed.
    driver_shares_db_connection_with_specs = Capybara.current_driver == :rack_test

    unless driver_shares_db_connection_with_specs
      # Driver is probably for an external browser with an app
      # under test that does *not* share a database connection with the
      # specs, so use truncation strategy.
      DatabaseCleaner.strategy = :truncation
    end
  end

  config.before(:each) do
    DatabaseCleaner.start
  end

  config.append_after(:each) do
    DatabaseCleaner.clean
  end