2020-05-14 08:08:21 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-24 02:09:01 -04:00
|
|
|
RSpec.describe StateNote do
|
2020-05-14 08:08:21 -04:00
|
|
|
describe '.from_event' do
|
|
|
|
let_it_be(:author) { create(:user) }
|
|
|
|
let_it_be(:project) { create(:project, :repository) }
|
|
|
|
let_it_be(:noteable) { create(:issue, author: author, project: project) }
|
|
|
|
|
|
|
|
ResourceStateEvent.states.each do |state, _value|
|
|
|
|
context "with event state #{state}" do
|
2020-07-15 08:09:26 -04:00
|
|
|
let(:event) { create(:resource_state_event, issue: noteable, state: state, created_at: '2020-02-05') }
|
2020-05-14 08:08:21 -04:00
|
|
|
|
|
|
|
subject { described_class.from_event(event, resource: noteable, resource_parent: project) }
|
|
|
|
|
2020-07-15 08:09:26 -04:00
|
|
|
it_behaves_like 'a synthetic note', state == 'reopened' ? 'opened' : state
|
|
|
|
|
|
|
|
it 'contains the expected values' do
|
|
|
|
expect(subject.author).to eq(author)
|
|
|
|
expect(subject.created_at).to eq(event.created_at)
|
|
|
|
expect(subject.note).to eq(state)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a mentionable source' do
|
|
|
|
subject { described_class.from_event(event, resource: noteable, resource_parent: project) }
|
|
|
|
|
|
|
|
context 'with a commit' do
|
|
|
|
let(:commit) { create(:commit, project: project) }
|
|
|
|
let(:event) { create(:resource_state_event, issue: noteable, state: :closed, created_at: '2020-02-05', source_commit: commit.id) }
|
|
|
|
|
|
|
|
it 'contains the expected values' do
|
|
|
|
expect(subject.author).to eq(author)
|
|
|
|
expect(subject.created_at).to eq(subject.created_at)
|
|
|
|
expect(subject.note).to eq("closed via commit #{commit.id}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a merge request' do
|
|
|
|
let(:merge_request) { create(:merge_request, source_project: project) }
|
|
|
|
let(:event) { create(:resource_state_event, issue: noteable, state: :closed, created_at: '2020-02-05', source_merge_request: merge_request) }
|
|
|
|
|
|
|
|
it 'contains the expected values' do
|
|
|
|
expect(subject.author).to eq(author)
|
|
|
|
expect(subject.created_at).to eq(event.created_at)
|
|
|
|
expect(subject.note).to eq("closed via merge request !#{merge_request.iid}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when closed by error tracking' do
|
|
|
|
let(:event) { create(:resource_state_event, issue: noteable, state: :closed, created_at: '2020-02-05', close_after_error_tracking_resolve: true) }
|
|
|
|
|
|
|
|
it 'contains the expected values' do
|
|
|
|
expect(subject.author).to eq(author)
|
|
|
|
expect(subject.created_at).to eq(event.created_at)
|
|
|
|
expect(subject.note).to eq('resolved the corresponding error and closed the issue.')
|
2020-05-14 08:08:21 -04:00
|
|
|
end
|
2020-07-15 08:09:26 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when closed by promotheus alert' do
|
|
|
|
let(:event) { create(:resource_state_event, issue: noteable, state: :closed, created_at: '2020-02-05', close_auto_resolve_prometheus_alert: true) }
|
2020-05-14 08:08:21 -04:00
|
|
|
|
|
|
|
it 'contains the expected values' do
|
|
|
|
expect(subject.author).to eq(author)
|
|
|
|
expect(subject.created_at).to eq(event.created_at)
|
2020-07-15 08:09:26 -04:00
|
|
|
expect(subject.note).to eq('automatically closed this issue because the alert resolved.')
|
2020-05-14 08:08:21 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|