Sha256: fd411212e96c91664ac2e5aa98b5b22515cc849ec00b4803f93bde9d1cd90821

Contents?: true

Size: 1.88 KB

Versions: 5

Compression:

Stored size: 1.88 KB

Contents

# frozen_string_literal: true

require 'spec_helper'

module RailsBestPractices
  module Reviews
    describe MoveCodeIntoControllerReview do
      let(:runner) { Core::Runner.new(reviews: MoveCodeIntoControllerReview.new) }

      it 'should move code into controller for method call' do
        content = <<-EOF
        <% Post.find(:all).each do |post| %>
          <%=h post.title %>
          <%=h post.content %>
        <% end %>
        EOF
        runner.review('app/views/posts/index.html.erb', content)
        expect(runner.errors.size).to eq(1)
        expect(runner.errors[0].to_s).to eq('app/views/posts/index.html.erb:1 - move code into controller')
      end

      it 'should move code into controller for assign' do
        content = <<-EOF
        <% @posts = Post.all %>
        <% @posts.each do |post| %>
          <%=h post.title %>
          <%=h post.content %>
        <% end %>
        EOF
        runner.review('app/views/posts/index.html.erb', content)
        expect(runner.errors.size).to eq(1)
        expect(runner.errors[0].to_s).to eq('app/views/posts/index.html.erb:1 - move code into controller')
      end

      it 'should not move code into controller' do
        content = <<-EOF
        <% @posts.each do |post| %>
          <%=h post.title %>
          <%=h post.content %>
        <% end %>
        EOF
        runner.review('app/views/posts/index.html.erb', content)
        expect(runner.errors.size).to eq(0)
      end

      it 'should not check ignored files' do
        runner = Core::Runner.new(reviews: MoveCodeIntoControllerReview.new(ignored_files: /app\/views\/post/))
        content = <<-EOF
        <% Post.find(:all).each do |post| %>
          <%=h post.title %>
          <%=h post.content %>
        <% end %>
        EOF
        runner.review('app/views/posts/index.html.erb', content)
        expect(runner.errors.size).to eq(0)
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
rails_best_practices-1.20.0 spec/rails_best_practices/reviews/move_code_into_controller_review_spec.rb
rails_best_practices-1.19.5 spec/rails_best_practices/reviews/move_code_into_controller_review_spec.rb
rails_best_practices-1.19.4 spec/rails_best_practices/reviews/move_code_into_controller_review_spec.rb
rails_best_practices-1.19.3 spec/rails_best_practices/reviews/move_code_into_controller_review_spec.rb
rails_best_practices-1.19.2 spec/rails_best_practices/reviews/move_code_into_controller_review_spec.rb