require 'spec_helper' describe ChatMessage::PipelineMessage do subject { described_class.new(args) } let(:user) { { name: 'hacker' } } let(:args) do { object_attributes: { id: 123, sha: '97de212e80737a608d939f648d959671fb0a0142', tag: false, ref: 'develop', status: status, duration: duration }, project: { path_with_namespace: 'project_name', web_url: 'example.gitlab.com' }, user: user } end let(:message) { build_message } context 'pipeline succeeded' do let(:status) { 'success' } let(:color) { 'good' } let(:duration) { 10 } let(:message) { build_message('passed') } it 'returns a message with information about succeeded build' do verify_message end end context 'pipeline failed' do let(:status) { 'failed' } let(:color) { 'danger' } let(:duration) { 10 } it 'returns a message with information about failed build' do verify_message end context 'when triggered by API therefore lacking user' do let(:user) { nil } let(:message) { build_message(status, 'API') } it 'returns a message stating it is by API' do verify_message end end end def verify_message expect(subject.pretext).to be_empty expect(subject.fallback).to eq(message) expect(subject.attachments).to eq([text: message, color: color]) end def build_message(status_text = status, name = user[:name]) "<example.gitlab.com|project_name>:" \ " Pipeline <example.gitlab.com/pipelines/123|#123>" \ " of <example.gitlab.com/commits/develop|develop> branch" \ " by #{name} #{status_text} in #{duration} #{'second'.pluralize(duration)}" end end