OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
openproject/spec_legacy/unit/issue_nested_set_spec.rb

147 lines
5.4 KiB

#-- encoding: UTF-8
#-- copyright
# OpenProject is a project management system.
# Copyright (C) 2012-2017 the OpenProject Foundation (OPF)
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
#
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
# Copyright (C) 2006-2017 Jean-Philippe Lang
# Copyright (C) 2010-2013 the ChiliProject Team
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# See doc/COPYRIGHT.rdoc for more details.
#++
require_relative '../legacy_spec_helper'
describe 'IssueNestedSet', type: :model do
include MiniTest::Assertions # refute
fixtures :all
self.use_transactional_fixtures = false
before do
WorkPackage.delete_all
end
it 'moving to a descendant should not validate' do
parent1 = create_issue!
child = create_issue!(parent: parent1)
grandchild = create_issue!(parent: child)
child.reload
child.parent = grandchild
assert !child.save
refute_empty child.errors[:parent]
end
it 'should destroy parent work package updated during children destroy' do
parent = create_issue!
create_issue!(start_date: Date.today, parent: parent)
create_issue!(start_date: 2.days.from_now, parent: parent)
assert_difference 'WorkPackage.count', -3 do
WorkPackage.find(parent.id).destroy
end
end
it 'should parent dates should be lowest start and highest due dates' do
parent = create_issue!
create_issue!(start_date: '2010-01-25', due_date: '2010-02-15', parent: parent)
create_issue!(due_date: '2010-02-13', parent: parent)
create_issue!(start_date: '2010-02-01', due_date: '2010-02-22', parent: parent)
parent.reload
assert_equal Date.parse('2010-01-25'), parent.start_date
assert_equal Date.parse('2010-02-22'), parent.due_date
end
it 'should parent done ratio should be average done ratio of leaves' do
parent = create_issue!
create_issue!(done_ratio: 20, parent: parent)
assert_equal 20, parent.reload.done_ratio
create_issue!(done_ratio: 70, parent: parent)
assert_equal 45, parent.reload.done_ratio
child = create_issue!(done_ratio: 0, parent: parent)
assert_equal 30, parent.reload.done_ratio
create_issue!(done_ratio: 30, parent: child)
assert_equal 30, child.reload.done_ratio
assert_equal 40, parent.reload.done_ratio
end
it 'should parent done ratio should be weighted by estimated times if any' do
parent = create_issue!
create_issue!(estimated_hours: 10, done_ratio: 20, parent: parent)
assert_equal 20, parent.reload.done_ratio
create_issue!(estimated_hours: 20, done_ratio: 50, parent: parent)
assert_equal (50 * 20 + 20 * 10) / 30, parent.reload.done_ratio
end
it 'should parent estimate should be sum of leaves' do
parent = create_issue!
create_issue!(estimated_hours: nil, parent: parent)
assert_nil parent.reload.estimated_hours
create_issue!(estimated_hours: 5, parent: parent)
assert_equal 5, parent.reload.estimated_hours
create_issue!(estimated_hours: 7, parent: parent)
assert_equal 12, parent.reload.estimated_hours
end
it 'should move parent updates old parent attributes' do
first_parent = create_issue!
second_parent = create_issue!
child = create_issue!(estimated_hours: 5,
parent: first_parent)
assert_equal 5, first_parent.reload.estimated_hours
child.update_attributes(estimated_hours: 7,
parent: second_parent)
assert_equal 7, second_parent.reload.estimated_hours
assert_nil first_parent.reload.estimated_hours
end
it 'should project copy should copy issue tree' do
Project.delete_all # make sure unqiue identifiers
p = Project.create!(name: 'Tree copy', identifier: 'tree-copy', type_ids: [1, 2])
i1 = create_issue!(project_id: p.id, subject: 'i1')
i2 = create_issue!(project_id: p.id, subject: 'i2', parent: i1)
create_issue!(project_id: p.id, subject: 'i3', parent: i1)
create_issue!(project_id: p.id, subject: 'i4', parent: i2)
create_issue!(project_id: p.id, subject: 'i5')
c = Project.new(name: 'Copy', identifier: 'copy', type_ids: [1, 2])
c.copy(p, only: 'work_packages')
c.reload
assert_equal 5, c.work_packages.count
ic1, ic2, ic3, ic4, ic5 = c.work_packages.reorder('subject')
assert ic1.root?
assert_equal ic1, ic2.parent
assert_equal ic1, ic3.parent
assert_equal ic2, ic4.parent
assert ic5.root?
end
# Helper that creates an issue with default attributes
def create_issue!(attributes = {})
(i = WorkPackage.new.tap do |wp|
attr = { project_id: 1, type_id: 1, author_id: 1, subject: 'test' }.merge(attributes)
wp.attributes = attr
end).save!
i
end
end