Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
authorMarin Jankovski <maxlazio@gmail.com>2015-01-12 13:08:53 +0300
committerMarin Jankovski <maxlazio@gmail.com>2015-01-12 13:08:53 +0300
commit8689ce1efef8438debeec2a3a6d669f4d5a435c4 (patch)
treeec6757d8ae062bbd8ceb38ebb7d136932302d5a3 /spec
parent31bcd04711d448c016506897b8431273e3454faa (diff)
Add search filter option on project api for authorized projects.
Diffstat (limited to 'spec')
-rw-r--r--spec/requests/api/projects_spec.rb25
1 files changed, 25 insertions, 0 deletions
diff --git a/spec/requests/api/projects_spec.rb b/spec/requests/api/projects_spec.rb
index 79865f15f06..dfc96c9df21 100644
--- a/spec/requests/api/projects_spec.rb
+++ b/spec/requests/api/projects_spec.rb
@@ -7,6 +7,8 @@ describe API::API, api: true do
let(:user3) { create(:user) }
let(:admin) { create(:admin) }
let(:project) { create(:project, creator_id: user.id, namespace: user.namespace) }
+ let(:project2) { create(:project, path: 'project2', creator_id: user.id, namespace: user.namespace) }
+ let(:project3) { create(:project, path: 'project3', creator_id: user.id, namespace: user.namespace) }
let(:snippet) { create(:project_snippet, author: user, project: project, title: 'example') }
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) }
@@ -29,6 +31,29 @@ describe API::API, api: true do
json_response.first['name'].should == project.name
json_response.first['owner']['username'].should == user.username
end
+
+ context "and using search" do
+ it "should return searched project" do
+ get api("/projects", user), { search: project.name }
+ response.status.should eq(200)
+ json_response.should be_an Array
+ json_response.length.should eq(1)
+ end
+ end
+
+ context "and using sorting" do
+ before do
+ project2
+ project3
+ end
+
+ it "should return the correct order when sorted by id" do
+ get api("/projects", user), { order_by: 'id', sort: 'desc'}
+ response.status.should eq(200)
+ json_response.should be_an Array
+ json_response.first['id'].should eq(3)
+ end
+ end
end
end