2015-04-26 12:48:37 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe Import::GitlabController do
|
2015-09-11 14:41:01 +05:30
|
|
|
include ImportSpecHelper
|
|
|
|
|
2015-09-25 12:07:36 +05:30
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:token) { "asdasd12345" }
|
|
|
|
let(:access_params) { { gitlab_access_token: token } }
|
|
|
|
|
|
|
|
def assign_session_token
|
|
|
|
session[:gitlab_access_token] = token
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
before do
|
|
|
|
sign_in(user)
|
2015-09-11 14:41:01 +05:30
|
|
|
allow(controller).to receive(:gitlab_import_enabled?).and_return(true)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET callback" do
|
|
|
|
it "updates access token" do
|
2015-09-11 14:41:01 +05:30
|
|
|
allow_any_instance_of(Gitlab::GitlabImport::Client).
|
|
|
|
to receive(:get_token).and_return(token)
|
|
|
|
stub_omniauth_provider('gitlab')
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
get :callback
|
|
|
|
|
2015-09-25 12:07:36 +05:30
|
|
|
expect(session[:gitlab_access_token]).to eq(token)
|
2015-04-26 12:48:37 +05:30
|
|
|
expect(controller).to redirect_to(status_import_gitlab_url)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET status" do
|
|
|
|
before do
|
|
|
|
@repo = OpenStruct.new(path: 'vim', path_with_namespace: 'asd/vim')
|
2015-09-25 12:07:36 +05:30
|
|
|
assign_session_token
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it "assigns variables" do
|
2017-08-17 22:00:37 +05:30
|
|
|
@project = create(:empty_project, import_type: 'gitlab', creator_id: user.id)
|
2015-09-11 14:41:01 +05:30
|
|
|
stub_client(projects: [@repo])
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
get :status
|
|
|
|
|
|
|
|
expect(assigns(:already_added_projects)).to eq([@project])
|
|
|
|
expect(assigns(:repos)).to eq([@repo])
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not show already added project" do
|
2017-08-17 22:00:37 +05:30
|
|
|
@project = create(:empty_project, import_type: 'gitlab', creator_id: user.id, import_source: 'asd/vim')
|
2015-09-11 14:41:01 +05:30
|
|
|
stub_client(projects: [@repo])
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
get :status
|
|
|
|
|
|
|
|
expect(assigns(:already_added_projects)).to eq([@project])
|
|
|
|
expect(assigns(:repos)).to eq([])
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "POST create" do
|
|
|
|
let(:gitlab_username) { user.username }
|
2015-09-11 14:41:01 +05:30
|
|
|
let(:gitlab_user) do
|
|
|
|
{ username: gitlab_username }.with_indifferent_access
|
|
|
|
end
|
|
|
|
let(:gitlab_repo) do
|
2015-04-26 12:48:37 +05:30
|
|
|
{
|
|
|
|
path: 'vim',
|
|
|
|
path_with_namespace: "#{gitlab_username}/vim",
|
|
|
|
owner: { name: gitlab_username },
|
|
|
|
namespace: { path: gitlab_username }
|
|
|
|
}.with_indifferent_access
|
2015-09-11 14:41:01 +05:30
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
before do
|
2015-09-11 14:41:01 +05:30
|
|
|
stub_client(user: gitlab_user, project: gitlab_repo)
|
2015-09-25 12:07:36 +05:30
|
|
|
assign_session_token
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
context "when the repository owner is the GitLab.com user" do
|
|
|
|
context "when the GitLab.com user and GitLab server user's usernames match" do
|
|
|
|
it "takes the current user's namespace" do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
2015-09-25 12:07:36 +05:30
|
|
|
to receive(:new).with(gitlab_repo, user.namespace, user, access_params).
|
2015-04-26 12:48:37 +05:30
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
post :create, format: :js
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the GitLab.com user and GitLab server user's usernames don't match" do
|
|
|
|
let(:gitlab_username) { "someone_else" }
|
|
|
|
|
|
|
|
it "takes the current user's namespace" do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
2015-09-25 12:07:36 +05:30
|
|
|
to receive(:new).with(gitlab_repo, user.namespace, user, access_params).
|
2015-04-26 12:48:37 +05:30
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
post :create, format: :js
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the repository owner is not the GitLab.com user" do
|
|
|
|
let(:other_username) { "someone_else" }
|
|
|
|
|
|
|
|
before do
|
|
|
|
gitlab_repo["namespace"]["path"] = other_username
|
2015-09-25 12:07:36 +05:30
|
|
|
assign_session_token
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
context "when a namespace with the GitLab.com user's username already exists" do
|
|
|
|
let!(:existing_namespace) { create(:namespace, name: other_username, owner: user) }
|
|
|
|
|
|
|
|
context "when the namespace is owned by the GitLab server user" do
|
|
|
|
it "takes the existing namespace" do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
2015-09-25 12:07:36 +05:30
|
|
|
to receive(:new).with(gitlab_repo, existing_namespace, user, access_params).
|
2015-04-26 12:48:37 +05:30
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
post :create, format: :js
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the namespace is not owned by the GitLab server user" do
|
|
|
|
before do
|
|
|
|
existing_namespace.owner = create(:user)
|
|
|
|
existing_namespace.save
|
|
|
|
end
|
|
|
|
|
|
|
|
it "doesn't create a project" do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
not_to receive(:new)
|
|
|
|
|
|
|
|
post :create, format: :js
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when a namespace with the GitLab.com user's username doesn't exist" do
|
2016-09-29 09:46:39 +05:30
|
|
|
context "when current user can create namespaces" do
|
|
|
|
it "creates the namespace" do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).and_return(double(execute: true))
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-09-29 09:46:39 +05:30
|
|
|
expect { post :create, format: :js }.to change(Namespace, :count).by(1)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "takes the new namespace" do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).with(gitlab_repo, an_instance_of(Group), user, access_params).
|
|
|
|
and_return(double(execute: true))
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-09-29 09:46:39 +05:30
|
|
|
post :create, format: :js
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
2016-09-29 09:46:39 +05:30
|
|
|
context "when current user can't create namespaces" do
|
|
|
|
before do
|
|
|
|
user.update_attribute(:can_create_group, false)
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-09-29 09:46:39 +05:30
|
|
|
it "doesn't create the namespace" do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).and_return(double(execute: true))
|
|
|
|
|
|
|
|
expect { post :create, format: :js }.not_to change(Namespace, :count)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "takes the current user's namespace" do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).with(gitlab_repo, user.namespace, user, access_params).
|
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
post :create, format: :js
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
context 'user has chosen an existing nested namespace for the project' do
|
|
|
|
let(:parent_namespace) { create(:namespace, name: 'foo', owner: user) }
|
|
|
|
let(:nested_namespace) { create(:namespace, name: 'bar', parent: parent_namespace, owner: user) }
|
|
|
|
|
|
|
|
it 'takes the selected namespace and name' do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).with(gitlab_repo, nested_namespace, user, access_params).
|
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
post :create, { target_namespace: nested_namespace.full_path, format: :js }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'user has chosen a non-existent nested namespaces for the project' do
|
|
|
|
let(:test_name) { 'test_name' }
|
|
|
|
|
|
|
|
it 'takes the selected namespace and name' do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).with(gitlab_repo, kind_of(Namespace), user, access_params).
|
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
post :create, { target_namespace: 'foo/bar', format: :js }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates the namespaces' do
|
|
|
|
allow(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).with(gitlab_repo, kind_of(Namespace), user, access_params).
|
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
expect { post :create, { target_namespace: 'foo/bar', format: :js } }
|
|
|
|
.to change { Namespace.count }.by(2)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'new namespace has the right parent' do
|
|
|
|
allow(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).with(gitlab_repo, kind_of(Namespace), user, access_params).
|
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
post :create, { target_namespace: 'foo/bar', format: :js }
|
|
|
|
|
|
|
|
expect(Namespace.find_by_path_or_name('bar').parent.path).to eq('foo')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'user has chosen existent and non-existent nested namespaces and name for the project' do
|
|
|
|
let(:test_name) { 'test_name' }
|
|
|
|
let!(:parent_namespace) { create(:namespace, name: 'foo', owner: user) }
|
|
|
|
|
|
|
|
it 'takes the selected namespace and name' do
|
|
|
|
expect(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).with(gitlab_repo, kind_of(Namespace), user, access_params).
|
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
post :create, { target_namespace: 'foo/foobar/bar', format: :js }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates the namespaces' do
|
|
|
|
allow(Gitlab::GitlabImport::ProjectCreator).
|
|
|
|
to receive(:new).with(gitlab_repo, kind_of(Namespace), user, access_params).
|
|
|
|
and_return(double(execute: true))
|
|
|
|
|
|
|
|
expect { post :create, { target_namespace: 'foo/foobar/bar', format: :js } }
|
|
|
|
.to change { Namespace.count }.by(2)
|
|
|
|
end
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|