Fix rspec tests due to different API

[ci skip]
This commit is contained in:
Z.J. van de Weg 2016-12-20 20:56:46 +01:00
parent 0bd8669f3a
commit 4a03fae930
5 changed files with 33 additions and 36 deletions

View file

@ -75,9 +75,9 @@ module Mattermost
def get(path, options = {})
self.class.get(path, options.merge(headers: @headers))
rescue HTTParty::Error => e
raise ConnectionError(e.message)
raise Mattermost::ConnectionError.new(e.message)
rescue Errno::ECONNREFUSED => e
raise ConnectionError(e.message)
raise Mattermost::ConnectionError.new(e.message)
end
def post(path, options = {})

View file

@ -4,10 +4,12 @@ feature 'Setup Mattermost slash commands', feature: true do
include WaitForAjax
let(:user) { create(:user) }
let(:project) { create(:project) }
let(:project) { create(:empty_project) }
let(:service) { project.create_mattermost_slash_commands_service }
let(:mattermost_enabled) { true }
before do
Settings.mattermost['enabled'] = mattermost_enabled
project.team << [user, :master]
login_as(user)
visit edit_namespace_project_service_path(project.namespace, project, service)
@ -32,19 +34,13 @@ feature 'Setup Mattermost slash commands', feature: true do
end
describe 'mattermost service is enabled' do
before do
allow(Gitlab.config.mattermost).to receive(:enabled).and_return(true)
end
it 'shows the add to mattermost button' do
expect(page).to have_link 'Add to Mattermost'
end
end
describe 'mattermost service is not enabled' do
before do
allow(Gitlab.config.mattermost).to receive(:enabled).and_return(false)
end
let(:mattermost_enabled) { false }
it 'shows the correct trigger url' do
value = find_field('request_url').value

View file

@ -1,17 +1,22 @@
require 'spec_helper'
describe Mattermost::Command do
let(:hash) { { 'token' => 'token' } }
let(:user) { create(:user) }
let(:params) { { 'token' => 'token', team_id: 'abc' } }
let(:user) { build(:user) }
before do
Mattermost::Session.base_uri("http://mattermost.example.com")
end
subject { described_class.new(user) }
describe '#create' do
it 'creates a command' do
described_class.new(user).
create(team_id: 'abc', url: 'http://trigger.com')
it 'interpolates the team id' do
allow(subject).to receive(:json_post).
with('/api/v3/teams/abc/commands/create', body: params.to_json).
and_return('token' => 'token')
subject.create(params)
end
end
end

View file

@ -2,7 +2,9 @@ require 'spec_helper'
describe Mattermost::Team do
describe '#all' do
let(:session) { double("session") }
let(:user) { build(:user) }
subject { described_class.new(user) }
let(:response) do
[{
@ -20,22 +22,13 @@ describe Mattermost::Team do
"allow_open_invite" => false }]
end
let(:json) { nil }
before do
allow(session).to receive(:get).with('/api/v3/teams/all').
and_return(json)
allow(json).to receive(:parsed_response).and_return(response)
allow(subject).to receive(:json_get).and_return(response)
end
it 'gets the teams' do
expect(described_class.all(session).count).to be(1)
end
it 'filters on being team admin' do
ids = described_class.all(session).map { |team| team['id'] }
expect(ids).to include("xiyro8huptfhdndadpz8r3wnbo")
expect(subject.all.count).to be(1)
end
end
end

View file

@ -3,23 +3,23 @@ require 'spec_helper'
describe MattermostSlashCommandsService, :models do
it_behaves_like "chat slash commands service"
describe '#configure!' do
describe '#configure' do
let(:project) { create(:empty_project) }
let(:service) { project.build_mattermost_slash_commands_service }
let(:user) { create(:user)}
before do
allow_any_instance_of(Mattermost::Session).to
receive(:with_session).and_yield
end
subject do
service.configure!(user, team_id: 'abc',
service.configure(user, team_id: 'abc',
trigger: 'gitlab', url: 'http://trigger.url',
icon_url: 'http://icon.url/icon.png')
end
context 'the requests succeeds' do
before do
allow_any_instance_of(Mattermost::Command).
to receive(:json_post).and_return('token' => 'token')
end
it 'saves the service' do
expect { subject }.to change { project.services.count }.by(1)
end
@ -27,13 +27,16 @@ describe MattermostSlashCommandsService, :models do
it 'saves the token' do
subject
expect(service.reload.token).to eq('mynewtoken')
expect(service.reload.token).to eq('token')
end
end
context 'an error is received' do
it 'shows error messages' do
expect(subject).to raise_error("Error")
succeeded, message = subject
expect(succeeded).to be(false)
expect(message).to start_with("Failed to open TCP connection to")
end
end
end