Skip to content
Snippets Groups Projects
Select Git revision
  • ag-test
  • rs-test
  • master default protected
  • test-me-pa
  • mksionek-master-patch-52381
  • new-branch-10
  • test-conflicts
  • test-suggestions
  • alejandro-test
  • patch-25
  • winh-test-image-doscussion
  • stg-lfs-image-test-2
  • stg-lfs-image-test
  • test42016
  • issue_42016
  • issue-32709
  • add-codeowners
  • ClemMakesApps-master-patch-62759
  • bvl-staging-test
  • bvl-merge-base-api
  • v9.2.0-rc6 protected
  • v9.2.0-rc5 protected
  • v9.2.0-rc4 protected
  • v9.2.0-rc3 protected
  • v9.1.4 protected
  • v9.2.0-rc2 protected
  • v9.2.0-rc1 protected
  • v9.1.3 protected
  • v8.17.6 protected
  • v9.0.7 protected
  • v9.1.2 protected
  • v9.1.1 protected
  • v9.2.0.pre protected
  • v9.1.0 protected
  • v9.1.0-rc7 protected
  • v9.1.0-rc6 protected
  • v9.0.6 protected
  • v9.1.0-rc5 protected
  • v9.1.0-rc4 protected
  • v9.1.0-rc3 protected
40 results

project_members_spec.rb

Blame
  • project_members_spec.rb 5.57 KiB
    require 'spec_helper'
    
    describe API::API, api: true  do
      include ApiHelpers
      let(:user) { create(:user) }
      let(:user2) { create(:user) }
      let(:user3) { create(:user) }
      let(:project) { create(:project, creator_id: user.id, namespace: user.namespace) }
      let(:project_member) { create(:project_member, user: user, project: project, access_level: ProjectMember::MASTER) }
      let(:project_member2) { create(:project_member, user: user3, project: project, access_level: ProjectMember::DEVELOPER) }
    
      describe "GET /projects/:id/members" do
        before { project_member }
        before { project_member2 }
    
        it "should return project team members" do
          get api("/projects/#{project.id}/members", user)
          response.status.should == 200
          json_response.should be_an Array
          json_response.count.should == 2
          json_response.map { |u| u['username'] }.should include user.username
        end
    
        it "finds team members with query string" do
          get api("/projects/#{project.id}/members", user), query: user.username
          response.status.should == 200
          json_response.should be_an Array
          json_response.count.should == 1
          json_response.first['username'].should == user.username
        end
    
        it "should return a 404 error if id not found" do
          get api("/projects/9999/members", user)
          response.status.should == 404
        end
      end
    
      describe "GET /projects/:id/members/:user_id" do
        before { project_member }
    
        it "should return project team member" do
          get api("/projects/#{project.id}/members/#{user.id}", user)
          response.status.should == 200
          json_response['username'].should == user.username
          json_response['access_level'].should == ProjectMember::MASTER
        end
    
        it "should return a 404 error if user id not found" do
          get api("/projects/#{project.id}/members/1234", user)
          response.status.should == 404
        end
      end
    
      describe "POST /projects/:id/members" do
        it "should add user to project team" do
          expect {
            post api("/projects/#{project.id}/members", user), user_id: user2.id,
              access_level: ProjectMember::DEVELOPER
          }.to change { ProjectMember.count }.by(1)
    
          response.status.should == 201
          json_response['username'].should == user2.username
          json_response['access_level'].should == ProjectMember::DEVELOPER
        end
    
        it "should return a 201 status if user is already project member" do
          post api("/projects/#{project.id}/members", user), user_id: user2.id,
            access_level: ProjectMember::DEVELOPER
          expect {
            post api("/projects/#{project.id}/members", user), user_id: user2.id,
              access_level: ProjectMember::DEVELOPER
          }.not_to change { ProjectMember.count }.by(1)
    
          response.status.should == 201
          json_response['username'].should == user2.username
          json_response['access_level'].should == ProjectMember::DEVELOPER
        end
    
        it "should return a 400 error when user id is not given" do
          post api("/projects/#{project.id}/members", user), access_level: ProjectMember::MASTER
          response.status.should == 400
        end
    
        it "should return a 400 error when access level is not given" do
          post api("/projects/#{project.id}/members", user), user_id: user2.id
          response.status.should == 400
        end
    
        it "should return a 422 error when access level is not known" do
          post api("/projects/#{project.id}/members", user), user_id: user2.id, access_level: 1234
          response.status.should == 422
        end
      end
    
      describe "PUT /projects/:id/members/:user_id" do
        before { project_member2 }
    
        it "should update project team member" do
          put api("/projects/#{project.id}/members/#{user3.id}", user), access_level: ProjectMember::MASTER
          response.status.should == 200
          json_response['username'].should == user3.username
          json_response['access_level'].should == ProjectMember::MASTER
        end
    
        it "should return a 404 error if user_id is not found" do
          put api("/projects/#{project.id}/members/1234", user), access_level: ProjectMember::MASTER
          response.status.should == 404
        end
    
        it "should return a 400 error when access level is not given" do
          put api("/projects/#{project.id}/members/#{user3.id}", user)
          response.status.should == 400
        end
    
        it "should return a 422 error when access level is not known" do
          put api("/projects/#{project.id}/members/#{user3.id}", user), access_level: 123
          response.status.should == 422
        end
      end
    
      describe "DELETE /projects/:id/members/:user_id" do
        before { project_member }
        before { project_member2 }
    
        it "should remove user from project team" do
          expect {
            delete api("/projects/#{project.id}/members/#{user3.id}", user)
          }.to change { ProjectMember.count }.by(-1)
        end
    
        it "should return 200 if team member is not part of a project" do
          delete api("/projects/#{project.id}/members/#{user3.id}", user)
          expect {
            delete api("/projects/#{project.id}/members/#{user3.id}", user)
          }.to_not change { ProjectMember.count }.by(1)
        end
    
        it "should return 200 if team member already removed" do
          delete api("/projects/#{project.id}/members/#{user3.id}", user)
          delete api("/projects/#{project.id}/members/#{user3.id}", user)
          response.status.should == 200
        end
    
        it "should return 200 OK when the user was not member" do
          expect {
            delete api("/projects/#{project.id}/members/1000000", user)
          }.to change { ProjectMember.count }.by(0)
          response.status.should == 200
          json_response['message'].should == "Access revoked"
          json_response['id'].should == 1000000
        end
      end
    end