2015-04-26 12:48:37 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2015-12-23 02:04:40 +05:30
|
|
|
describe 'Gitlab::NoteDataBuilder', lib: true do
|
2015-04-26 12:48:37 +05:30
|
|
|
let(:project) { create(:project) }
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:data) { Gitlab::NoteDataBuilder.build(note, user) }
|
|
|
|
let(:fixed_time) { Time.at(1425600000) } # Avoid time precision errors
|
|
|
|
|
|
|
|
before(:each) do
|
|
|
|
expect(data).to have_key(:object_attributes)
|
|
|
|
expect(data[:object_attributes]).to have_key(:url)
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(data[:object_attributes][:url])
|
|
|
|
.to eq(Gitlab::UrlBuilder.build(note))
|
2015-04-26 12:48:37 +05:30
|
|
|
expect(data[:object_kind]).to eq('note')
|
|
|
|
expect(data[:user]).to eq(user.hook_attrs)
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'When asking for a note on commit' do
|
2016-04-02 18:10:28 +05:30
|
|
|
let(:note) { create(:note_on_commit, project: project) }
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
it 'returns the note and commit-specific data' do
|
|
|
|
expect(data).to have_key(:commit)
|
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
|
|
|
|
include_examples 'project hook data'
|
|
|
|
include_examples 'deprecated repository hook data'
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe 'When asking for a note on commit diff' do
|
2016-08-24 12:49:21 +05:30
|
|
|
let(:note) { create(:diff_note_on_commit, project: project) }
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
it 'returns the note and commit-specific data' do
|
|
|
|
expect(data).to have_key(:commit)
|
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
|
|
|
|
include_examples 'project hook data'
|
|
|
|
include_examples 'deprecated repository hook data'
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe 'When asking for a note on issue' do
|
2016-06-16 23:09:34 +05:30
|
|
|
let(:issue) do
|
|
|
|
create(:issue, created_at: fixed_time, updated_at: fixed_time,
|
|
|
|
project: project)
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:note) do
|
|
|
|
create(:note_on_issue, noteable: issue, project: project)
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
it 'returns the note and issue-specific data' do
|
|
|
|
expect(data).to have_key(:issue)
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(data[:issue].except('updated_at'))
|
|
|
|
.to eq(issue.reload.hook_attrs.except('updated_at'))
|
|
|
|
expect(data[:issue]['updated_at'])
|
|
|
|
.to be > issue.hook_attrs['updated_at']
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
|
|
|
|
include_examples 'project hook data'
|
|
|
|
include_examples 'deprecated repository hook data'
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe 'When asking for a note on merge request' do
|
2016-06-16 23:09:34 +05:30
|
|
|
let(:merge_request) do
|
|
|
|
create(:merge_request, created_at: fixed_time,
|
|
|
|
updated_at: fixed_time,
|
|
|
|
source_project: project)
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:note) do
|
|
|
|
create(:note_on_merge_request, noteable: merge_request,
|
|
|
|
project: project)
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
it 'returns the note and merge request data' do
|
|
|
|
expect(data).to have_key(:merge_request)
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(data[:merge_request].except('updated_at'))
|
|
|
|
.to eq(merge_request.reload.hook_attrs.except('updated_at'))
|
|
|
|
expect(data[:merge_request]['updated_at'])
|
|
|
|
.to be > merge_request.hook_attrs['updated_at']
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
|
|
|
|
include_examples 'project hook data'
|
|
|
|
include_examples 'deprecated repository hook data'
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe 'When asking for a note on merge request diff' do
|
2016-06-16 23:09:34 +05:30
|
|
|
let(:merge_request) do
|
|
|
|
create(:merge_request, created_at: fixed_time, updated_at: fixed_time,
|
|
|
|
source_project: project)
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:note) do
|
2016-08-24 12:49:21 +05:30
|
|
|
create(:diff_note_on_merge_request, noteable: merge_request,
|
2016-06-16 23:09:34 +05:30
|
|
|
project: project)
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
it 'returns the note and merge request diff data' do
|
|
|
|
expect(data).to have_key(:merge_request)
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(data[:merge_request].except('updated_at'))
|
|
|
|
.to eq(merge_request.reload.hook_attrs.except('updated_at'))
|
|
|
|
expect(data[:merge_request]['updated_at'])
|
|
|
|
.to be > merge_request.hook_attrs['updated_at']
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
|
|
|
|
include_examples 'project hook data'
|
|
|
|
include_examples 'deprecated repository hook data'
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe 'When asking for a note on project snippet' do
|
2016-06-16 23:09:34 +05:30
|
|
|
let!(:snippet) do
|
|
|
|
create(:project_snippet, created_at: fixed_time, updated_at: fixed_time,
|
|
|
|
project: project)
|
|
|
|
end
|
|
|
|
|
|
|
|
let!(:note) do
|
|
|
|
create(:note_on_project_snippet, noteable: snippet,
|
|
|
|
project: project)
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
it 'returns the note and project snippet data' do
|
|
|
|
expect(data).to have_key(:snippet)
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(data[:snippet].except('updated_at'))
|
|
|
|
.to eq(snippet.reload.hook_attrs.except('updated_at'))
|
|
|
|
expect(data[:snippet]['updated_at'])
|
|
|
|
.to be > snippet.hook_attrs['updated_at']
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
2016-04-02 18:10:28 +05:30
|
|
|
|
|
|
|
include_examples 'project hook data'
|
|
|
|
include_examples 'deprecated repository hook data'
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|