You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							112 lines
						
					
					
						
							3.3 KiB
						
					
					
				
			
		
		
	
	
							112 lines
						
					
					
						
							3.3 KiB
						
					
					
				| require 'spec_helper'
 | |
| 
 | |
| describe Gitlab::Client do
 | |
|   describe ".groups" do
 | |
|     before do
 | |
|       stub_get("/groups", "groups")
 | |
|       stub_get("/groups/3", "group")
 | |
|       @group = Gitlab.group(3)
 | |
|       @groups = Gitlab.groups
 | |
|     end
 | |
| 
 | |
|     it "should get the correct resource" do
 | |
|       expect(a_get("/groups")).to have_been_made
 | |
|       expect(a_get("/groups/3")).to have_been_made
 | |
|     end
 | |
| 
 | |
|     it "should return an array of Groups" do
 | |
|       expect(@groups).to be_an Array
 | |
|       expect(@groups.first.path).to eq("threegroup")
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   describe ".create_group" do
 | |
|     before do
 | |
|       stub_post("/groups", "group_create")
 | |
|       @group = Gitlab.create_group('GitLab-Group', 'gitlab-path')
 | |
|     end
 | |
| 
 | |
|     it "should get the correct resource" do
 | |
|       expect(a_post("/groups").
 | |
|           with(:body => {:path => 'gitlab-path', :name => 'GitLab-Group'})).to have_been_made
 | |
|     end
 | |
| 
 | |
|     it "should return information about a created group" do
 | |
|       expect(@group.name).to eq("Gitlab-Group")
 | |
|       expect(@group.path).to eq("gitlab-group")
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   describe ".transfer_project_to_group" do
 | |
|     before do
 | |
|       stub_post("/projects", "project")
 | |
|       @project = Gitlab.create_project('Gitlab')
 | |
|       stub_post("/groups", "group_create")
 | |
|       @group = Gitlab.create_group('GitLab-Group', 'gitlab-path')
 | |
| 
 | |
|       stub_post("/groups/#{@group.id}/projects/#{@project.id}", "group_create")
 | |
|       @group_transfer = Gitlab.transfer_project_to_group(@group.id,@project.id)
 | |
|     end
 | |
| 
 | |
|     it "should post to the correct resource" do
 | |
|       expect(a_post("/groups/#{@group.id}/projects/#{@project.id}").with(:body => {:id => @group.id.to_s, :project_id => @project.id.to_s})).to have_been_made
 | |
|     end
 | |
| 
 | |
|     it "should return information about the group" do
 | |
|       expect(@group_transfer.name).to eq(@group.name)
 | |
|       expect(@group_transfer.path).to eq(@group.path)
 | |
|       expect(@group_transfer.id).to eq(@group.id)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   describe ".group_members" do
 | |
|     before do
 | |
|       stub_get("/groups/3/members", "group_members")
 | |
|       @members = Gitlab.group_members(3)
 | |
|     end
 | |
| 
 | |
|     it "should get the correct resource" do
 | |
|       expect(a_get("/groups/3/members")).to have_been_made
 | |
|     end
 | |
| 
 | |
|     it "should return information about a group members" do
 | |
|       expect(@members).to be_an Array
 | |
|       expect(@members.size).to eq(2)
 | |
|       expect(@members[1].name).to eq("John Smith")
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   describe ".add_group_member" do
 | |
|     before do
 | |
|       stub_post("/groups/3/members", "group_member")
 | |
|       @member = Gitlab.add_group_member(3, 1, 40)
 | |
|     end
 | |
| 
 | |
|     it "should get the correct resource" do
 | |
|       expect(a_post("/groups/3/members").
 | |
|         with(:body => {:user_id => '1', :access_level => '40'})).to have_been_made
 | |
|     end
 | |
| 
 | |
|     it "should return information about an added member" do
 | |
|       expect(@member.name).to eq("John Smith")
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   describe ".remove_group_member" do
 | |
|     before do
 | |
|       stub_delete("/groups/3/members/1", "group_member_delete")
 | |
|       @group = Gitlab.remove_group_member(3, 1)
 | |
|     end
 | |
| 
 | |
|     it "should get the correct resource" do
 | |
|       expect(a_delete("/groups/3/members/1")).to have_been_made
 | |
|     end
 | |
| 
 | |
|     it "should return information about the group the member was removed from" do
 | |
|       expect(@group.group_id).to eq(3)
 | |
|     end
 | |
|   end
 | |
| 
 | |
| 
 | |
| end
 |