2019-07-07 11:18:12 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-12-04 20:38:33 +05:30
|
|
|
require 'spec_helper'
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
RSpec.describe Timelog do
|
2017-08-17 22:00:37 +05:30
|
|
|
subject { build(:timelog) }
|
2019-12-21 20:55:43 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
let(:issue) { create(:issue) }
|
|
|
|
let(:merge_request) { create(:merge_request) }
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
it { is_expected.to belong_to(:issue).touch(true) }
|
|
|
|
it { is_expected.to belong_to(:merge_request).touch(true) }
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
it { is_expected.to be_valid }
|
|
|
|
|
|
|
|
it { is_expected.to validate_presence_of(:time_spent) }
|
|
|
|
it { is_expected.to validate_presence_of(:user) }
|
|
|
|
|
|
|
|
describe 'Issuable validation' do
|
|
|
|
it 'is invalid if issue_id and merge_request_id are missing' do
|
|
|
|
subject.attributes = { issue: nil, merge_request: nil }
|
|
|
|
|
|
|
|
expect(subject).to be_invalid
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'is invalid if issue_id and merge_request_id are set' do
|
|
|
|
subject.attributes = { issue: issue, merge_request: merge_request }
|
|
|
|
|
|
|
|
expect(subject).to be_invalid
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'is valid if only issue_id is set' do
|
|
|
|
subject.attributes = { issue: issue, merge_request: nil }
|
|
|
|
|
|
|
|
expect(subject).to be_valid
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'is valid if only merge_request_id is set' do
|
|
|
|
subject.attributes = { merge_request: merge_request, issue: nil }
|
|
|
|
|
|
|
|
expect(subject).to be_valid
|
|
|
|
end
|
2021-02-22 17:27:13 +05:30
|
|
|
|
|
|
|
describe 'when importing' do
|
|
|
|
it 'is valid if issue_id and merge_request_id are missing' do
|
|
|
|
subject.attributes = { issue: nil, merge_request: nil, importing: true }
|
|
|
|
|
|
|
|
expect(subject).to be_valid
|
|
|
|
end
|
|
|
|
end
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
2020-01-01 13:55:28 +05:30
|
|
|
|
|
|
|
describe 'scopes' do
|
|
|
|
describe 'for_issues_in_group' do
|
|
|
|
it 'return timelogs created for group issues' do
|
|
|
|
group = create(:group)
|
|
|
|
subgroup = create(:group, parent: group)
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
create(:issue_timelog)
|
|
|
|
timelog1 = create(:issue_timelog, issue: create(:issue, project: create(:project, group: group)))
|
|
|
|
timelog2 = create(:issue_timelog, issue: create(:issue, project: create(:project, group: subgroup)))
|
2020-01-01 13:55:28 +05:30
|
|
|
|
|
|
|
expect(described_class.for_issues_in_group(group)).to contain_exactly(timelog1, timelog2)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-05-24 23:13:21 +05:30
|
|
|
describe 'between_times' do
|
|
|
|
it 'returns collection of timelogs within given times' do
|
2021-04-29 21:17:54 +05:30
|
|
|
create(:issue_timelog, spent_at: 65.days.ago)
|
|
|
|
timelog1 = create(:issue_timelog, spent_at: 15.days.ago)
|
|
|
|
timelog2 = create(:issue_timelog, spent_at: 5.days.ago)
|
2020-05-24 23:13:21 +05:30
|
|
|
timelogs = described_class.between_times(20.days.ago, 1.day.ago)
|
2020-01-01 13:55:28 +05:30
|
|
|
|
|
|
|
expect(timelogs).to contain_exactly(timelog1, timelog2)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|