summaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
authorJames Lopez <james@gitlab.com>2019-06-10 09:31:05 +0000
committerGitLab Release Tools Bot <delivery-team+release-tools@gitlab.com>2019-06-26 10:04:48 +0000
commite3bb5f49e09621e57b6afcccc6844cd4f13b3888 (patch)
treeaa007d5a3d7f16548bad0204d8a16fe70ffa0856 /spec
parent0c3b3dda5fcd98c0cb7c08321b412b5e338bb63b (diff)
downloadgitlab-ce-e3bb5f49e09621e57b6afcccc6844cd4f13b3888.tar.gz
Merge branch 'sh-fix-fogbugz-import' into 'master'
Fix Fogbugz Importer not working Closes #33530 See merge request gitlab-org/gitlab-ce!29383 (cherry picked from commit 895519a83e186071a6144917806250fb8da59036) 1a4d1b05 Fix Fogbugz Importer not working
Diffstat (limited to 'spec')
-rw-r--r--spec/controllers/import/fogbugz_controller_spec.rb38
1 files changed, 38 insertions, 0 deletions
diff --git a/spec/controllers/import/fogbugz_controller_spec.rb b/spec/controllers/import/fogbugz_controller_spec.rb
index f1e0923f316..f7c813576aa 100644
--- a/spec/controllers/import/fogbugz_controller_spec.rb
+++ b/spec/controllers/import/fogbugz_controller_spec.rb
@@ -11,6 +11,44 @@ describe Import::FogbugzController do
sign_in(user)
end
+ describe 'POST #callback' do
+ let(:token) { FFaker::Lorem.characters(8) }
+ let(:uri) { 'https://example.com' }
+ let(:xml_response) { %Q(<?xml version=\"1.0\" encoding=\"UTF-8\"?><response><token><![CDATA[#{token}]]></token></response>) }
+
+ it 'attempts to contact Fogbugz server' do
+ stub_request(:post, "https://example.com/api.asp").to_return(status: 200, body: xml_response, headers: {})
+
+ post :callback, params: { uri: uri, email: 'test@example.com', password: 'mypassword' }
+
+ expect(session[:fogbugz_token]).to eq(token)
+ expect(session[:fogbugz_uri]).to eq(uri)
+ expect(response).to redirect_to(new_user_map_import_fogbugz_path)
+ end
+ end
+
+ describe 'POST #create_user_map' do
+ let(:user_map) do
+ {
+ "2" => {
+ "name" => "Test User",
+ "email" => "testuser@example.com",
+ "gitlab_user" => "3"
+ }
+ }
+ end
+
+ it 'stores the user map in the session' do
+ client = double(user_map: {})
+ expect(controller).to receive(:client).and_return(client)
+
+ post :create_user_map, params: { users: user_map }
+
+ expect(session[:fogbugz_user_map]).to eq(user_map)
+ expect(response).to redirect_to(status_import_fogbugz_path)
+ end
+ end
+
describe 'GET status' do
before do
@repo = OpenStruct.new(name: 'vim')