From 3123be9fbbc494e45a638f21ed3dcff942cb97c4 Mon Sep 17 00:00:00 2001 From: Camil Staps Date: Tue, 5 Feb 2019 12:49:58 +0100 Subject: Add tests for starrers views --- spec/finders/users_star_projects_finder_spec.rb | 40 +++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 spec/finders/users_star_projects_finder_spec.rb (limited to 'spec/finders/users_star_projects_finder_spec.rb') diff --git a/spec/finders/users_star_projects_finder_spec.rb b/spec/finders/users_star_projects_finder_spec.rb new file mode 100644 index 00000000000..4c0aa3f8f77 --- /dev/null +++ b/spec/finders/users_star_projects_finder_spec.rb @@ -0,0 +1,40 @@ +require 'spec_helper' + +describe UsersStarProjectsFinder do + let(:project) { create(:project, :public, :empty_repo) } + + let(:user) { create(:user) } + let(:private_user) { create(:user, private_profile: true) } + let(:other_user) { create(:user) } + + before do + user.toggle_star(project) + private_user.toggle_star(project) + end + + describe '#execute' do + let(:finder) { described_class.new(project, {}, current_user: current_user) } + let(:public_stars) { user.users_star_projects } + let(:private_stars) { private_user.users_star_projects } + + subject { finder.execute } + + describe 'as same user' do + let(:current_user) { private_user } + + it { is_expected.to eq(private_stars + public_stars) } + end + + describe 'as other user' do + let(:current_user) { other_user } + + it { is_expected.to eq(public_stars) } + end + + describe 'as no user' do + let(:current_user) { nil } + + it { is_expected.to eq(public_stars) } + end + end +end -- cgit v1.2.3