2019-07-07 11:18:12 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2016-11-03 12:29:30 +05:30
|
|
|
describe IssuablesHelper do
|
2016-09-13 17:45:13 +05:30
|
|
|
let(:label) { build_stubbed(:label) }
|
|
|
|
let(:label2) { build_stubbed(:label) }
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
describe '#users_dropdown_label' do
|
2019-03-02 22:35:43 +05:30
|
|
|
let(:user) { build_stubbed(:user) }
|
|
|
|
let(:user2) { build_stubbed(:user) }
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
it 'returns unassigned' do
|
|
|
|
expect(users_dropdown_label([])).to eq('Unassigned')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns selected user\'s name' do
|
|
|
|
expect(users_dropdown_label([user])).to eq(user.name)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns selected user\'s name and counter' do
|
|
|
|
expect(users_dropdown_label([user, user2])).to eq("#{user.name} + 1 more")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-11-18 11:00:15 +05:30
|
|
|
describe '#group_dropdown_label' do
|
2019-03-02 22:35:43 +05:30
|
|
|
let(:group) { create(:group) }
|
2018-11-18 11:00:15 +05:30
|
|
|
let(:default) { 'default label' }
|
|
|
|
|
|
|
|
it 'returns default group label when group_id is nil' do
|
|
|
|
expect(group_dropdown_label(nil, default)).to eq('default label')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns "any group" when group_id is 0' do
|
|
|
|
expect(group_dropdown_label('0', default)).to eq('Any group')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns group full path when a group was found for the provided id' do
|
|
|
|
expect(group_dropdown_label(group.id, default)).to eq(group.full_name)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns default label when a group was not found for the provided id' do
|
|
|
|
expect(group_dropdown_label(9999, default)).to eq('default label')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-11-03 12:29:30 +05:30
|
|
|
describe '#issuable_labels_tooltip' do
|
2019-02-15 15:39:39 +05:30
|
|
|
let(:label_entity) { LabelEntity.represent(label).as_json }
|
|
|
|
let(:label2_entity) { LabelEntity.represent(label2).as_json }
|
|
|
|
|
2018-10-15 14:42:47 +05:30
|
|
|
it 'returns label text with no labels' do
|
|
|
|
expect(issuable_labels_tooltip([])).to eq("Labels")
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns label text with labels within max limit' do
|
2019-02-15 15:39:39 +05:30
|
|
|
expect(issuable_labels_tooltip([label_entity])).to eq(label[:title])
|
2016-09-13 17:45:13 +05:30
|
|
|
end
|
|
|
|
|
2018-10-15 14:42:47 +05:30
|
|
|
it 'returns label text with labels exceeding max limit' do
|
2019-02-15 15:39:39 +05:30
|
|
|
expect(issuable_labels_tooltip([label_entity, label2_entity], limit: 1)).to eq("#{label[:title]}, and 1 more")
|
2016-09-13 17:45:13 +05:30
|
|
|
end
|
|
|
|
end
|
2016-11-03 12:29:30 +05:30
|
|
|
|
|
|
|
describe '#issuables_state_counter_text' do
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
|
|
|
describe 'state text' do
|
|
|
|
before do
|
|
|
|
allow(helper).to receive(:issuables_count_for_state).and_return(42)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns "Open" when state is :opened' do
|
2018-05-09 12:01:36 +05:30
|
|
|
expect(helper.issuables_state_counter_text(:issues, :opened, true))
|
2018-11-08 19:23:39 +05:30
|
|
|
.to eq('<span>Open</span> <span class="badge badge-pill">42</span>')
|
2016-11-03 12:29:30 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns "Closed" when state is :closed' do
|
2018-05-09 12:01:36 +05:30
|
|
|
expect(helper.issuables_state_counter_text(:issues, :closed, true))
|
2018-11-08 19:23:39 +05:30
|
|
|
.to eq('<span>Closed</span> <span class="badge badge-pill">42</span>')
|
2016-11-03 12:29:30 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns "Merged" when state is :merged' do
|
2018-05-09 12:01:36 +05:30
|
|
|
expect(helper.issuables_state_counter_text(:merge_requests, :merged, true))
|
2018-11-08 19:23:39 +05:30
|
|
|
.to eq('<span>Merged</span> <span class="badge badge-pill">42</span>')
|
2016-11-03 12:29:30 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns "All" when state is :all' do
|
2018-05-09 12:01:36 +05:30
|
|
|
expect(helper.issuables_state_counter_text(:merge_requests, :all, true))
|
2018-11-08 19:23:39 +05:30
|
|
|
.to eq('<span>All</span> <span class="badge badge-pill">42</span>')
|
2016-11-03 12:29:30 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
describe '#issuable_reference' do
|
|
|
|
context 'when show_full_reference truthy' do
|
|
|
|
it 'display issuable full reference' do
|
|
|
|
assign(:show_full_reference, true)
|
|
|
|
issue = build_stubbed(:issue)
|
|
|
|
|
|
|
|
expect(helper.issuable_reference(issue)).to eql(issue.to_reference(full: true))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when show_full_reference falsey' do
|
|
|
|
context 'when @group present' do
|
|
|
|
it 'display issuable reference to @group' do
|
|
|
|
project = build_stubbed(:project)
|
|
|
|
|
|
|
|
assign(:show_full_reference, nil)
|
|
|
|
assign(:group, project.namespace)
|
|
|
|
|
|
|
|
issue = build_stubbed(:issue)
|
|
|
|
|
|
|
|
expect(helper.issuable_reference(issue)).to eql(issue.to_reference(project.namespace))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when @project present' do
|
|
|
|
it 'display issuable reference to @project' do
|
|
|
|
project = build_stubbed(:project)
|
|
|
|
|
|
|
|
assign(:show_full_reference, nil)
|
|
|
|
assign(:group, nil)
|
|
|
|
assign(:project, project)
|
|
|
|
|
|
|
|
issue = build_stubbed(:issue)
|
|
|
|
|
|
|
|
expect(helper.issuable_reference(issue)).to eql(issue.to_reference(project))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe '#updated_at_by' do
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:unedited_issuable) { create(:issue) }
|
2018-03-17 18:26:18 +05:30
|
|
|
let(:edited_issuable) { create(:issue, last_edited_by: user, created_at: 3.days.ago, updated_at: 1.day.ago, last_edited_at: 2.days.ago) }
|
2017-09-10 17:25:29 +05:30
|
|
|
let(:edited_updated_at_by) do
|
|
|
|
{
|
2018-03-17 18:26:18 +05:30
|
|
|
updatedAt: edited_issuable.last_edited_at.to_time.iso8601,
|
2017-09-10 17:25:29 +05:30
|
|
|
updatedBy: {
|
|
|
|
name: user.name,
|
|
|
|
path: user_path(user)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(helper.updated_at_by(unedited_issuable)).to eq({}) }
|
|
|
|
it { expect(helper.updated_at_by(edited_issuable)).to eq(edited_updated_at_by) }
|
|
|
|
|
|
|
|
context 'when updated by a deleted user' do
|
|
|
|
let(:edited_updated_at_by) do
|
|
|
|
{
|
2018-03-17 18:26:18 +05:30
|
|
|
updatedAt: edited_issuable.last_edited_at.to_time.iso8601,
|
2017-09-10 17:25:29 +05:30
|
|
|
updatedBy: {
|
|
|
|
name: User.ghost.name,
|
|
|
|
path: user_path(User.ghost)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
user.destroy
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns "Ghost user" as edited_by' do
|
|
|
|
expect(helper.updated_at_by(edited_issuable.reload)).to eq(edited_updated_at_by)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
|
|
|
|
describe '#issuable_initial_data' do
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(helper).to receive(:current_user).and_return(user)
|
|
|
|
allow(helper).to receive(:can?).and_return(true)
|
2019-03-02 22:35:43 +05:30
|
|
|
stub_commonmark_sourcepos_disabled
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
|
2019-07-07 11:18:12 +05:30
|
|
|
it 'returns the correct data for an issue' do
|
2018-03-17 18:26:18 +05:30
|
|
|
issue = create(:issue, author: user, description: 'issue text')
|
|
|
|
@project = issue.project
|
|
|
|
|
|
|
|
expected_data = {
|
2018-03-27 19:54:05 +05:30
|
|
|
endpoint: "/#{@project.full_path}/issues/#{issue.iid}",
|
|
|
|
updateEndpoint: "/#{@project.full_path}/issues/#{issue.iid}.json",
|
|
|
|
canUpdate: true,
|
|
|
|
canDestroy: true,
|
|
|
|
issuableRef: "##{issue.iid}",
|
|
|
|
markdownPreviewPath: "/#{@project.full_path}/preview_markdown",
|
|
|
|
markdownDocsPath: '/help/user/markdown',
|
|
|
|
issuableTemplates: [],
|
2019-03-02 22:35:43 +05:30
|
|
|
lockVersion: issue.lock_version,
|
2018-03-27 19:54:05 +05:30
|
|
|
projectPath: @project.path,
|
|
|
|
projectNamespace: @project.namespace.path,
|
|
|
|
initialTitleHtml: issue.title,
|
|
|
|
initialTitleText: issue.title,
|
|
|
|
initialDescriptionHtml: '<p dir="auto">issue text</p>',
|
|
|
|
initialDescriptionText: 'issue text',
|
|
|
|
initialTaskStatus: '0 of 0 tasks completed'
|
2018-03-17 18:26:18 +05:30
|
|
|
}
|
2019-07-07 11:18:12 +05:30
|
|
|
expect(helper.issuable_initial_data(issue)).to match(hash_including(expected_data))
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
2019-09-30 21:07:59 +05:30
|
|
|
|
|
|
|
describe '#zoomMeetingUrl in issue' do
|
|
|
|
let(:issue) { create(:issue, author: user, description: description) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
assign(:project, issue.project)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'no zoom links in the issue description' do
|
|
|
|
let(:description) { 'issue text' }
|
|
|
|
|
|
|
|
it 'does not set zoomMeetingUrl' do
|
|
|
|
expect(helper.issuable_initial_data(issue))
|
|
|
|
.not_to include(:zoomMeetingUrl)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'no zoom links in the issue description if it has link but not a zoom link' do
|
|
|
|
let(:description) { 'issue text https://stackoverflow.com/questions/22' }
|
|
|
|
|
|
|
|
it 'does not set zoomMeetingUrl' do
|
|
|
|
expect(helper.issuable_initial_data(issue))
|
|
|
|
.not_to include(:zoomMeetingUrl)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with two zoom links in description' do
|
|
|
|
let(:description) do
|
|
|
|
<<~TEXT
|
|
|
|
issue text and
|
|
|
|
zoom call on https://zoom.us/j/123456789 this url
|
|
|
|
and new zoom url https://zoom.us/s/lastone and some more text
|
|
|
|
TEXT
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sets zoomMeetingUrl value to the last url' do
|
|
|
|
expect(helper.issuable_initial_data(issue))
|
|
|
|
.to include(zoomMeetingUrl: 'https://zoom.us/s/lastone')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
end
|