158 lines
5.0 KiB
Ruby
158 lines
5.0 KiB
Ruby
require 'spec_helper'
|
|
|
|
def set_data
|
|
@user = FactoryGirl.create(:user)
|
|
@stranger = FactoryGirl.create(:user)
|
|
end
|
|
|
|
def create_issue issue_owner
|
|
ActionMailer::Base.deliveries = []
|
|
@issue = FactoryGirl.create(:issue, project_id: @project.id,
|
|
user: issue_owner, assignee: nil)
|
|
end
|
|
|
|
describe Issue do
|
|
before do
|
|
stub_symlink_methods
|
|
allow_any_instance_of(Project).to receive(:versions).and_return(%w(v1.0 v2.0))
|
|
end
|
|
|
|
|
|
context '#update_statistic' do
|
|
it 'updates styatistics' do
|
|
expect { FactoryGirl.create(:issue) }.to change(Statistic, :count).by(1)
|
|
end
|
|
end
|
|
|
|
context 'for project admin user' do
|
|
before(:each) do
|
|
set_data
|
|
@project = FactoryGirl.create(:project, owner: @user)
|
|
end
|
|
|
|
it 'should send an e-mail' do
|
|
create_issue(@stranger)
|
|
expect(ActionMailer::Base.deliveries.count).to eq(1)
|
|
expect(ActionMailer::Base.deliveries.last.to).to include(@user.email)
|
|
end
|
|
|
|
it 'should not send an e-mail to creator' do
|
|
create_issue(@user)
|
|
expect(ActionMailer::Base.deliveries.count).to eq(0)
|
|
end
|
|
|
|
it 'should create automatic comment from another issue' do
|
|
create_issue(@user)
|
|
another_issue = FactoryGirl.create(:issue, project: @project, title: "[##{@issue.serial_id}]")
|
|
expect(Comment.where(automatic: true, commentable_type: 'Issue',
|
|
created_from_issue_id: another_issue.id).count).to eq(1)
|
|
end
|
|
|
|
it 'should create automatic comment after updating another issue body' do
|
|
create_issue(@user)
|
|
another_issue = FactoryGirl.create(:issue, project: @project)
|
|
another_issue = Issue.find another_issue.id
|
|
another_issue.update_attribute(:title, "[##{@issue.serial_id}]")
|
|
|
|
expect(Comment.where(automatic: true, commentable_type: 'Issue',
|
|
created_from_issue_id: another_issue.id).count).to eq(1)
|
|
end
|
|
|
|
it 'should send email message to new assignee' do
|
|
create_issue(@user)
|
|
ActionMailer::Base.deliveries = []
|
|
@issue = Issue.find @issue.id
|
|
@issue.update_attribute :assignee_id, @user.id
|
|
|
|
expect(ActionMailer::Base.deliveries.count).to eq(1)
|
|
end
|
|
end
|
|
|
|
context 'for member-group' do
|
|
before(:each) do
|
|
set_data
|
|
@project = FactoryGirl.create(:project, owner: @user)
|
|
|
|
@group = FactoryGirl.create(:group)
|
|
@reader = FactoryGirl.create :user
|
|
create_actor_relation(@group, @reader, 'reader')
|
|
end
|
|
|
|
it 'should send an e-mail to all members of the admin group' do
|
|
create_relation(@project, @group, 'admin')
|
|
|
|
create_issue(@stranger)
|
|
expect(ActionMailer::Base.deliveries.count).to eq(3) # 1 owner + 2 group member. enough?
|
|
end
|
|
|
|
it 'should send an e-mail to all members of the admin group except creator' do
|
|
create_relation(@project, @group, 'admin')
|
|
|
|
create_issue(@group.owner)
|
|
expect(ActionMailer::Base.deliveries.count).to eq(2) # 1 owner + 1 group member. enough?
|
|
end
|
|
|
|
it 'should send emails to members of the reader group' do
|
|
create_relation(@project, @group, 'reader')
|
|
create_issue(@stranger)
|
|
expect(ActionMailer::Base.deliveries.count).to eq(3) # project owner + group owner + group member
|
|
end
|
|
|
|
it 'should reset issue assignee after remove him from group' do
|
|
create_relation(@project, @group, 'reader')
|
|
create_issue(@group.owner)
|
|
@issue.update_column :assignee_id, @reader.id
|
|
@group.remove_member @reader
|
|
expect(@issue.reload.assignee_id).to be_nil
|
|
end
|
|
|
|
it 'should not reset issue assignee' do
|
|
create_relation(@project, @group, 'reader')
|
|
create_relation(@project, @reader, 'reader')
|
|
create_issue(@group.owner)
|
|
@issue.update_column :assignee_id, @reader.id
|
|
@group.remove_member @reader
|
|
expect(@issue.reload.assignee_id).to eq(@reader.id)
|
|
end
|
|
|
|
it 'should reset issue assignee after remove him from project' do
|
|
create_relation(@project, @reader, 'reader')
|
|
create_issue(@reader)
|
|
@issue.update_column :assignee_id, @reader.id
|
|
@project.remove_member @reader # via api
|
|
expect(@issue.reload.assignee_id).to be_nil
|
|
end
|
|
|
|
end
|
|
|
|
context 'Group project' do
|
|
before(:each) do
|
|
set_data
|
|
@group = FactoryGirl.create(:group, owner: @user)
|
|
@project = FactoryGirl.create(:project, owner: @group)
|
|
end
|
|
|
|
context 'for admin of the group' do
|
|
it 'should send an e-mail' do
|
|
create_issue(@stranger)
|
|
expect(ActionMailer::Base.deliveries.count).to eq(1)
|
|
expect(ActionMailer::Base.deliveries.last.to).to include(@user.email)
|
|
end
|
|
|
|
it 'should not send an e-mail to creator' do
|
|
create_issue(@user)
|
|
expect(ActionMailer::Base.deliveries.count).to eq(0)
|
|
end
|
|
end
|
|
|
|
context 'for reader of the group' do
|
|
it 'should send an email' do
|
|
reader = FactoryGirl.create :user
|
|
create_actor_relation(@group, reader, 'reader')
|
|
create_issue(@stranger)
|
|
expect(ActionMailer::Base.deliveries.count).to eq(2) # group owner + group reader
|
|
end
|
|
end
|
|
end
|
|
end
|