Commit a68d0dd0 authored by GitLab Bot's avatar GitLab Bot

Automatic merge of gitlab-org/gitlab-ce master

parents 5966e367 0de554ed
...@@ -47,14 +47,14 @@ class NotificationRecipient ...@@ -47,14 +47,14 @@ class NotificationRecipient
def suitable_notification_level? def suitable_notification_level?
case notification_level case notification_level
when :disabled, nil
false
when :custom
custom_enabled? || %i[participating mention].include?(@type)
when :watch, :participating
!action_excluded?
when :mention when :mention
@type == :mention @type == :mention
when :participating
!excluded_participating_action? && %i[participating mention watch].include?(@type)
when :custom
custom_enabled? || %i[participating mention].include?(@type)
when :watch
!excluded_watcher_action?
else else
false false
end end
...@@ -100,18 +100,14 @@ class NotificationRecipient ...@@ -100,18 +100,14 @@ class NotificationRecipient
end end
end end
def action_excluded?
excluded_watcher_action? || excluded_participating_action?
end
def excluded_watcher_action? def excluded_watcher_action?
return false unless @custom_action && notification_level == :watch return false unless @custom_action
NotificationSetting::EXCLUDED_WATCHER_EVENTS.include?(@custom_action) NotificationSetting::EXCLUDED_WATCHER_EVENTS.include?(@custom_action)
end end
def excluded_participating_action? def excluded_participating_action?
return false unless @custom_action && notification_level == :participating return false unless @custom_action
NotificationSetting::EXCLUDED_PARTICIPATING_EVENTS.include?(@custom_action) NotificationSetting::EXCLUDED_PARTICIPATING_EVENTS.include?(@custom_action)
end end
......
...@@ -135,7 +135,7 @@ module NotificationRecipientService ...@@ -135,7 +135,7 @@ module NotificationRecipientService
global_users_ids = user_ids_with_project_level_global.concat(user_ids_with_group_level_global) global_users_ids = user_ids_with_project_level_global.concat(user_ids_with_group_level_global)
user_ids += user_ids_with_global_level_custom(global_users_ids, custom_action) user_ids += user_ids_with_global_level_custom(global_users_ids, custom_action)
add_recipients(user_scope.where(id: user_ids), :watch, nil) add_recipients(user_scope.where(id: user_ids), :custom, nil)
end end
# rubocop: enable CodeReuse/ActiveRecord # rubocop: enable CodeReuse/ActiveRecord
...@@ -391,7 +391,7 @@ module NotificationRecipientService ...@@ -391,7 +391,7 @@ module NotificationRecipientService
def build! def build!
return [] unless project return [] unless project
add_recipients(project.team.maintainers, :watch, nil) add_recipients(project.team.maintainers, :mention, nil)
end end
def acting_user def acting_user
......
---
title: Fix extra emails for custom notifications
merge_request: 25607
author:
type: fixed
...@@ -96,13 +96,15 @@ To use an external Prometheus server: ...@@ -96,13 +96,15 @@ To use an external Prometheus server:
1. Set each bundled service's [exporter](#bundled-software-metrics) to listen on a network address, for example: 1. Set each bundled service's [exporter](#bundled-software-metrics) to listen on a network address, for example:
```ruby ```ruby
gitlab_monitor['listen_address'] = '0.0.0.0' gitlab_monitor['listen_address'] = '0.0.0.0'
sidekiq['listen_address'] = '0.0.0.0'
gitlab_monitor['listen_port'] = '9168' gitlab_monitor['listen_port'] = '9168'
gitaly['prometheus_listen_addr'] = "0.0.0.0:9236"
node_exporter['listen_address'] = '0.0.0.0:9100' node_exporter['listen_address'] = '0.0.0.0:9100'
redis_exporter['listen_address'] = '0.0.0.0:9121' redis_exporter['listen_address'] = '0.0.0.0:9121'
postgres_exporter['listen_address'] = '0.0.0.0:9187' postgres_exporter['listen_address'] = '0.0.0.0:9187'
gitaly['prometheus_listen_addr'] = "0.0.0.0:9236"
gitlab_workhorse['prometheus_listen_addr'] = "0.0.0.0:9229"
``` ```
1. Install and set up a dedicated Prometheus instance, if necessary, using the [official installation instructions](https://prometheus.io/docs/prometheus/latest/installation/). 1. Install and set up a dedicated Prometheus instance, if necessary, using the [official installation instructions](https://prometheus.io/docs/prometheus/latest/installation/).
...@@ -112,6 +114,18 @@ To use an external Prometheus server: ...@@ -112,6 +114,18 @@ To use an external Prometheus server:
gitlab_rails['monitoring_whitelist'] = ['127.0.0.0/8', '192.168.0.1'] gitlab_rails['monitoring_whitelist'] = ['127.0.0.0/8', '192.168.0.1']
``` ```
1. To scrape nginx metrics, you'll also need to configure nginx to allow the Prometheus server
IP. For example:
```ruby
nginx['status']['options'] = {
"server_tokens" => "off",
"access_log" => "off",
"allow" => "192.168.0.1",
"deny" => "all",
}
```
1. [Reconfigure GitLab][reconfigure] to apply the changes 1. [Reconfigure GitLab][reconfigure] to apply the changes
1. Edit the Prometheus server's configuration file. 1. Edit the Prometheus server's configuration file.
1. Add each node's exporters to the Prometheus server's 1. Add each node's exporters to the Prometheus server's
......
# Pipelines for merge requests # Pipelines for merge requests
NOTE: **Note**:
As of GitLab 11.10, pipelines for merge requests require GitLab Runner 11.9
or higher due to the [recent refspecs
changes](https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/25504).
Anything lower will cause the pipeline to fail.
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ce/issues/15310) in GitLab 11.6. > [Introduced](https://gitlab.com/gitlab-org/gitlab-ce/issues/15310) in GitLab 11.6.
Usually, when you create a new merge request, a pipeline runs with the Usually, when you create a new merge request, a pipeline runs with the
...@@ -68,7 +74,7 @@ when a merge request was created or updated. For example: ...@@ -68,7 +74,7 @@ when a merge request was created or updated. For example:
It's possible for your source and target branches to diverge, which can result It's possible for your source and target branches to diverge, which can result
in the scenario that source branch's pipeline was green, the target's pipeline was green, in the scenario that source branch's pipeline was green, the target's pipeline was green,
but the combined output fails. By having your merge request pipeline automatically but the combined output fails. By having your merge request pipeline automatically
create a new ref that contains the merge result of the source and target branch create a new ref that contains the merge result of the source and target branch
(then running a pipeline on that ref), we can better test that the combined result (then running a pipeline on that ref), we can better test that the combined result
is also valid. is also valid.
......
...@@ -41,7 +41,7 @@ Debian/Ubuntu: ...@@ -41,7 +41,7 @@ Debian/Ubuntu:
sudo apt-get install pgloader sudo apt-get install pgloader
``` ```
For other distributions, follow the instructions in PostrgreSQL's For other distributions, follow the instructions in PostgreSQL's
[download page](https://www.postgresql.org/download/) to add their repository [download page](https://www.postgresql.org/download/) to add their repository
and then install `pgloader`. and then install `pgloader`.
......
...@@ -643,6 +643,64 @@ describe NotificationService, :mailer do ...@@ -643,6 +643,64 @@ describe NotificationService, :mailer do
end end
end end
describe 'Participating project notification settings have priority over group and global settings if available' do
let!(:group) { create(:group) }
let!(:maintainer) { group.add_owner(create(:user, username: 'maintainer')).user }
let!(:user1) { group.add_developer(create(:user, username: 'user_with_project_and_custom_setting')).user }
let(:project) { create(:project, :public, namespace: group) }
let(:issue) { create :issue, project: project, assignees: [assignee], description: '' }
before do
reset_delivered_emails!
create_notification_setting(user1, project, :participating)
end
context 'custom on group' do
[nil, true].each do |new_issue_value|
value_caption = new_issue_value || 'nil'
it "does not send an email to user1 when a new issue is created and new_issue is set to #{value_caption}" do
update_custom_notification(:new_issue, user1, resource: group, value: new_issue_value)
notification.new_issue(issue, maintainer)
should_not_email(user1)
end
end
end
context 'watch on group' do
it 'does not send an email' do
user1.notification_settings_for(group).update!(level: :watch)
notification.new_issue(issue, maintainer)
should_not_email(user1)
end
end
context 'custom on global, global on group' do
it 'does not send an email' do
user1.notification_settings_for(nil).update!(level: :custom)
user1.notification_settings_for(group).update!(level: :global)
notification.new_issue(issue, maintainer)
should_not_email(user1)
end
end
context 'watch on global, global on group' do
it 'does not send an email' do
user1.notification_settings_for(nil).update!(level: :watch)
user1.notification_settings_for(group).update!(level: :global)
notification.new_issue(issue, maintainer)
should_not_email(user1)
end
end
end
describe 'Issues' do describe 'Issues' do
let(:group) { create(:group) } let(:group) { create(:group) }
let(:project) { create(:project, :public, namespace: group) } let(:project) { create(:project, :public, namespace: group) }
...@@ -660,7 +718,7 @@ describe NotificationService, :mailer do ...@@ -660,7 +718,7 @@ describe NotificationService, :mailer do
end end
describe '#new_issue' do describe '#new_issue' do
it do it 'notifies the expected users' do
notification.new_issue(issue, @u_disabled) notification.new_issue(issue, @u_disabled)
should_email(assignee) should_email(assignee)
...@@ -1639,7 +1697,7 @@ describe NotificationService, :mailer do ...@@ -1639,7 +1697,7 @@ describe NotificationService, :mailer do
end end
describe '#project_was_moved' do describe '#project_was_moved' do
it do it 'notifies the expected users' do
notification.project_was_moved(project, "gitlab/gitlab") notification.project_was_moved(project, "gitlab/gitlab")
should_email(@u_watcher) should_email(@u_watcher)
......
...@@ -16,7 +16,9 @@ module EmailHelpers ...@@ -16,7 +16,9 @@ module EmailHelpers
end end
def should_email(user, times: 1, recipients: email_recipients) def should_email(user, times: 1, recipients: email_recipients)
expect(sent_to_user(user, recipients: recipients)).to eq(times) amount = sent_to_user(user, recipients: recipients)
failed_message = lambda { "User #{user.username} (#{user.id}): email test failed (expected #{times}, got #{amount})" }
expect(amount).to eq(times), failed_message
end end
def should_not_email(user, recipients: email_recipients) def should_not_email(user, recipients: email_recipients)
......
...@@ -17,11 +17,15 @@ module NotificationHelpers ...@@ -17,11 +17,15 @@ module NotificationHelpers
def create_user_with_notification(level, username, resource = project) def create_user_with_notification(level, username, resource = project)
user = create(:user, username: username) user = create(:user, username: username)
create_notification_setting(user, resource, level)
user
end
def create_notification_setting(user, resource, level)
setting = user.notification_settings_for(resource) setting = user.notification_settings_for(resource)
setting.level = level setting.level = level
setting.save setting.save
user
end end
# Create custom notifications # Create custom notifications
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment