diff options
author | Camil Staps <info@camilstaps.nl> | 2019-02-05 12:49:58 +0100 |
---|---|---|
committer | Camil Staps <info@camilstaps.nl> | 2019-08-07 20:49:17 +0200 |
commit | 3123be9fbbc494e45a638f21ed3dcff942cb97c4 (patch) | |
tree | 02442921724bc3238b43557ad7e24eb65a433000 /spec/finders | |
parent | 99bb207ef14d12fe59e23fd70e219ed5e166470b (diff) | |
download | gitlab-ce-3123be9fbbc494e45a638f21ed3dcff942cb97c4.tar.gz |
Add tests for starrers views
Diffstat (limited to 'spec/finders')
-rw-r--r-- | spec/finders/starred_projects_finder_spec.rb | 39 | ||||
-rw-r--r-- | spec/finders/users_star_projects_finder_spec.rb | 40 |
2 files changed, 79 insertions, 0 deletions
diff --git a/spec/finders/starred_projects_finder_spec.rb b/spec/finders/starred_projects_finder_spec.rb new file mode 100644 index 00000000000..6bc19af7a57 --- /dev/null +++ b/spec/finders/starred_projects_finder_spec.rb @@ -0,0 +1,39 @@ +require 'spec_helper' + +describe StarredProjectsFinder do + let(:project1) { create(:project, :public, :empty_repo) } + let(:project2) { create(:project, :public, :empty_repo) } + let(:other_project) { create(:project, :public, :empty_repo) } + + let(:user) { create(:user) } + let(:other_user) { create(:user) } + + before do + user.toggle_star(project1) + user.toggle_star(project2) + end + + describe '#execute' do + let(:finder) { described_class.new(user, params: {}, current_user: current_user) } + + subject { finder.execute } + + describe 'as same user' do + let(:current_user) { user } + + it { is_expected.to eq([project2, project1]) } + end + + describe 'as other user' do + let(:current_user) { other_user } + + it { is_expected.to eq([project2, project1]) } + end + + describe 'as no user' do + let(:current_user) { nil } + + it { is_expected.to eq([project2, project1]) } + end + end +end 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 |