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
5e081c84
Commit
5e081c84
authored
Jan 28, 2021
by
Alex Buijs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add add_group method to Experiment model
parent
cdc8962f
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
65 additions
and
0 deletions
+65
-0
app/models/experiment.rb
app/models/experiment.rb
+8
-0
spec/models/experiment_spec.rb
spec/models/experiment_spec.rb
+57
-0
No files found.
app/models/experiment.rb
View file @
5e081c84
...
@@ -10,6 +10,10 @@ class Experiment < ApplicationRecord
...
@@ -10,6 +10,10 @@ class Experiment < ApplicationRecord
find_or_create_by!
(
name:
name
).
record_user_and_group
(
user
,
group_type
,
context
)
find_or_create_by!
(
name:
name
).
record_user_and_group
(
user
,
group_type
,
context
)
end
end
def
self
.
add_group
(
name
,
variant
:,
group
:)
find_or_create_by!
(
name:
name
).
record_group_and_variant!
(
group
,
variant
)
end
def
self
.
record_conversion_event
(
name
,
user
)
def
self
.
record_conversion_event
(
name
,
user
)
find_or_create_by!
(
name:
name
).
record_conversion_event_for_user
(
user
)
find_or_create_by!
(
name:
name
).
record_conversion_event_for_user
(
user
)
end
end
...
@@ -24,4 +28,8 @@ class Experiment < ApplicationRecord
...
@@ -24,4 +28,8 @@ class Experiment < ApplicationRecord
def
record_conversion_event_for_user
(
user
)
def
record_conversion_event_for_user
(
user
)
experiment_users
.
find_by
(
user:
user
,
converted_at:
nil
)
&
.
touch
(
:converted_at
)
experiment_users
.
find_by
(
user:
user
,
converted_at:
nil
)
&
.
touch
(
:converted_at
)
end
end
def
record_group_and_variant!
(
group
,
variant
)
experiment_subjects
.
find_or_initialize_by
(
group:
group
).
update!
(
variant:
variant
)
end
end
end
spec/models/experiment_spec.rb
View file @
5e081c84
...
@@ -3,6 +3,8 @@
...
@@ -3,6 +3,8 @@
require
'spec_helper'
require
'spec_helper'
RSpec
.
describe
Experiment
do
RSpec
.
describe
Experiment
do
include
AfterNextHelpers
subject
{
build
(
:experiment
)
}
subject
{
build
(
:experiment
)
}
describe
'associations'
do
describe
'associations'
do
...
@@ -67,6 +69,33 @@ RSpec.describe Experiment do
...
@@ -67,6 +69,33 @@ RSpec.describe Experiment do
end
end
end
end
describe
'.add_group'
do
let_it_be
(
:experiment_name
)
{
:experiment_key
}
let_it_be
(
:variant
)
{
:control
}
let_it_be
(
:group
)
{
build
(
:group
)
}
subject
(
:add_group
)
{
described_class
.
add_group
(
experiment_name
,
variant:
variant
,
group:
group
)
}
context
'when an experiment with the provided name does not exist'
do
it
'creates a new experiment record'
do
allow_next
(
described_class
,
name: :experiment_key
)
.
to
receive
(
:record_group_and_variant!
).
with
(
group
,
variant
)
expect
{
add_group
}.
to
change
(
described_class
,
:count
).
by
(
1
)
end
end
context
'when an experiment with the provided name already exists'
do
before
do
create
(
:experiment
,
name:
experiment_name
)
end
it
'does not create a new experiment record'
do
expect
{
add_group
}.
not_to
change
(
described_class
,
:count
)
end
end
end
describe
'.record_conversion_event'
do
describe
'.record_conversion_event'
do
let_it_be
(
:user
)
{
build
(
:user
)
}
let_it_be
(
:user
)
{
build
(
:user
)
}
...
@@ -136,6 +165,34 @@ RSpec.describe Experiment do
...
@@ -136,6 +165,34 @@ RSpec.describe Experiment do
end
end
end
end
describe
'#record_group_and_variant!'
do
let_it_be
(
:group
)
{
create
(
:group
)
}
let_it_be
(
:variant
)
{
:control
}
let_it_be
(
:experiment
)
{
create
(
:experiment
)
}
subject
(
:record_group_and_variant!
)
{
experiment
.
record_group_and_variant!
(
group
,
variant
)
}
context
'when no existing experiment_subject record exists for the given group'
do
it
'creates an experiment_subject record'
do
expect_next
(
ExperimentSubject
).
to
receive
(
:update!
).
with
(
variant:
variant
).
and_call_original
expect
{
record_group_and_variant!
}.
to
change
(
ExperimentSubject
,
:count
).
by
(
1
)
end
end
context
'when an existing experiment_subject exists for the given group'
do
context
'but it belonged to a different variant'
do
let!
(
:experiment_subject
)
do
create
(
:experiment_subject
,
experiment:
experiment
,
group:
group
,
user:
nil
,
variant: :experimental
)
end
it
'updates the variant value'
do
expect
{
record_group_and_variant!
}.
to
change
{
experiment_subject
.
reload
.
variant
}.
to
(
'control'
)
end
end
end
end
describe
'#record_user_and_group'
do
describe
'#record_user_and_group'
do
let_it_be
(
:experiment
)
{
create
(
:experiment
)
}
let_it_be
(
:experiment
)
{
create
(
:experiment
)
}
let_it_be
(
:user
)
{
create
(
:user
)
}
let_it_be
(
:user
)
{
create
(
: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