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
diff options
context:
space:
mode:
authorZ.J. van de Weg <git@zjvandeweg.nl>2016-12-12 11:31:48 +0300
committerZ.J. van de Weg <git@zjvandeweg.nl>2016-12-12 13:48:41 +0300
commit429c9220f0ce49fa54ea640cbfc78e3591202138 (patch)
treee3a50dd2dc3c724ff9aeb61e08e08856b2ae7676 /spec/lib/mattermost
parentdb9e1635d0d17596193ecbee8e0acc1916918d1d (diff)
Setup mattermost session
Diffstat (limited to 'spec/lib/mattermost')
-rw-r--r--spec/lib/mattermost/mattermost_spec.rb42
1 files changed, 42 insertions, 0 deletions
diff --git a/spec/lib/mattermost/mattermost_spec.rb b/spec/lib/mattermost/mattermost_spec.rb
new file mode 100644
index 00000000000..7c99b4df9f3
--- /dev/null
+++ b/spec/lib/mattermost/mattermost_spec.rb
@@ -0,0 +1,42 @@
+require 'spec_helper'
+
+describe Mattermost::Mattermost do
+ let(:user) { create(:user) }
+
+ subject { described_class.new('http://localhost:8065', user) }
+
+ # Needed for doorman to function
+ it { is_expected.to respond_to(:current_resource_owner) }
+ it { is_expected.to respond_to(:request) }
+ it { is_expected.to respond_to(:authorization) }
+ it { is_expected.to respond_to(:strategy) }
+
+ describe '#with session' do
+ let!(:stub) do
+ WebMock.stub_request(:get, 'http://localhost:8065/api/v3/oauth/gitlab/login').
+ to_return(headers: { 'location' => 'http://mylocation.com' }, status: 307)
+ end
+
+ context 'without oauth uri' do
+ it 'makes a request to the oauth uri' do
+ expect { subject.with_session }.to raise_error(Mattermost::NoSessionError)
+ end
+
+ context 'with oauth_uri' do
+ let!(:doorkeeper) do
+ Doorkeeper::Application.create(name: "GitLab Mattermost",
+ redirect_uri: "http://localhost:8065/signup/gitlab/complete\nhttp://localhost:8065/login/gitlab/complete",
+ scopes: "")
+ end
+
+ context 'without token_uri' do
+ it 'can not create a session' do
+ expect do
+ subject.with_session
+ end.to raise_error(Mattermost::NoSessionError)
+ end
+ end
+ end
+ end
+ end
+end