rosa-build/spec/models/issue_spec.rb

161 lines
4.9 KiB
Ruby
Raw Normal View History

require 'spec_helper'
2012-12-17 10:39:53 +00:00
def set_data
@user = FactoryGirl.create(:user)
@stranger = FactoryGirl.create(:user)
end
def create_issue issue_owner
ActionMailer::Base.deliveries = []
2014-01-21 04:51:49 +00:00
@issue = FactoryGirl.create(:issue, project_id: @project.id,
user: issue_owner, assignee: nil)
2012-12-17 10:39:53 +00:00
end
describe Issue do
2012-12-17 10:39:53 +00:00
before do
stub_symlink_methods
2015-02-19 01:28:02 +00:00
allow_any_instance_of(Project).to receive(:versions).and_return(%w(v1.0 v2.0))
2012-12-17 10:39:53 +00:00
end
context '#update_statistic' do
it 'updates styatistics' do
expect do
FactoryGirl.create(:issue)
end.to change(Statistic, :count).by(1)
end
end
2012-12-17 10:39:53 +00:00
context 'for project admin user' do
before(:each) do
set_data
2014-01-21 04:51:49 +00:00
@project = FactoryGirl.create(:project, owner: @user)
2012-12-17 10:39:53 +00:00
end
it 'should send an e-mail' do
2013-01-11 14:01:10 +00:00
create_issue(@stranger)
2012-12-17 10:39:53 +00:00
ActionMailer::Base.deliveries.count.should == 1
ActionMailer::Base.deliveries.last.to.include?(@user.email).should == true
end
2013-01-11 14:01:10 +00:00
it 'should not send an e-mail to creator' do
create_issue(@user)
ActionMailer::Base.deliveries.count.should == 0
end
2013-07-10 18:44:18 +01:00
it 'should create automatic comment from another issue' do
create_issue(@user)
2014-01-21 04:51:49 +00:00
another_issue = FactoryGirl.create(:issue, project: @project, title: "[##{@issue.serial_id}]")
Comment.where(automatic: true, commentable_type: 'Issue',
created_from_issue_id: another_issue.id).count.should == 1
2013-07-10 18:44:18 +01:00
end
it 'should create automatic comment after updating another issue body' do
create_issue(@user)
2014-01-21 04:51:49 +00:00
another_issue = FactoryGirl.create(:issue, project: @project)
2013-07-10 18:44:18 +01:00
another_issue.update_attribute(:title, "[##{@issue.serial_id}]")
another_issue.send(:send_assign_notifications)
2014-01-21 04:51:49 +00:00
Comment.where(automatic: true, commentable_type: 'Issue',
created_from_issue_id: another_issue.id).count.should == 1
2013-07-10 18:44:18 +01:00
end
2013-07-11 12:19:18 +01:00
it 'should send email message to new assignee' do
create_issue(@user)
ActionMailer::Base.deliveries = []
@issue.update_attribute :assignee_id, @user.id
@issue.send(:send_assign_notifications, :update)
ActionMailer::Base.deliveries.count.should == 1
end
2012-12-17 10:39:53 +00:00
end
context 'for member-group' do
before(:each) do
set_data
2014-01-21 04:51:49 +00:00
@project = FactoryGirl.create(:project, owner: @user)
2012-12-17 10:39:53 +00:00
@group = FactoryGirl.create(:group)
2013-04-17 21:53:17 +01:00
@reader = FactoryGirl.create :user
create_actor_relation(@group, @reader, 'reader')
2012-12-17 10:39:53 +00:00
end
it 'should send an e-mail to all members of the admin group' do
create_relation(@project, @group, 'admin')
2012-12-17 10:39:53 +00:00
create_issue(@stranger)
ActionMailer::Base.deliveries.count.should == 3 # 1 owner + 2 group member. enough?
end
2013-01-11 14:01:10 +00:00
it 'should send an e-mail to all members of the admin group except creator' do
create_relation(@project, @group, 'admin')
2013-01-11 14:01:10 +00:00
create_issue(@group.owner)
ActionMailer::Base.deliveries.count.should == 2 # 1 owner + 1 group member. enough?
end
2012-12-17 10:39:53 +00:00
it 'should not send an e-mail to members of the reader group' do
create_relation(@project, @group, 'reader')
2012-12-17 10:39:53 +00:00
create_issue(@stranger)
ActionMailer::Base.deliveries.count.should == 1 # 1 project owner
end
2013-04-17 21:53:17 +01:00
it 'should reset issue assignee after remove him from group' do
create_relation(@project, @group, 'reader')
2013-04-17 21:53:17 +01:00
create_issue(@group.owner)
@issue.update_column :assignee_id, @reader.id
@group.remove_member @reader
@issue.reload.assignee_id.should == nil
end
it 'should not reset issue assignee' do
create_relation(@project, @group, 'reader')
create_relation(@project, @reader, 'reader')
2013-04-17 21:53:17 +01:00
create_issue(@group.owner)
@issue.update_column :assignee_id, @reader.id
@group.remove_member @reader
@issue.reload.assignee_id.should == @reader.id
end
it 'should reset issue assignee after remove him from project' do
create_relation(@project, @reader, 'reader')
2013-04-17 21:53:17 +01:00
create_issue(@reader)
@issue.update_column :assignee_id, @reader.id
2013-04-18 12:19:48 +01:00
@project.remove_member @reader # via api
2013-04-17 21:53:17 +01:00
@issue.reload.assignee_id.should == nil
end
2012-12-17 10:39:53 +00:00
end
context 'Group project' do
before(:each) do
set_data
2014-01-21 04:51:49 +00:00
@group = FactoryGirl.create(:group, owner: @user)
@project = FactoryGirl.create(:project, owner: @group)
2012-12-17 10:39:53 +00:00
end
context 'for admin of the group' do
it 'should send an e-mail' do
create_issue(@stranger)
ActionMailer::Base.deliveries.count.should == 1
ActionMailer::Base.deliveries.last.to.include?(@user.email).should == true
end
2013-01-11 14:01:10 +00:00
it 'should not send an e-mail to creator' do
create_issue(@user)
ActionMailer::Base.deliveries.count.should == 0
end
2012-12-17 10:39:53 +00:00
end
context 'for reader of the group' do
it 'should not send an e-mail' do
reader = FactoryGirl.create :user
create_actor_relation(@group, reader, 'reader')
2012-12-17 10:39:53 +00:00
create_issue(@stranger)
ActionMailer::Base.deliveries.count.should == 1
end
end
end
end