# frozen_string_literal: true

require 'spec_helper'

module RailsBestPractices
  module Reviews
    describe UseObserverReview do
      let(:runner) { Core::Runner.new(prepares: Prepares::MailerPrepare.new, reviews: described_class.new) }

      before do
        content = <<-EOF
        class ProjectMailer < ActionMailer::Base
        end
        EOF
        runner.prepare('app/models/project_mailer.rb', content)
      end

      it 'uses observer' do
        content = <<-EOF
        class Project < ActiveRecord::Base
          after_create :send_create_notification

          private
          def send_create_notification
            self.members.each do |member|
              ProjectMailer.notification(self, member).deliver
            end
          end
        end
        EOF
        runner.review('app/models/project.rb', content)
        expect(runner.errors.size).to eq(1)
        expect(runner.errors[0].to_s).to eq('app/models/project.rb:5 - use observer')
      end

      it 'does not use observer without callback' do
        content = <<-EOF
        class Project < ActiveRecord::Base
          private
          def send_create_notification
            self.members.each do |member|
              ProjectMailer.notification(self, member).deliver
            end
          end
        end
        EOF
        runner.review('app/models/project.rb', content)
        expect(runner.errors.size).to eq(0)
      end

      it 'uses observer with two after_create' do
        content = <<-EOF
        class Project < ActiveRecord::Base
          after_create :send_create_notification, :update_author

          private
          def send_create_notification
            self.members.each do |member|
              ProjectMailer.notification(self, member).deliver
            end
          end

          def update_author
          end
        end
        EOF
        runner.review('app/models/project.rb', content)
        expect(runner.errors.size).to eq(1)
        expect(runner.errors[0].to_s).to eq('app/models/project.rb:5 - use observer')
      end

      it 'does not raise when initiate an object in callback' do
        content = <<-EOF
        class Project < ActiveRecord::Base
          after_create ProjectMailer.new
        end
        EOF
        expect { runner.review('app/models/project.rb', content) }.not_to raise_error
      end
    end
  end
end