Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
f27f14f4
Commit
f27f14f4
authored
Sep 04, 2020
by
Doug Stull
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Resolve invite bug on inviting a user
- was causing a regression where render_404 was being hit.
parent
63db21c1
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
107 additions
and
64 deletions
+107
-64
app/controllers/invites_controller.rb
app/controllers/invites_controller.rb
+5
-1
app/models/member.rb
app/models/member.rb
+2
-2
changelogs/unreleased/241359-nomethoderror-undefined-method-invite_email-for-actionview-outputb.yml
...-undefined-method-invite_email-for-actionview-outputb.yml
+5
-0
spec/controllers/invites_controller_spec.rb
spec/controllers/invites_controller_spec.rb
+87
-61
spec/models/member_spec.rb
spec/models/member_spec.rb
+8
-0
No files found.
app/controllers/invites_controller.rb
View file @
f27f14f4
...
@@ -76,8 +76,12 @@ class InvitesController < ApplicationController
...
@@ -76,8 +76,12 @@ class InvitesController < ApplicationController
notice
<<
"or create an account"
if
Gitlab
::
CurrentSettings
.
allow_signup?
notice
<<
"or create an account"
if
Gitlab
::
CurrentSettings
.
allow_signup?
notice
=
notice
.
join
(
' '
)
+
"."
notice
=
notice
.
join
(
' '
)
+
"."
initial_member
=
Member
.
find_by_invite_token
(
params
[
:id
])
redirect_params
=
initial_member
?
{
invite_email:
member
.
invite_email
}
:
{}
store_location_for
:user
,
request
.
fullpath
store_location_for
:user
,
request
.
fullpath
redirect_to
new_user_session_path
(
invite_email:
member
.
invite_email
),
notice:
notice
redirect_to
new_user_session_path
(
redirect_params
),
notice:
notice
end
end
def
invite_details
def
invite_details
...
...
app/models/member.rb
View file @
f27f14f4
...
@@ -161,8 +161,8 @@ class Member < ApplicationRecord
...
@@ -161,8 +161,8 @@ class Member < ApplicationRecord
where
(
user_id:
user_ids
).
has_access
.
pluck
(
:user_id
,
:access_level
).
to_h
where
(
user_id:
user_ids
).
has_access
.
pluck
(
:user_id
,
:access_level
).
to_h
end
end
def
find_by_invite_token
(
invite_token
)
def
find_by_invite_token
(
raw_
invite_token
)
invite_token
=
Devise
.
token_generator
.
digest
(
self
,
:invite_token
,
invite_token
)
invite_token
=
Devise
.
token_generator
.
digest
(
self
,
:invite_token
,
raw_
invite_token
)
find_by
(
invite_token:
invite_token
)
find_by
(
invite_token:
invite_token
)
end
end
...
...
changelogs/unreleased/241359-nomethoderror-undefined-method-invite_email-for-actionview-outputb.yml
0 → 100644
View file @
f27f14f4
---
title
:
'
Resolve
NoMethodError:
undefined
method
invite_email'
merge_request
:
41587
author
:
type
:
fixed
spec/controllers/invites_controller_spec.rb
View file @
f27f14f4
...
@@ -3,96 +3,122 @@
...
@@ -3,96 +3,122 @@
require
'spec_helper'
require
'spec_helper'
RSpec
.
describe
InvitesController
do
RSpec
.
describe
InvitesController
do
let
(
:token
)
{
'123456'
}
let_it_be
(
:user
)
{
create
(
:user
)
}
let_it_be
(
:user
)
{
create
(
:user
)
}
let
(
:member
)
{
create
(
:project_member
,
:invited
,
invite_token:
token
,
invite_email:
user
.
email
)
}
let
(
:member
)
{
create
(
:project_member
,
:invited
,
invite_email:
user
.
email
)
}
let
(
:raw_invite_token
)
{
member
.
raw_invite_token
}
let
(
:project_members
)
{
member
.
source
.
users
}
let
(
:project_members
)
{
member
.
source
.
users
}
let
(
:md5_member_global_id
)
{
Digest
::
MD5
.
hexdigest
(
member
.
to_global_id
.
to_s
)
}
let
(
:md5_member_global_id
)
{
Digest
::
MD5
.
hexdigest
(
member
.
to_global_id
.
to_s
)
}
let
(
:params
)
{
{
id:
raw_invite_token
}
}
before
do
before
do
stub_application_setting
(
snowplow_enabled:
true
,
snowplow_collector_hostname:
'localhost'
)
stub_application_setting
(
snowplow_enabled:
true
,
snowplow_collector_hostname:
'localhost'
)
controller
.
instance_variable_set
(
:@member
,
member
)
controller
.
instance_variable_set
(
:@member
,
member
)
sign_in
(
user
)
end
end
describe
'GET #show'
do
describe
'GET #show'
do
let
(
:params
)
{
{
id:
token
}
}
subject
(
:request
)
{
get
:show
,
params:
params
}
subject
(
:request
)
{
get
:show
,
params:
params
}
it
'accepts user if invite email matches signed in user'
do
context
'when logged in'
do
expect
do
before
do
request
sign_in
(
user
)
end
.
to
change
{
project_members
.
include?
(
user
)
}.
from
(
false
).
to
(
true
)
end
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
flash
[
:notice
]).
to
include
'You have been granted'
end
it
'forces re-confirmation if email does not match signed in user'
do
it
'accepts user if invite email matches signed in user'
do
member
.
invite_email
=
'bogus@email.com'
expect
do
request
end
.
to
change
{
project_members
.
include?
(
user
)
}.
from
(
false
).
to
(
true
)
expect
do
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
request
expect
(
flash
[
:notice
]).
to
include
'You have been granted'
end
.
not_to
change
{
project_members
.
include?
(
user
)
}
end
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
it
'forces re-confirmation if email does not match signed in user'
do
expect
(
flash
[
:notice
]).
to
be_nil
member
.
invite_email
=
'bogus@email.com'
end
context
'when new_user_invite is not set'
do
expect
do
it
'does not track the user as experiment group'
do
request
e
xpect
(
Gitlab
::
Tracking
).
not_to
receive
(
:event
)
e
nd
.
not_to
change
{
project_members
.
include?
(
user
)
}
request
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
flash
[
:notice
]).
to
be_nil
end
end
end
context
'when new_user_invite is experiment'
do
context
'when new_user_invite is not set'
do
let
(
:params
)
{
{
id:
token
,
new_user_invite:
'experiment'
}
}
it
'does not track the user as experiment group'
do
expect
(
Gitlab
::
Tracking
).
not_to
receive
(
:event
)
it
'tracks the user as experiment group'
do
request
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
end
'Growth::Acquisition::Experiment::InviteEmail'
,
end
'opened'
,
property:
'experiment_group'
,
label:
md5_member_global_id
)
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
'Growth::Acquisition::Experiment::InviteEmail'
,
'accepted'
,
property:
'experiment_group'
,
label:
md5_member_global_id
)
request
context
'when new_user_invite is experiment'
do
let
(
:params
)
{
{
id:
raw_invite_token
,
new_user_invite:
'experiment'
}
}
it
'tracks the user as experiment group'
do
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
'Growth::Acquisition::Experiment::InviteEmail'
,
'opened'
,
property:
'experiment_group'
,
label:
md5_member_global_id
)
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
'Growth::Acquisition::Experiment::InviteEmail'
,
'accepted'
,
property:
'experiment_group'
,
label:
md5_member_global_id
)
request
end
end
context
'when new_user_invite is control'
do
let
(
:params
)
{
{
id:
raw_invite_token
,
new_user_invite:
'control'
}
}
it
'tracks the user as control group'
do
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
'Growth::Acquisition::Experiment::InviteEmail'
,
'opened'
,
property:
'control_group'
,
label:
md5_member_global_id
)
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
'Growth::Acquisition::Experiment::InviteEmail'
,
'accepted'
,
property:
'control_group'
,
label:
md5_member_global_id
)
request
end
end
end
end
end
context
'when new_user_invite is control'
do
context
'when not logged in'
do
let
(
:params
)
{
{
id:
token
,
new_user_invite:
'control'
}
}
context
'when inviter is a member'
do
it
'is redirected to a new session with invite email param'
do
request
it
'tracks the user as control group'
do
expect
(
response
).
to
redirect_to
(
new_user_session_path
(
invite_email:
member
.
invite_email
))
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
end
'Growth::Acquisition::Experiment::InviteEmail'
,
end
'opened'
,
property:
'control_group'
,
label:
md5_member_global_id
)
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
'Growth::Acquisition::Experiment::InviteEmail'
,
'accepted'
,
property:
'control_group'
,
label:
md5_member_global_id
)
request
context
'when inviter is not a member'
do
let
(
:params
)
{
{
id:
'_bogus_token_'
}
}
it
'is redirected to a new session'
do
request
expect
(
response
).
to
redirect_to
(
new_user_session_path
)
end
end
end
end
end
end
end
describe
'POST #accept'
do
describe
'POST #accept'
do
let
(
:params
)
{
{
id:
token
}
}
before
do
sign_in
(
user
)
end
subject
(
:request
)
{
post
:accept
,
params:
params
}
subject
(
:request
)
{
post
:accept
,
params:
params
}
...
@@ -105,7 +131,7 @@ RSpec.describe InvitesController do
...
@@ -105,7 +131,7 @@ RSpec.describe InvitesController do
end
end
context
'when new_user_invite is experiment'
do
context
'when new_user_invite is experiment'
do
let
(
:params
)
{
{
id:
token
,
new_user_invite:
'experiment'
}
}
let
(
:params
)
{
{
id:
raw_invite_
token
,
new_user_invite:
'experiment'
}
}
it
'tracks the user as experiment group'
do
it
'tracks the user as experiment group'
do
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
...
@@ -120,7 +146,7 @@ RSpec.describe InvitesController do
...
@@ -120,7 +146,7 @@ RSpec.describe InvitesController do
end
end
context
'when new_user_invite is control'
do
context
'when new_user_invite is control'
do
let
(
:params
)
{
{
id:
token
,
new_user_invite:
'control'
}
}
let
(
:params
)
{
{
id:
raw_invite_
token
,
new_user_invite:
'control'
}
}
it
'tracks the user as control group'
do
it
'tracks the user as control group'
do
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
expect
(
Gitlab
::
Tracking
).
to
receive
(
:event
).
and_call_original
.
with
(
...
...
spec/models/member_spec.rb
View file @
f27f14f4
...
@@ -630,6 +630,14 @@ RSpec.describe Member do
...
@@ -630,6 +630,14 @@ RSpec.describe Member do
end
end
end
end
describe
'.find_by_invite_token'
do
let!
(
:member
)
{
create
(
:project_member
,
invite_email:
"user@example.com"
,
user:
nil
)
}
it
'finds the member'
do
expect
(
described_class
.
find_by_invite_token
(
member
.
raw_invite_token
)).
to
eq
member
end
end
describe
"#invite_to_unknown_user?"
do
describe
"#invite_to_unknown_user?"
do
subject
{
member
.
invite_to_unknown_user?
}
subject
{
member
.
invite_to_unknown_user?
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment