summaryrefslogtreecommitdiff
path: root/spec/controllers/projects_controller_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/controllers/projects_controller_spec.rb')
-rw-r--r--spec/controllers/projects_controller_spec.rb538
1 files changed, 269 insertions, 269 deletions
diff --git a/spec/controllers/projects_controller_spec.rb b/spec/controllers/projects_controller_spec.rb
index a1662658ade..cec2242907b 100644
--- a/spec/controllers/projects_controller_spec.rb
+++ b/spec/controllers/projects_controller_spec.rb
@@ -1,4 +1,4 @@
-require('spec_helper')
+require("spec_helper")
describe ProjectsController do
include ProjectForksHelper
@@ -6,44 +6,44 @@ describe ProjectsController do
let(:project) { create(:project) }
let(:public_project) { create(:project, :public) }
let(:user) { create(:user) }
- let(:jpg) { fixture_file_upload('spec/fixtures/rails_sample.jpg', 'image/jpg') }
- let(:txt) { fixture_file_upload('spec/fixtures/doc_sample.txt', 'text/plain') }
+ let(:jpg) { fixture_file_upload("spec/fixtures/rails_sample.jpg", "image/jpg") }
+ let(:txt) { fixture_file_upload("spec/fixtures/doc_sample.txt", "text/plain") }
- describe 'GET new' do
- context 'with an authenticated user' do
+ describe "GET new" do
+ context "with an authenticated user" do
let(:group) { create(:group) }
before do
sign_in(user)
end
- context 'when namespace_id param is present' do
- context 'when user has access to the namespace' do
- it 'renders the template' do
+ context "when namespace_id param is present" do
+ context "when user has access to the namespace" do
+ it "renders the template" do
group.add_owner(user)
- get :new, params: { namespace_id: group.id }
+ get :new, params: {namespace_id: group.id}
expect(response).to have_gitlab_http_status(200)
- expect(response).to render_template('new')
+ expect(response).to render_template("new")
end
end
- context 'when user does not have access to the namespace' do
- it 'responds with status 404' do
- get :new, params: { namespace_id: group.id }
+ context "when user does not have access to the namespace" do
+ it "responds with status 404" do
+ get :new, params: {namespace_id: group.id}
expect(response).to have_gitlab_http_status(404)
- expect(response).not_to render_template('new')
+ expect(response).not_to render_template("new")
end
end
end
end
end
- describe 'GET index' do
- context 'as a user' do
- it 'redirects to root page' do
+ describe "GET index" do
+ context "as a user" do
+ it "redirects to root page" do
sign_in(user)
get :index
@@ -52,8 +52,8 @@ describe ProjectsController do
end
end
- context 'as a guest' do
- it 'redirects to Explore page' do
+ context "as a guest" do
+ it "redirects to Explore page" do
get :index
expect(response).to redirect_to(explore_root_path)
@@ -71,7 +71,7 @@ describe ProjectsController do
let(:private_project) { create(:project, :private) }
it "does not initialize notification setting" do
- get :show, params: { namespace_id: private_project.namespace, id: private_project }
+ get :show, params: {namespace_id: private_project.namespace, id: private_project}
expect(assigns(:notification_setting)).to be_nil
end
end
@@ -79,7 +79,7 @@ describe ProjectsController do
context "user has access to project" do
context "and does not have notification setting" do
it "initializes notification as disabled" do
- get :show, params: { namespace_id: public_project.namespace, id: public_project }
+ get :show, params: {namespace_id: public_project.namespace, id: public_project}
expect(assigns(:notification_setting).level).to eq("global")
end
end
@@ -92,7 +92,7 @@ describe ProjectsController do
end
it "shows current notification setting" do
- get :show, params: { namespace_id: public_project.namespace, id: public_project }
+ get :show, params: {namespace_id: public_project.namespace, id: public_project}
expect(assigns(:notification_setting).level).to eq("watch")
end
end
@@ -106,42 +106,42 @@ describe ProjectsController do
project.project_feature.update_attribute(:repository_access_level, ProjectFeature::DISABLED)
end
- it 'shows wiki homepage' do
- get :show, params: { namespace_id: project.namespace, id: project }
+ it "shows wiki homepage" do
+ get :show, params: {namespace_id: project.namespace, id: project}
- expect(response).to render_template('projects/_wiki')
+ expect(response).to render_template("projects/_wiki")
end
- it 'shows issues list page if wiki is disabled' do
+ it "shows issues list page if wiki is disabled" do
project.project_feature.update_attribute(:wiki_access_level, ProjectFeature::DISABLED)
create(:issue, project: project)
- get :show, params: { namespace_id: project.namespace, id: project }
+ get :show, params: {namespace_id: project.namespace, id: project}
- expect(response).to render_template('projects/issues/_issues')
+ expect(response).to render_template("projects/issues/_issues")
expect(assigns(:issuable_meta_data)).not_to be_nil
end
- it 'shows customize workflow page if wiki and issues are disabled' do
+ it "shows customize workflow page if wiki and issues are disabled" do
project.project_feature.update_attribute(:wiki_access_level, ProjectFeature::DISABLED)
project.project_feature.update_attribute(:issues_access_level, ProjectFeature::DISABLED)
- get :show, params: { namespace_id: project.namespace, id: project }
+ get :show, params: {namespace_id: project.namespace, id: project}
expect(response).to render_template("projects/_customize_workflow")
end
- it 'shows activity if enabled by user' do
- user.update_attribute(:project_view, 'activity')
+ it "shows activity if enabled by user" do
+ user.update_attribute(:project_view, "activity")
- get :show, params: { namespace_id: project.namespace, id: project }
+ get :show, params: {namespace_id: project.namespace, id: project}
expect(response).to render_template("projects/_activity")
end
end
end
- context 'when the storage is not available', :broken_storage do
+ context "when the storage is not available", :broken_storage do
set(:project) { create(:project, :broken_storage) }
before do
@@ -149,8 +149,8 @@ describe ProjectsController do
sign_in(user)
end
- it 'renders a 503' do
- get :show, params: { namespace_id: project.namespace, id: project }
+ it "renders a 503" do
+ get :show, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(503)
end
@@ -168,11 +168,11 @@ describe ProjectsController do
before do
user.update(project_view: project_view)
- get :show, params: { namespace_id: empty_project.namespace, id: empty_project }
+ get :show, params: {namespace_id: empty_project.namespace, id: empty_project}
end
it "renders the empty project view" do
- expect(response).to render_template('empty')
+ expect(response).to render_template("empty")
end
end
end
@@ -190,13 +190,13 @@ describe ProjectsController do
before do
user.update(project_view: project_view)
- get :show, params: { namespace_id: empty_project.namespace, id: empty_project }
+ get :show, params: {namespace_id: empty_project.namespace, id: empty_project}
end
it "renders the empty project view" do
allow(Project).to receive(:repo).and_raise(Gitlab::Git::Repository::NoRepository)
- expect(response).to render_template('projects/no_repo')
+ expect(response).to render_template("projects/no_repo")
end
end
end
@@ -209,60 +209,60 @@ describe ProjectsController do
it "renders the activity view" do
allow(controller).to receive(:current_user).and_return(user)
- allow(user).to receive(:project_view).and_return('activity')
+ allow(user).to receive(:project_view).and_return("activity")
- get :show, params: { namespace_id: public_project.namespace, id: public_project }
- expect(response).to render_template('_activity')
+ get :show, params: {namespace_id: public_project.namespace, id: public_project}
+ expect(response).to render_template("_activity")
end
it "renders the files view" do
allow(controller).to receive(:current_user).and_return(user)
- allow(user).to receive(:project_view).and_return('files')
+ allow(user).to receive(:project_view).and_return("files")
- get :show, params: { namespace_id: public_project.namespace, id: public_project }
- expect(response).to render_template('_files')
+ get :show, params: {namespace_id: public_project.namespace, id: public_project}
+ expect(response).to render_template("_files")
end
it "renders the readme view" do
allow(controller).to receive(:current_user).and_return(user)
- allow(user).to receive(:project_view).and_return('readme')
+ allow(user).to receive(:project_view).and_return("readme")
- get :show, params: { namespace_id: public_project.namespace, id: public_project }
- expect(response).to render_template('_readme')
+ get :show, params: {namespace_id: public_project.namespace, id: public_project}
+ expect(response).to render_template("_readme")
end
end
context "when the url contains .atom" do
- let(:public_project_with_dot_atom) { build(:project, :public, name: 'my.atom', path: 'my.atom') }
+ let(:public_project_with_dot_atom) { build(:project, :public, name: "my.atom", path: "my.atom") }
- it 'expects an error creating the project' do
+ it "expects an error creating the project" do
expect(public_project_with_dot_atom).not_to be_valid
end
end
- context 'when the project is pending deletions' do
- it 'renders a 404 error' do
+ context "when the project is pending deletions" do
+ it "renders a 404 error" do
project = create(:project, pending_delete: true)
sign_in(user)
- get :show, params: { namespace_id: project.namespace, id: project }
+ get :show, params: {namespace_id: project.namespace, id: project}
expect(response.status).to eq 404
end
end
context "redirection from http://someproject.git" do
- it 'redirects to project page (format.html)' do
+ it "redirects to project page (format.html)" do
project = create(:project, :public)
- get :show, params: { namespace_id: project.namespace, id: project }, format: :git
+ get :show, params: {namespace_id: project.namespace, id: project}, format: :git
expect(response).to have_gitlab_http_status(302)
expect(response).to redirect_to(namespace_project_path)
end
end
- context 'when the project is forked and has a repository', :request_store do
+ context "when the project is forked and has a repository", :request_store do
let(:public_project) { create(:project, :public, :repository) }
let(:other_user) { create(:user) }
@@ -275,25 +275,25 @@ describe ProjectsController do
fork_project(public_project)
end
- it 'does not increase the number of queries when the project is forked' do
+ it "does not increase the number of queries when the project is forked" do
expected_query = /#{public_project.fork_network.find_forks_in(other_user.namespace).to_sql}/
- expect { get(:show, params: { namespace_id: public_project.namespace, id: public_project }) }
+ expect { get(:show, params: {namespace_id: public_project.namespace, id: public_project}) }
.not_to exceed_query_limit(2).for_query(expected_query)
end
end
end
- describe 'GET edit' do
- it 'sets the badge API endpoint' do
+ describe "GET edit" do
+ it "sets the badge API endpoint" do
sign_in(user)
project.add_maintainer(user)
get :edit,
- params: {
- namespace_id: project.namespace.path,
- id: project.path
- }
+ params: {
+ namespace_id: project.namespace.path,
+ id: project.path,
+ }
expect(assigns(:badge_api_endpoint)).not_to be_nil
end
@@ -308,20 +308,20 @@ describe ProjectsController do
sign_in(admin)
end
- shared_examples_for 'updating a project' do
- context 'when only renaming a project path' do
+ shared_examples_for "updating a project" do
+ context "when only renaming a project path" do
it "sets the repository to the right path after a rename" do
- original_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access do
+ original_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access {
project.repository.path
- end
+ }
- expect { update_project path: 'renamed_path' }
+ expect { update_project path: "renamed_path" }
.to change { project.reload.path }
- expect(project.path).to include 'renamed_path'
+ expect(project.path).to include "renamed_path"
- assign_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access do
+ assign_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access {
assigns(:repository).path
- end
+ }
if project.hashed_storage?(:repository)
expect(assign_repository_path).to eq(original_repository_path)
@@ -333,15 +333,15 @@ describe ProjectsController do
end
end
- context 'when project has container repositories with tags' do
+ context "when project has container repositories with tags" do
before do
stub_container_registry_config(enabled: true)
stub_container_registry_tags(repository: /image/, tags: %w[rc1])
create(:container_repository, project: project, name: :image)
end
- it 'does not allow to rename the project' do
- expect { update_project path: 'renamed_path' }
+ it "does not allow to rename the project" do
+ expect { update_project path: "renamed_path" }
.not_to change { project.reload.path }
expect(controller).to set_flash.now[:alert].to(/container registry tags/)
@@ -349,19 +349,19 @@ describe ProjectsController do
end
end
- it 'updates Fast Forward Merge attributes' do
+ it "updates Fast Forward Merge attributes" do
controller.instance_variable_set(:@project, project)
params = {
- merge_method: :ff
+ merge_method: :ff,
}
put :update,
- params: {
- namespace_id: project.namespace,
- id: project.id,
- project: params
- }
+ params: {
+ namespace_id: project.namespace,
+ id: project.id,
+ project: params,
+ }
expect(response).to have_gitlab_http_status(302)
params.each do |param, value|
@@ -371,44 +371,44 @@ describe ProjectsController do
def update_project(**parameters)
put :update,
- params: {
- namespace_id: project.namespace.path,
- id: project.path,
- project: parameters
- }
+ params: {
+ namespace_id: project.namespace.path,
+ id: project.path,
+ project: parameters,
+ }
end
end
- context 'hashed storage' do
+ context "hashed storage" do
let(:project) { create(:project, :repository) }
- it_behaves_like 'updating a project'
+ it_behaves_like "updating a project"
end
- context 'legacy storage' do
+ context "legacy storage" do
let(:project) { create(:project, :repository, :legacy_storage) }
- it_behaves_like 'updating a project'
+ it_behaves_like "updating a project"
end
end
- describe '#transfer' do
+ describe "#transfer" do
render_views
let(:project) { create(:project, :repository) }
let(:admin) { create(:admin) }
let(:new_namespace) { create(:namespace) }
- it 'updates namespace' do
+ it "updates namespace" do
sign_in(admin)
put :transfer,
- params: {
- namespace_id: project.namespace.path,
- new_namespace_id: new_namespace.id,
- id: project.path
- },
- format: :js
+ params: {
+ namespace_id: project.namespace.path,
+ new_namespace_id: new_namespace.id,
+ id: project.path,
+ },
+ format: :js
project.reload
@@ -416,26 +416,26 @@ describe ProjectsController do
expect(response).to have_gitlab_http_status(200)
end
- context 'when new namespace is empty' do
- it 'project namespace is not changed' do
+ context "when new namespace is empty" do
+ it "project namespace is not changed" do
controller.instance_variable_set(:@project, project)
sign_in(admin)
old_namespace = project.namespace
put :transfer,
- params: {
- namespace_id: old_namespace.path,
- new_namespace_id: nil,
- id: project.path
- },
- format: :js
+ params: {
+ namespace_id: old_namespace.path,
+ new_namespace_id: nil,
+ id: project.path,
+ },
+ format: :js
project.reload
expect(project.namespace).to eq(old_namespace)
expect(response).to have_gitlab_http_status(200)
- expect(flash[:alert]).to eq 'Please select a new namespace for your project.'
+ expect(flash[:alert]).to eq "Please select a new namespace for your project."
end
end
end
@@ -448,7 +448,7 @@ describe ProjectsController do
sign_in(admin)
orig_id = project.id
- delete :destroy, params: { namespace_id: project.namespace, id: project }
+ delete :destroy, params: {namespace_id: project.namespace, id: project}
expect { Project.find(orig_id) }.to raise_error(ActiveRecord::RecordNotFound)
expect(response).to have_gitlab_http_status(302)
@@ -468,20 +468,20 @@ describe ProjectsController do
project.merge_requests << merge_request
sign_in(admin)
- delete :destroy, params: { namespace_id: forked_project.namespace, id: forked_project }
+ delete :destroy, params: {namespace_id: forked_project.namespace, id: forked_project}
- expect(merge_request.reload.state).to eq('closed')
+ expect(merge_request.reload.state).to eq("closed")
end
end
end
- describe 'PUT #new_issuable_address for issue' do
+ describe "PUT #new_issuable_address for issue" do
subject do
put :new_issuable_address,
params: {
namespace_id: project.namespace,
id: project,
- issuable_type: 'issue'
+ issuable_type: "issue",
}
user.reload
end
@@ -492,26 +492,26 @@ describe ProjectsController do
allow(Gitlab.config.incoming_email).to receive(:enabled).and_return(true)
end
- it 'has http status 200' do
+ it "has http status 200" do
expect(response).to have_gitlab_http_status(200)
end
- it 'changes the user incoming email token' do
+ it "changes the user incoming email token" do
expect { subject }.to change { user.incoming_email_token }
end
- it 'changes projects new issue address' do
- expect { subject }.to change { project.new_issuable_address(user, 'issue') }
+ it "changes projects new issue address" do
+ expect { subject }.to change { project.new_issuable_address(user, "issue") }
end
end
- describe 'PUT #new_issuable_address for merge request' do
+ describe "PUT #new_issuable_address for merge request" do
subject do
put :new_issuable_address,
params: {
namespace_id: project.namespace,
id: project,
- issuable_type: 'merge_request'
+ issuable_type: "merge_request",
}
user.reload
end
@@ -522,16 +522,16 @@ describe ProjectsController do
allow(Gitlab.config.incoming_email).to receive(:enabled).and_return(true)
end
- it 'has http status 200' do
+ it "has http status 200" do
expect(response).to have_http_status(200)
end
- it 'changes the user incoming email token' do
+ it "changes the user incoming email token" do
expect { subject }.to change { user.incoming_email_token }
end
- it 'changes projects new merge request address' do
- expect { subject }.to change { project.new_issuable_address(user, 'merge_request') }
+ it "changes projects new merge request address" do
+ expect { subject }.to change { project.new_issuable_address(user, "merge_request") }
end
end
@@ -540,68 +540,68 @@ describe ProjectsController do
sign_in(user)
expect(user.starred?(public_project)).to be_falsey
post(:toggle_star,
- params: {
- namespace_id: public_project.namespace,
- id: public_project
- })
+ params: {
+ namespace_id: public_project.namespace,
+ id: public_project,
+ })
expect(user.starred?(public_project)).to be_truthy
post(:toggle_star,
- params: {
- namespace_id: public_project.namespace,
- id: public_project
- })
+ params: {
+ namespace_id: public_project.namespace,
+ id: public_project,
+ })
expect(user.starred?(public_project)).to be_falsey
end
it "does nothing if user is not signed in" do
post(:toggle_star,
- params: {
- namespace_id: project.namespace,
- id: public_project
- })
+ params: {
+ namespace_id: project.namespace,
+ id: public_project,
+ })
expect(user.starred?(public_project)).to be_falsey
post(:toggle_star,
- params: {
- namespace_id: project.namespace,
- id: public_project
- })
+ params: {
+ namespace_id: project.namespace,
+ id: public_project,
+ })
expect(user.starred?(public_project)).to be_falsey
end
end
describe "DELETE remove_fork" do
- context 'when signed in' do
+ context "when signed in" do
before do
sign_in(user)
end
- context 'with forked project' do
+ context "with forked project" do
let(:forked_project) { fork_project(create(:project, :public), user) }
- it 'removes fork from project' do
+ it "removes fork from project" do
delete(:remove_fork,
- params: {
- namespace_id: forked_project.namespace.to_param,
- id: forked_project.to_param
- },
- format: :js)
+ params: {
+ namespace_id: forked_project.namespace.to_param,
+ id: forked_project.to_param,
+ },
+ format: :js)
expect(forked_project.reload.forked?).to be_falsey
- expect(flash[:notice]).to eq('The fork relationship has been removed.')
+ expect(flash[:notice]).to eq("The fork relationship has been removed.")
expect(response).to render_template(:remove_fork)
end
end
- context 'when project not forked' do
+ context "when project not forked" do
let(:unforked_project) { create(:project, namespace: user.namespace) }
- it 'does nothing if project was not forked' do
+ it "does nothing if project was not forked" do
delete(:remove_fork,
- params: {
- namespace_id: unforked_project.namespace,
- id: unforked_project
- },
- format: :js)
+ params: {
+ namespace_id: unforked_project.namespace,
+ id: unforked_project,
+ },
+ format: :js)
expect(flash[:notice]).to be_nil
expect(response).to render_template(:remove_fork)
@@ -611,11 +611,11 @@ describe ProjectsController do
it "does nothing if user is not signed in" do
delete(:remove_fork,
- params: {
- namespace_id: project.namespace,
- id: project
- },
- format: :js)
+ params: {
+ namespace_id: project.namespace,
+ id: project,
+ },
+ format: :js)
expect(response).to have_gitlab_http_status(401)
end
end
@@ -623,18 +623,18 @@ describe ProjectsController do
describe "GET refs" do
let(:project) { create(:project, :public, :repository) }
- it 'gets a list of branches and tags' do
- get :refs, params: { namespace_id: project.namespace, id: project, sort: 'updated_desc' }
+ it "gets a list of branches and tags" do
+ get :refs, params: {namespace_id: project.namespace, id: project, sort: "updated_desc"}
parsed_body = JSON.parse(response.body)
- expect(parsed_body['Branches']).to include('master')
- expect(parsed_body['Tags'].first).to eq('v1.1.0')
- expect(parsed_body['Tags'].last).to eq('v1.0.0')
- expect(parsed_body['Commits']).to be_nil
+ expect(parsed_body["Branches"]).to include("master")
+ expect(parsed_body["Tags"].first).to eq("v1.1.0")
+ expect(parsed_body["Tags"].last).to eq("v1.0.0")
+ expect(parsed_body["Commits"]).to be_nil
end
it "gets a list of branches, tags and commits" do
- get :refs, params: { namespace_id: project.namespace, id: project, ref: "123456" }
+ get :refs, params: {namespace_id: project.namespace, id: project, ref: "123456"}
parsed_body = JSON.parse(response.body)
expect(parsed_body["Branches"]).to include("master")
@@ -644,12 +644,12 @@ describe ProjectsController do
context "when preferred language is Japanese" do
before do
- user.update!(preferred_language: 'ja')
+ user.update!(preferred_language: "ja")
sign_in(user)
end
it "gets a list of branches, tags and commits" do
- get :refs, params: { namespace_id: project.namespace, id: project, ref: "123456" }
+ get :refs, params: {namespace_id: project.namespace, id: project, ref: "123456"}
parsed_body = JSON.parse(response.body)
expect(parsed_body["Branches"]).to include("master")
@@ -658,16 +658,16 @@ describe ProjectsController do
end
end
- context 'when private project' do
+ context "when private project" do
let(:project) { create(:project, :repository) }
- context 'as a guest' do
- it 'renders forbidden' do
+ context "as a guest" do
+ it "renders forbidden" do
user = create(:user)
project.add_guest(user)
sign_in(user)
- get :refs, params: { namespace_id: project.namespace, id: project }
+ get :refs, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(404)
end
@@ -675,57 +675,57 @@ describe ProjectsController do
end
end
- describe 'POST #preview_markdown' do
+ describe "POST #preview_markdown" do
before do
sign_in(user)
end
- it 'renders json in a correct format' do
- post :preview_markdown, params: { namespace_id: public_project.namespace, id: public_project, text: '*Markdown* text' }
+ it "renders json in a correct format" do
+ post :preview_markdown, params: {namespace_id: public_project.namespace, id: public_project, text: "*Markdown* text"}
- expect(JSON.parse(response.body).keys).to match_array(%w(body references))
+ expect(JSON.parse(response.body).keys).to match_array(%w[body references])
end
- context 'state filter on references' do
+ context "state filter on references" do
let(:issue) { create(:issue, :closed, project: public_project) }
let(:merge_request) { create(:merge_request, :closed, target_project: public_project) }
- it 'renders JSON body with state filter for issues' do
+ it "renders JSON body with state filter for issues" do
post :preview_markdown, params: {
- namespace_id: public_project.namespace,
- id: public_project,
- text: issue.to_reference
- }
+ namespace_id: public_project.namespace,
+ id: public_project,
+ text: issue.to_reference,
+ }
json_response = JSON.parse(response.body)
- expect(json_response['body']).to match(/\##{issue.iid} \(closed\)/)
+ expect(json_response["body"]).to match(/\##{issue.iid} \(closed\)/)
end
- it 'renders JSON body with state filter for MRs' do
+ it "renders JSON body with state filter for MRs" do
post :preview_markdown, params: {
- namespace_id: public_project.namespace,
- id: public_project,
- text: merge_request.to_reference
- }
+ namespace_id: public_project.namespace,
+ id: public_project,
+ text: merge_request.to_reference,
+ }
json_response = JSON.parse(response.body)
- expect(json_response['body']).to match(/\!#{merge_request.iid} \(closed\)/)
+ expect(json_response["body"]).to match(/\!#{merge_request.iid} \(closed\)/)
end
end
end
- describe '#ensure_canonical_path' do
+ describe "#ensure_canonical_path" do
before do
sign_in(user)
end
- context 'for a GET request' do
- context 'when requesting the canonical path' do
+ context "for a GET request" do
+ context "when requesting the canonical path" do
context "with exactly matching casing" do
it "loads the project" do
- get :show, params: { namespace_id: public_project.namespace, id: public_project }
+ get :show, params: {namespace_id: public_project.namespace, id: public_project}
expect(assigns(:project)).to eq(public_project)
expect(response).to have_gitlab_http_status(200)
@@ -734,7 +734,7 @@ describe ProjectsController do
context "with different casing" do
it "redirects to the normalized path" do
- get :show, params: { namespace_id: public_project.namespace, id: public_project.path.upcase }
+ get :show, params: {namespace_id: public_project.namespace, id: public_project.path.upcase}
expect(assigns(:project)).to eq(public_project)
expect(response).to redirect_to("/#{public_project.full_path}")
@@ -743,18 +743,18 @@ describe ProjectsController do
end
end
- context 'when requesting a redirected path' do
+ context "when requesting a redirected path" do
let!(:redirect_route) { public_project.redirect_routes.create!(path: "foo/bar") }
- it 'redirects to the canonical path' do
- get :show, params: { namespace_id: 'foo', id: 'bar' }
+ it "redirects to the canonical path" do
+ get :show, params: {namespace_id: "foo", id: "bar"}
expect(response).to redirect_to(public_project)
expect(controller).to set_flash[:notice].to(project_moved_message(redirect_route, public_project))
end
- it 'redirects to the canonical path (testing non-show action)' do
- get :refs, params: { namespace_id: 'foo', id: 'bar' }
+ it "redirects to the canonical path (testing non-show action)" do
+ get :refs, params: {namespace_id: "foo", id: "bar"}
expect(response).to redirect_to(refs_project_path(public_project))
expect(controller).to set_flash[:notice].to(project_moved_message(redirect_route, public_project))
@@ -762,56 +762,56 @@ describe ProjectsController do
end
end
- context 'for a POST request' do
- context 'when requesting the canonical path with different casing' do
- it 'does not 404' do
- post :toggle_star, params: { namespace_id: public_project.namespace, id: public_project.path.upcase }
+ context "for a POST request" do
+ context "when requesting the canonical path with different casing" do
+ it "does not 404" do
+ post :toggle_star, params: {namespace_id: public_project.namespace, id: public_project.path.upcase}
expect(response).not_to have_gitlab_http_status(404)
end
- it 'does not redirect to the correct casing' do
- post :toggle_star, params: { namespace_id: public_project.namespace, id: public_project.path.upcase }
+ it "does not redirect to the correct casing" do
+ post :toggle_star, params: {namespace_id: public_project.namespace, id: public_project.path.upcase}
expect(response).not_to have_gitlab_http_status(301)
end
end
- context 'when requesting a redirected path' do
+ context "when requesting a redirected path" do
let!(:redirect_route) { public_project.redirect_routes.create!(path: "foo/bar") }
- it 'returns not found' do
- post :toggle_star, params: { namespace_id: 'foo', id: 'bar' }
+ it "returns not found" do
+ post :toggle_star, params: {namespace_id: "foo", id: "bar"}
expect(response).to have_gitlab_http_status(404)
end
end
end
- context 'for a DELETE request' do
+ context "for a DELETE request" do
before do
sign_in(create(:admin))
end
- context 'when requesting the canonical path with different casing' do
- it 'does not 404' do
- delete :destroy, params: { namespace_id: project.namespace, id: project.path.upcase }
+ context "when requesting the canonical path with different casing" do
+ it "does not 404" do
+ delete :destroy, params: {namespace_id: project.namespace, id: project.path.upcase}
expect(response).not_to have_gitlab_http_status(404)
end
- it 'does not redirect to the correct casing' do
- delete :destroy, params: { namespace_id: project.namespace, id: project.path.upcase }
+ it "does not redirect to the correct casing" do
+ delete :destroy, params: {namespace_id: project.namespace, id: project.path.upcase}
expect(response).not_to have_gitlab_http_status(301)
end
end
- context 'when requesting a redirected path' do
+ context "when requesting a redirected path" do
let!(:redirect_route) { project.redirect_routes.create!(path: "foo/bar") }
- it 'returns not found' do
- delete :destroy, params: { namespace_id: 'foo', id: 'bar' }
+ it "returns not found" do
+ delete :destroy, params: {namespace_id: "foo", id: "bar"}
expect(response).to have_gitlab_http_status(404)
end
@@ -819,57 +819,57 @@ describe ProjectsController do
end
end
- describe '#export' do
+ describe "#export" do
before do
sign_in(user)
project.add_maintainer(user)
end
- context 'when project export is enabled' do
- it 'returns 302' do
- get :export, params: { namespace_id: project.namespace, id: project }
+ context "when project export is enabled" do
+ it "returns 302" do
+ get :export, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(302)
end
end
- context 'when project export is disabled' do
+ context "when project export is disabled" do
before do
stub_application_setting(project_export_enabled?: false)
end
- it 'returns 404' do
- get :export, params: { namespace_id: project.namespace, id: project }
+ it "returns 404" do
+ get :export, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(404)
end
end
end
- describe '#download_export' do
+ describe "#download_export" do
before do
sign_in(user)
project.add_maintainer(user)
end
- context 'object storage enabled' do
- context 'when project export is enabled' do
- it 'returns 302' do
- get :download_export, params: { namespace_id: project.namespace, id: project }
+ context "object storage enabled" do
+ context "when project export is enabled" do
+ it "returns 302" do
+ get :download_export, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(302)
end
end
- context 'when project export is disabled' do
+ context "when project export is disabled" do
before do
stub_application_setting(project_export_enabled?: false)
end
- it 'returns 404' do
- get :download_export, params: { namespace_id: project.namespace, id: project }
+ it "returns 404" do
+ get :download_export, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(404)
end
@@ -877,66 +877,66 @@ describe ProjectsController do
end
end
- describe '#remove_export' do
+ describe "#remove_export" do
before do
sign_in(user)
project.add_maintainer(user)
end
- context 'when project export is enabled' do
- it 'returns 302' do
- post :remove_export, params: { namespace_id: project.namespace, id: project }
+ context "when project export is enabled" do
+ it "returns 302" do
+ post :remove_export, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(302)
end
end
- context 'when project export is disabled' do
+ context "when project export is disabled" do
before do
stub_application_setting(project_export_enabled?: false)
end
- it 'returns 404' do
- post :remove_export, params: { namespace_id: project.namespace, id: project }
+ it "returns 404" do
+ post :remove_export, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(404)
end
end
end
- describe '#generate_new_export' do
+ describe "#generate_new_export" do
before do
sign_in(user)
project.add_maintainer(user)
end
- context 'when project export is enabled' do
- it 'returns 302' do
- post :generate_new_export, params: { namespace_id: project.namespace, id: project }
+ context "when project export is enabled" do
+ it "returns 302" do
+ post :generate_new_export, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(302)
end
end
- context 'when project export is disabled' do
+ context "when project export is disabled" do
before do
stub_application_setting(project_export_enabled?: false)
end
- it 'returns 404' do
- post :generate_new_export, params: { namespace_id: project.namespace, id: project }
+ it "returns 404" do
+ post :generate_new_export, params: {namespace_id: project.namespace, id: project}
expect(response).to have_gitlab_http_status(404)
end
end
end
- context 'private project with token authentication' do
+ context "private project with token authentication" do
let(:private_project) { create(:project, :private) }
- it_behaves_like 'authenticates sessionless user', :show, :atom do
+ it_behaves_like "authenticates sessionless user", :show, :atom do
before do
default_params.merge!(id: private_project, namespace_id: private_project.namespace)
@@ -945,63 +945,63 @@ describe ProjectsController do
end
end
- context 'public project with token authentication' do
+ context "public project with token authentication" do
let(:public_project) { create(:project, :public) }
- it_behaves_like 'authenticates sessionless user', :show, :atom, public: true do
+ it_behaves_like "authenticates sessionless user", :show, :atom, public: true do
before do
default_params.merge!(id: public_project, namespace_id: public_project.namespace)
end
end
end
- describe 'GET resolve' do
- shared_examples 'resolvable endpoint' do
- it 'redirects to the project page' do
- get :resolve, params: { id: project.id }
+ describe "GET resolve" do
+ shared_examples "resolvable endpoint" do
+ it "redirects to the project page" do
+ get :resolve, params: {id: project.id}
expect(response).to have_gitlab_http_status(302)
expect(response).to redirect_to(project_path(project))
end
end
- context 'with an authenticated user' do
+ context "with an authenticated user" do
before do
sign_in(user)
end
- context 'when user has access to the project' do
+ context "when user has access to the project" do
before do
project.add_developer(user)
end
- it_behaves_like 'resolvable endpoint'
+ it_behaves_like "resolvable endpoint"
end
- context 'when user has no access to the project' do
- it 'gives 404 for existing project' do
- get :resolve, params: { id: project.id }
+ context "when user has no access to the project" do
+ it "gives 404 for existing project" do
+ get :resolve, params: {id: project.id}
expect(response).to have_gitlab_http_status(404)
end
end
- it 'gives 404 for non-existing project' do
- get :resolve, params: { id: '0' }
+ it "gives 404 for non-existing project" do
+ get :resolve, params: {id: "0"}
expect(response).to have_gitlab_http_status(404)
end
end
- context 'non authenticated user' do
- context 'with a public project' do
+ context "non authenticated user" do
+ context "with a public project" do
let(:project) { public_project }
- it_behaves_like 'resolvable endpoint'
+ it_behaves_like "resolvable endpoint"
end
- it 'gives 404 for private project' do
- get :resolve, params: { id: project.id }
+ it "gives 404 for private project" do
+ get :resolve, params: {id: project.id}
expect(response).to have_gitlab_http_status(404)
end