Commit 4b53d41e authored by Olena Horal-Koretska's avatar Olena Horal-Koretska

Merge branch...

Merge branch '330033-notifications-switch-cannot-be-enabled-for-projects-where-it-previously-could-be' into 'master'

Fix ability for non project member to subscribe to an issue

See merge request gitlab-org/gitlab!61953
parents a7804336 b444b07f
......@@ -24,7 +24,6 @@ export default {
GlToggle,
SidebarEditableItem,
},
inject: ['canUpdate'],
props: {
iid: {
type: String,
......@@ -102,6 +101,12 @@ export default {
parent: this.parentIsGroup ? 'group' : 'project',
});
},
isLoggedIn() {
return Boolean(gon.current_user_id);
},
canSubscribe() {
return this.emailsDisabled || !this.isLoggedIn;
},
},
methods: {
setSubscribed(subscribed) {
......@@ -174,7 +179,7 @@ export default {
<gl-toggle
:value="subscribed"
:is-loading="isLoading"
:disabled="emailsDisabled || !canUpdate"
:disabled="canSubscribe"
class="hide-collapsed gl-ml-auto"
data-testid="subscription-toggle"
:label="$options.i18n.notifications"
......
......@@ -5,8 +5,20 @@ require "spec_helper"
RSpec.describe "User toggles subscription", :js do
let(:project) { create(:project_empty_repo, :public) }
let(:user) { create(:user) }
let(:user2) { create(:user) }
let(:issue) { create(:issue, project: project, author: user) }
context 'user is not logged in' do
before do
visit(project_issue_path(project, issue))
end
it 'does not display the Notification toggle' do
expect(page).not_to have_button('Notifications')
end
end
context 'user is logged in' do
before do
project.add_developer(user)
sign_in(user)
......@@ -14,7 +26,7 @@ RSpec.describe "User toggles subscription", :js do
visit(project_issue_path(project, issue))
end
it "unsubscribes from issue" do
it 'unsubscribes from issue' do
subscription_button = find('[data-testid="subscription-toggle"]')
# Check we're subscribed.
......@@ -36,4 +48,27 @@ RSpec.describe "User toggles subscription", :js do
expect(page).to have_button('Notifications', class: 'is-disabled')
end
end
end
context 'user is logged in without edit permission' do
before do
sign_in(user2)
visit(project_issue_path(project, issue))
end
it 'subscribes to issue' do
subscription_button = find('[data-testid="subscription-toggle"]')
# Check we're not subscribed.
expect(subscription_button).to have_css("button:not(.is-checked)")
# Toggle subscription.
find('[data-testid="subscription-toggle"]').click
wait_for_requests
# Check we're subscribed.
expect(subscription_button).to have_css("button.is-checked")
end
end
end
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