BigW Consortium Gitlab

forks_controller_spec.rb 1.85 KB
Newer Older
1 2 3 4
require 'spec_helper'

describe Projects::ForksController do
  let(:user) { create(:user) }
5
  let(:project) { create(:project, :public) }
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
  let(:forked_project) { Projects::ForkService.new(project, user).execute }
  let(:group) { create(:group, owner: forked_project.creator) }

  describe 'GET index' do
    def get_forks
      get :index,
        namespace_id: project.namespace.to_param,
        project_id: project.to_param
    end

    context 'when fork is public' do
      before { forked_project.update_attribute(:visibility_level, Project::PUBLIC) }

      it 'should be visible for non logged in users' do
        get_forks

        expect(assigns[:forks]).to be_present
      end
    end

    context 'when fork is private' do
      before do
        forked_project.update_attributes(visibility_level: Project::PRIVATE, group: group)
      end

      it 'should not be visible for non logged in users' do
        get_forks

        expect(assigns[:forks]).to be_blank
      end

      context 'when user is logged in' do
        before { sign_in(project.creator) }

        context 'when user is not a Project member neither a group member' do
          it 'should not see the Project listed' do
            get_forks

            expect(assigns[:forks]).to be_blank
          end
        end

        context 'when user is a member of the Project' do
          before { forked_project.team << [project.creator, :developer] }

          it 'should see the project listed' do
            get_forks

            expect(assigns[:forks]).to be_present
          end
        end

        context 'when user is a member of the Group' do
          before { forked_project.group.add_developer(project.creator) }

          it 'should see the project listed' do
            get_forks

            expect(assigns[:forks]).to be_present
          end
        end

      end
    end
  end

end