71 lines
1.9 KiB
Ruby
71 lines
1.9 KiB
Ruby
|
require 'spec_helper'
|
||
|
|
||
|
describe FinderMethods do
|
||
|
let(:finder_class) do
|
||
|
Class.new do
|
||
|
include FinderMethods
|
||
|
|
||
|
attr_reader :current_user
|
||
|
|
||
|
def initialize(user)
|
||
|
@current_user = user
|
||
|
end
|
||
|
|
||
|
def execute
|
||
|
Project.all
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
let(:user) { create(:user) }
|
||
|
let(:finder) { finder_class.new(user) }
|
||
|
let(:authorized_project) { create(:project) }
|
||
|
let(:unauthorized_project) { create(:project) }
|
||
|
|
||
|
before do
|
||
|
authorized_project.add_developer(user)
|
||
|
end
|
||
|
|
||
|
describe '#find_by!' do
|
||
|
it 'returns the project if the user has access' do
|
||
|
expect(finder.find_by!(id: authorized_project.id)).to eq(authorized_project)
|
||
|
end
|
||
|
|
||
|
it 'raises not found when the project is not found' do
|
||
|
expect { finder.find_by!(id: 0) }.to raise_error(ActiveRecord::RecordNotFound)
|
||
|
end
|
||
|
|
||
|
it 'raises not found the user does not have access' do
|
||
|
expect { finder.find_by!(id: unauthorized_project.id) }.to raise_error(ActiveRecord::RecordNotFound)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe '#find' do
|
||
|
it 'returns the project if the user has access' do
|
||
|
expect(finder.find(authorized_project.id)).to eq(authorized_project)
|
||
|
end
|
||
|
|
||
|
it 'raises not found when the project is not found' do
|
||
|
expect { finder.find(0) }.to raise_error(ActiveRecord::RecordNotFound)
|
||
|
end
|
||
|
|
||
|
it 'raises not found the user does not have access' do
|
||
|
expect { finder.find(unauthorized_project.id) }.to raise_error(ActiveRecord::RecordNotFound)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe '#find_by' do
|
||
|
it 'returns the project if the user has access' do
|
||
|
expect(finder.find_by(id: authorized_project.id)).to eq(authorized_project)
|
||
|
end
|
||
|
|
||
|
it 'returns nil when the project is not found' do
|
||
|
expect(finder.find_by(id: 0)).to be_nil
|
||
|
end
|
||
|
|
||
|
it 'returns nil when the user does not have access' do
|
||
|
expect(finder.find_by(id: unauthorized_project.id)).to be_nil
|
||
|
end
|
||
|
end
|
||
|
end
|