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
0
Merge Requests
0
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
Jérome Perrin
gitlab-ce
Commits
b214be49
Commit
b214be49
authored
Dec 02, 2016
by
James Lopez
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
big refactor based on MR feedback
parent
daa4f3de
Changes
32
Hide whitespace changes
Inline
Side-by-side
Showing
32 changed files
with
136 additions
and
129 deletions
+136
-129
app/models/cycle_analytics.rb
app/models/cycle_analytics.rb
+1
-1
lib/gitlab/cycle_analytics/base_event_fetcher.rb
lib/gitlab/cycle_analytics/base_event_fetcher.rb
+4
-8
lib/gitlab/cycle_analytics/base_stage.rb
lib/gitlab/cycle_analytics/base_stage.rb
+9
-4
lib/gitlab/cycle_analytics/class_name_util.rb
lib/gitlab/cycle_analytics/class_name_util.rb
+0
-13
lib/gitlab/cycle_analytics/code_event_fetcher.rb
lib/gitlab/cycle_analytics/code_event_fetcher.rb
+4
-3
lib/gitlab/cycle_analytics/code_stage.rb
lib/gitlab/cycle_analytics/code_stage.rb
+11
-6
lib/gitlab/cycle_analytics/event.rb
lib/gitlab/cycle_analytics/event.rb
+1
-1
lib/gitlab/cycle_analytics/issue_event_fetcher.rb
lib/gitlab/cycle_analytics/issue_event_fetcher.rb
+1
-3
lib/gitlab/cycle_analytics/issue_stage.rb
lib/gitlab/cycle_analytics/issue_stage.rb
+12
-7
lib/gitlab/cycle_analytics/metrics_fetcher.rb
lib/gitlab/cycle_analytics/metrics_fetcher.rb
+14
-11
lib/gitlab/cycle_analytics/plan_event_fetcher.rb
lib/gitlab/cycle_analytics/plan_event_fetcher.rb
+1
-4
lib/gitlab/cycle_analytics/plan_stage.rb
lib/gitlab/cycle_analytics/plan_stage.rb
+12
-7
lib/gitlab/cycle_analytics/production_event_fetcher.rb
lib/gitlab/cycle_analytics/production_event_fetcher.rb
+1
-4
lib/gitlab/cycle_analytics/production_stage.rb
lib/gitlab/cycle_analytics/production_stage.rb
+11
-6
lib/gitlab/cycle_analytics/review_event_fetcher.rb
lib/gitlab/cycle_analytics/review_event_fetcher.rb
+1
-6
lib/gitlab/cycle_analytics/review_stage.rb
lib/gitlab/cycle_analytics/review_stage.rb
+11
-6
lib/gitlab/cycle_analytics/stage.rb
lib/gitlab/cycle_analytics/stage.rb
+1
-1
lib/gitlab/cycle_analytics/staging_event_fetcher.rb
lib/gitlab/cycle_analytics/staging_event_fetcher.rb
+1
-3
lib/gitlab/cycle_analytics/staging_stage.rb
lib/gitlab/cycle_analytics/staging_stage.rb
+11
-6
lib/gitlab/cycle_analytics/test_event.rb
lib/gitlab/cycle_analytics/test_event.rb
+0
-12
lib/gitlab/cycle_analytics/test_event_fetcher.rb
lib/gitlab/cycle_analytics/test_event_fetcher.rb
+6
-0
lib/gitlab/cycle_analytics/test_stage.rb
lib/gitlab/cycle_analytics/test_stage.rb
+11
-6
spec/lib/gitlab/cycle_analytics/code_event_fetcher_spec.rb
spec/lib/gitlab/cycle_analytics/code_event_fetcher_spec.rb
+1
-1
spec/lib/gitlab/cycle_analytics/issue_event_fetcher_spec.rb
spec/lib/gitlab/cycle_analytics/issue_event_fetcher_spec.rb
+1
-1
spec/lib/gitlab/cycle_analytics/plan_event_fetcher_spec.rb
spec/lib/gitlab/cycle_analytics/plan_event_fetcher_spec.rb
+1
-1
spec/lib/gitlab/cycle_analytics/production_event_fetcher_spec.rb
...b/gitlab/cycle_analytics/production_event_fetcher_spec.rb
+1
-1
spec/lib/gitlab/cycle_analytics/review_event_fetcher_spec.rb
spec/lib/gitlab/cycle_analytics/review_event_fetcher_spec.rb
+1
-1
spec/lib/gitlab/cycle_analytics/shared_event_spec.rb
spec/lib/gitlab/cycle_analytics/shared_event_spec.rb
+3
-2
spec/lib/gitlab/cycle_analytics/shared_stage_spec.rb
spec/lib/gitlab/cycle_analytics/shared_stage_spec.rb
+1
-1
spec/lib/gitlab/cycle_analytics/staging_event_fetcher_spec.rb
.../lib/gitlab/cycle_analytics/staging_event_fetcher_spec.rb
+1
-1
spec/lib/gitlab/cycle_analytics/test_event_fetcher_spec.rb
spec/lib/gitlab/cycle_analytics/test_event_fetcher_spec.rb
+1
-1
spec/serializers/analytics_stage_serializer_spec.rb
spec/serializers/analytics_stage_serializer_spec.rb
+1
-1
No files found.
app/models/cycle_analytics.rb
View file @
b214be49
...
...
@@ -32,7 +32,7 @@ class CycleAnalytics
def
stats_per_stage
STAGES
.
map
do
|
stage_name
|
Gitlab
::
CycleAnalytics
::
Stage
[
stage_name
].
new
(
project:
@project
,
options:
@options
).
median_data
self
[
stage_name
].
new
(
project:
@project
,
options:
@options
).
median_data
end
end
end
lib/gitlab/cycle_analytics/base_event.rb
→
lib/gitlab/cycle_analytics/base_event
_fetcher
.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
BaseEvent
class
BaseEvent
Fetcher
include
MetricsTables
include
ClassNameUtil
attr_reader
:
start_time_attrs
,
:end_time_attrs
,
:projections
,
:query
attr_reader
:
projections
,
:query
,
:stage
def
initialize
(
fetcher
:,
options
:)
def
initialize
(
fetcher
:,
options
:
,
stage
:
)
@fetcher
=
fetcher
@project
=
fetcher
.
project
@options
=
options
@stage
=
stage
end
def
fetch
...
...
@@ -26,10 +26,6 @@ module Gitlab
@order
||
@start_time_attrs
end
def
stage
class_name_for
(
'Event'
)
end
private
def
update_author!
...
...
lib/gitlab/cycle_analytics/base_stage.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
BaseStage
include
ClassNameUtil
attr_accessor
:start_time_attrs
,
:end_time_attrs
def
initialize
(
project
:,
options
:)
@project
=
project
@options
=
options
@fetcher
=
Gitlab
::
CycleAnalytics
::
MetricsFetcher
.
new
(
project:
project
,
from:
options
[
:from
],
branch:
options
[
:branch
])
branch:
options
[
:branch
],
stage:
self
)
end
def
event
@event
||=
Gitlab
::
CycleAnalytics
::
Event
[
stage
].
new
(
fetcher:
@fetcher
,
options:
@options
)
end
def
events
Gitlab
::
CycleAnalytics
::
Event
[
stage
].
new
(
fetcher:
@fetcher
,
options:
@options
)
.
fetch
event
.
fetch
end
def
median_data
...
...
@@ -24,7 +29,7 @@ module Gitlab
end
def
median
raise
NotImplementedError
.
new
(
"Expected
#{
self
.
name
}
to implement median"
)
@fetcher
.
median
end
private
...
...
lib/gitlab/cycle_analytics/class_name_util.rb
deleted
100644 → 0
View file @
daa4f3de
module
Gitlab
module
CycleAnalytics
module
ClassNameUtil
def
class_name_for
(
type
)
class_name
.
split
(
type
).
first
.
to_sym
end
def
class_name
self
.
class
.
name
.
demodulize
end
end
end
end
lib/gitlab/cycle_analytics/
review_event
.rb
→
lib/gitlab/cycle_analytics/
code_event_fetcher
.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
ReviewEvent
<
BaseEvent
class
CodeEventFetcher
<
BaseEventFetcher
include
MergeRequestAllowed
def
initialize
(
*
args
)
@start_time_attrs
=
mr_table
[
:created_at
]
@end_time_attrs
=
mr_metrics_table
[
:merged_at
]
@projections
=
[
mr_table
[
:title
],
mr_table
[
:iid
],
mr_table
[
:id
],
mr_table
[
:created_at
],
mr_table
[
:state
],
mr_table
[
:author_id
]]
@order
=
mr_table
[
:created_at
]
super
(
*
args
)
end
private
def
serialize
(
event
)
AnalyticsMergeRequestSerializer
.
new
(
project:
@project
).
represent
(
event
).
as_json
end
...
...
lib/gitlab/cycle_analytics/code_stage.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
CodeStage
<
BaseStage
def
description
"Time until first merge request"
def
initialize
(
*
args
)
@start_time_attrs
=
issue_metrics_table
[
:first_mentioned_in_commit_at
]
@end_time_attrs
=
mr_table
[
:created_at
]
super
(
*
args
)
end
def
median
@fetcher
.
median
(
:code
,
Issue
::
Metrics
.
arel_table
[
:first_mentioned_in_commit_at
],
MergeRequest
.
arel_table
[
:created_at
])
def
stage
:code
end
def
description
"Time until first merge request"
end
end
end
...
...
lib/gitlab/cycle_analytics/event.rb
View file @
b214be49
...
...
@@ -2,7 +2,7 @@ module Gitlab
module
CycleAnalytics
module
Event
def
self
.
[]
(
stage_name
)
const_get
(
"::Gitlab::CycleAnalytics::
#{
stage_name
.
to_s
.
camelize
}
Event"
)
CycleAnalytics
.
const_get
(
"
#{
stage_name
.
to_s
.
camelize
}
Event"
)
end
end
end
...
...
lib/gitlab/cycle_analytics/
production_event
.rb
→
lib/gitlab/cycle_analytics/
issue_event_fetcher
.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
ProductionEvent
<
BaseEvent
class
IssueEventFetcher
<
BaseEventFetcher
include
IssueAllowed
def
initialize
(
*
args
)
@start_time_attrs
=
issue_table
[
:created_at
]
@end_time_attrs
=
mr_metrics_table
[
:first_deployed_to_production_at
]
@projections
=
[
issue_table
[
:title
],
issue_table
[
:iid
],
issue_table
[
:id
],
...
...
lib/gitlab/cycle_analytics/issue_stage.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
IssueStage
<
BaseStage
def
description
"Time before an issue gets scheduled"
def
initialize
(
*
args
)
@start_time_attrs
=
issue_table
[
:created_at
]
@end_time_attrs
=
[
issue_metrics_table
[
:first_associated_with_milestone_at
],
issue_metrics_table
[
:first_added_to_board_at
]]
super
(
*
args
)
end
def
median
@fetcher
.
median
(
:issue
,
Issue
.
arel_table
[
:created_at
],
[
Issue
::
Metrics
.
arel_table
[
:first_associated_with_milestone_at
],
Issue
::
Metrics
.
arel_table
[
:first_added_to_board_at
]])
def
stage
:issue
end
def
description
"Time before an issue gets scheduled"
end
end
end
...
...
lib/gitlab/cycle_analytics/metrics_fetcher.rb
View file @
b214be49
...
...
@@ -9,14 +9,15 @@ module Gitlab
DEPLOYMENT_METRIC_STAGES
=
%i[production staging]
def
initialize
(
project
:,
from
:,
branch
:)
def
initialize
(
project
:,
from
:,
branch
:
,
stage
:
)
@project
=
project
@from
=
from
@branch
=
branch
@stage
=
stage
end
def
median
(
name
,
start_time_attrs
,
end_time_attrs
)
cte_table
=
Arel
::
Table
.
new
(
"cte_table_for_
#{
nam
e
}
"
)
def
median
cte_table
=
Arel
::
Table
.
new
(
"cte_table_for_
#{
@stage
.
stag
e
}
"
)
# Build a `SELECT` query. We find the first of the `end_time_attrs` that isn't `NULL` (call this end_time).
# Next, we find the first of the start_time_attrs that isn't `NULL` (call this start_time).
...
...
@@ -24,24 +25,26 @@ module Gitlab
# cycle analytics stage.
interval_query
=
Arel
::
Nodes
::
As
.
new
(
cte_table
,
subtract_datetimes
(
base_query_for
(
name
),
start_time_attrs
,
end_time_attrs
,
nam
e
.
to_s
))
subtract_datetimes
(
base_query_for
(
name
),
@stage
.
start_time_attrs
,
@stage
.
end_time_attrs
,
@stage
.
stag
e
.
to_s
))
median_datetime
(
cte_table
,
interval_query
,
name
)
end
def
events
(
stage_class
)
ActiveRecord
::
Base
.
connection
.
exec_query
(
events_query
(
stage_class
)
.
to_sql
)
def
events
ActiveRecord
::
Base
.
connection
.
exec_query
(
events_query
.
to_sql
)
end
private
def
events_query
(
stage_class
)
base_query
=
base_query_for
(
stage_class
.
stage
)
diff_fn
=
subtract_datetimes_diff
(
base_query
,
stage_class
.
start_time_attrs
,
stage_class
.
end_time_attrs
)
def
events_query
base_query
=
base_query_for
(
@stage
.
stage
)
event
=
@stage
.
event
stage_class
.
custom_query
(
base_query
)
diff_fn
=
subtract_datetimes_diff
(
base_query
,
@stage
.
start_time_attrs
,
@stage
.
end_time_attrs
)
base_query
.
project
(
extract_diff_epoch
(
diff_fn
).
as
(
'total_time'
),
*
stage_class
.
projections
).
order
(
stage_class
.
order
.
desc
)
event_instance
.
custom_query
(
base_query
)
base_query
.
project
(
extract_diff_epoch
(
diff_fn
).
as
(
'total_time'
),
*
event
.
projections
).
order
(
event
.
order
.
desc
)
end
# Join table with a row for every <issue,merge_request> pair (where the merge request
...
...
lib/gitlab/cycle_analytics/plan_event.rb
→
lib/gitlab/cycle_analytics/plan_event
_fetcher
.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
PlanEvent
<
BaseEvent
class
PlanEvent
Fetcher
<
BaseEventFetcher
def
initialize
(
*
args
)
@start_time_attrs
=
issue_metrics_table
[
:first_associated_with_milestone_at
]
@end_time_attrs
=
[
issue_metrics_table
[
:first_added_to_board_at
],
issue_metrics_table
[
:first_mentioned_in_commit_at
]]
@projections
=
[
mr_diff_table
[
:st_commits
].
as
(
'commits'
),
issue_metrics_table
[
:first_mentioned_in_commit_at
]]
...
...
lib/gitlab/cycle_analytics/plan_stage.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
PlanStage
<
BaseStage
def
description
"Time before an issue starts implementation"
def
initialize
(
*
args
)
@start_time_attrs
=
[
issue_metrics_table
[
:first_associated_with_milestone_at
],
issue_metrics_table
[
:first_added_to_board_at
]]
@end_time_attrs
=
issue_metrics_table
[
:first_mentioned_in_commit_at
]
super
(
*
args
)
end
def
median
@fetcher
.
median
(
:plan
,
[
Issue
::
Metrics
.
arel_table
[
:first_associated_with_milestone_at
],
Issue
::
Metrics
.
arel_table
[
:first_added_to_board_at
]],
Issue
::
Metrics
.
arel_table
[
:first_mentioned_in_commit_at
])
def
stage
:code
end
def
description
"Time before an issue starts implementation"
end
end
end
...
...
lib/gitlab/cycle_analytics/
issue_event
.rb
→
lib/gitlab/cycle_analytics/
production_event_fetcher
.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
IssueEvent
<
BaseEvent
class
ProductionEventFetcher
<
BaseEventFetcher
include
IssueAllowed
def
initialize
(
*
args
)
@start_time_attrs
=
issue_table
[
:created_at
]
@end_time_attrs
=
[
issue_metrics_table
[
:first_associated_with_milestone_at
],
issue_metrics_table
[
:first_added_to_board_at
]]
@projections
=
[
issue_table
[
:title
],
issue_table
[
:iid
],
issue_table
[
:id
],
...
...
lib/gitlab/cycle_analytics/production_stage.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
ProductionStage
<
BaseStage
def
description
"From issue creation until deploy to production"
def
initialize
(
*
args
)
@start_time_attrs
=
issue_table
[
:created_at
]
@end_time_attrs
=
mr_metrics_table
[
:first_deployed_to_production_at
]
super
(
*
args
)
end
def
median
@fetcher
.
median
(
:production
,
Issue
.
arel_table
[
:created_at
],
MergeRequest
::
Metrics
.
arel_table
[
:first_deployed_to_production_at
])
def
stage
:production
end
def
description
"From issue creation until deploy to production"
end
end
end
...
...
lib/gitlab/cycle_analytics/
code_event
.rb
→
lib/gitlab/cycle_analytics/
review_event_fetcher
.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
CodeEvent
<
BaseEvent
class
ReviewEventFetcher
<
BaseEventFetcher
include
MergeRequestAllowed
def
initialize
(
*
args
)
@start_time_attrs
=
issue_metrics_table
[
:first_mentioned_in_commit_at
]
@end_time_attrs
=
mr_table
[
:created_at
]
@projections
=
[
mr_table
[
:title
],
mr_table
[
:iid
],
mr_table
[
:id
],
mr_table
[
:created_at
],
mr_table
[
:state
],
mr_table
[
:author_id
]]
@order
=
mr_table
[
:created_at
]
super
(
*
args
)
end
private
def
serialize
(
event
)
AnalyticsMergeRequestSerializer
.
new
(
project:
@project
).
represent
(
event
).
as_json
end
...
...
lib/gitlab/cycle_analytics/review_stage.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
ReviewStage
<
BaseStage
def
description
"Time between merge request creation and merge/close"
def
initialize
(
*
args
)
@start_time_attrs
=
mr_table
[
:created_at
]
@end_time_attrs
=
mr_metrics_table
[
:merged_at
]
super
(
*
args
)
end
def
median
@fetcher
.
median
(
:review
,
MergeRequest
.
arel_table
[
:created_at
],
MergeRequest
::
Metrics
.
arel_table
[
:merged_at
])
def
stage
:review
end
def
description
"Time between merge request creation and merge/close"
end
end
end
...
...
lib/gitlab/cycle_analytics/stage.rb
View file @
b214be49
...
...
@@ -2,7 +2,7 @@ module Gitlab
module
CycleAnalytics
module
Stage
def
self
.
[]
(
stage_name
)
const_get
(
"::Gitlab::CycleAnalytics::
#{
stage_name
.
to_s
.
camelize
}
Stage"
)
CycleAnalytics
.
const_get
(
"
#{
stage_name
.
to_s
.
camelize
}
Stage"
)
end
end
end
...
...
lib/gitlab/cycle_analytics/staging_event.rb
→
lib/gitlab/cycle_analytics/staging_event
_fetcher
.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
StagingEvent
<
BaseEvent
class
StagingEvent
Fetcher
<
BaseEventFetcher
def
initialize
(
*
args
)
@start_time_attrs
=
mr_metrics_table
[
:merged_at
]
@end_time_attrs
=
mr_metrics_table
[
:first_deployed_to_production_at
]
@projections
=
[
build_table
[
:id
]]
@order
=
build_table
[
:created_at
]
...
...
lib/gitlab/cycle_analytics/staging_stage.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
StagingStage
<
BaseStage
def
description
"From merge request merge until deploy to production"
def
initialize
(
*
args
)
@start_time_attrs
=
mr_metrics_table
[
:merged_at
]
@end_time_attrs
=
mr_metrics_table
[
:first_deployed_to_production_at
]
super
(
*
args
)
end
def
median
@fetcher
.
median
(
:staging
,
MergeRequest
::
Metrics
.
arel_table
[
:merged_at
],
MergeRequest
::
Metrics
.
arel_table
[
:first_deployed_to_production_at
])
def
stage
:staging
end
def
description
"From merge request merge until deploy to production"
end
end
end
...
...
lib/gitlab/cycle_analytics/test_event.rb
deleted
100644 → 0
View file @
daa4f3de
module
Gitlab
module
CycleAnalytics
class
TestEvent
<
StagingEvent
def
initialize
(
*
args
)
super
(
*
args
)
@start_time_attrs
=
mr_metrics_table
[
:latest_build_started_at
]
@end_time_attrs
=
mr_metrics_table
[
:latest_build_finished_at
]
end
end
end
end
lib/gitlab/cycle_analytics/test_event_fetcher.rb
0 → 100644
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
TestEventFetcher
<
StagingEventFetcher
end
end
end
lib/gitlab/cycle_analytics/test_stage.rb
View file @
b214be49
module
Gitlab
module
CycleAnalytics
class
TestStage
<
BaseStage
def
description
"Total test time for all commits/merges"
def
initialize
(
*
args
)
@start_time_attrs
=
mr_metrics_table
[
:latest_build_started_at
]
@end_time_attrs
=
mr_metrics_table
[
:latest_build_finished_at
]
super
(
*
args
)
end
def
median
@fetcher
.
median
(
:test
,
MergeRequest
::
Metrics
.
arel_table
[
:latest_build_started_at
],
MergeRequest
::
Metrics
.
arel_table
[
:latest_build_finished_at
])
def
stage
:test
end
def
description
"Total test time for all commits/merges"
end
end
end
...
...
spec/lib/gitlab/cycle_analytics/code_event_spec.rb
→
spec/lib/gitlab/cycle_analytics/code_event_
fetcher_
spec.rb
View file @
b214be49
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_event_spec'
describe
Gitlab
::
CycleAnalytics
::
CodeEvent
do
describe
Gitlab
::
CycleAnalytics
::
CodeEvent
Fetcher
do
let
(
:stage_name
)
{
:code
}
it_behaves_like
'default query config'
do
...
...
spec/lib/gitlab/cycle_analytics/issue_event_spec.rb
→
spec/lib/gitlab/cycle_analytics/issue_event_
fetcher_
spec.rb
View file @
b214be49
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_event_spec'
describe
Gitlab
::
CycleAnalytics
::
IssueEvent
do
describe
Gitlab
::
CycleAnalytics
::
IssueEvent
Fetcher
do
let
(
:stage_name
)
{
:issue
}
it_behaves_like
'default query config'
do
...
...
spec/lib/gitlab/cycle_analytics/plan_event_spec.rb
→
spec/lib/gitlab/cycle_analytics/plan_event_
fetcher_
spec.rb
View file @
b214be49
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_event_spec'
describe
Gitlab
::
CycleAnalytics
::
PlanEvent
do
describe
Gitlab
::
CycleAnalytics
::
PlanEvent
Fetcher
do
let
(
:stage_name
)
{
:plan
}
it_behaves_like
'default query config'
do
...
...
spec/lib/gitlab/cycle_analytics/production_event_spec.rb
→
spec/lib/gitlab/cycle_analytics/production_event_
fetcher_
spec.rb
View file @
b214be49
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_event_spec'
describe
Gitlab
::
CycleAnalytics
::
ProductionEvent
do
describe
Gitlab
::
CycleAnalytics
::
ProductionEvent
Fetcher
do
let
(
:stage_name
)
{
:production
}
it_behaves_like
'default query config'
do
...
...
spec/lib/gitlab/cycle_analytics/review_event_spec.rb
→
spec/lib/gitlab/cycle_analytics/review_event_
fetcher_
spec.rb
View file @
b214be49
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_event_spec'
describe
Gitlab
::
CycleAnalytics
::
ReviewEvent
do
describe
Gitlab
::
CycleAnalytics
::
ReviewEvent
Fetcher
do
let
(
:stage_name
)
{
:review
}
it_behaves_like
'default query config'
do
...
...
spec/lib/gitlab/cycle_analytics/shared_event_spec.rb
View file @
b214be49
...
...
@@ -4,10 +4,11 @@ shared_examples 'default query config' do
let
(
:fetcher
)
do
Gitlab
::
CycleAnalytics
::
MetricsFetcher
.
new
(
project:
create
(
:empty_project
),
from:
1
.
day
.
ago
,
branch:
nil
)
branch:
nil
,
stage:
stage_name
)
end
let
(
:event
)
{
described_class
.
new
(
fetcher:
fetcher
,
options:
{})
}
let
(
:event
)
{
described_class
.
new
(
fetcher:
fetcher
,
options:
{}
,
stage:
stage_name
)
}
it
'has the start attributes'
do
expect
(
event
.
start_time_attrs
).
not_to
be_nil
...
...
spec/lib/gitlab/cycle_analytics/shared_stage_spec.rb
View file @
b214be49
...
...
@@ -5,7 +5,7 @@ shared_examples 'base stage' do
before
do
allow_any_instance_of
(
Gitlab
::
CycleAnalytics
::
MetricsFetcher
).
to
receive
(
:median
).
and_return
(
1.12
)
allow_any_instance_of
(
Gitlab
::
CycleAnalytics
::
BaseEvent
).
to
receive
(
:event_result
).
and_return
({})
allow_any_instance_of
(
Gitlab
::
CycleAnalytics
::
BaseEvent
Fetcher
).
to
receive
(
:event_result
).
and_return
({})
end
it
'has the median data value'
do
...
...
spec/lib/gitlab/cycle_analytics/staging_event_spec.rb
→
spec/lib/gitlab/cycle_analytics/staging_event_
fetcher_
spec.rb
View file @
b214be49
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_event_spec'
describe
Gitlab
::
CycleAnalytics
::
StagingEvent
do
describe
Gitlab
::
CycleAnalytics
::
StagingEvent
Fetcher
do
let
(
:stage_name
)
{
:staging
}
it_behaves_like
'default query config'
do
...
...
spec/lib/gitlab/cycle_analytics/test_event_spec.rb
→
spec/lib/gitlab/cycle_analytics/test_event_
fetcher_
spec.rb
View file @
b214be49
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_event_spec'
describe
Gitlab
::
CycleAnalytics
::
TestEvent
do
describe
Gitlab
::
CycleAnalytics
::
TestEvent
Fetcher
do
let
(
:stage_name
)
{
:test
}
it_behaves_like
'default query config'
do
...
...
spec/serializers/analytics_stage_serializer_spec.rb
View file @
b214be49
...
...
@@ -11,7 +11,7 @@ describe AnalyticsStageSerializer do
before
do
allow_any_instance_of
(
Gitlab
::
CycleAnalytics
::
MetricsFetcher
).
to
receive
(
:median
).
and_return
(
1.12
)
allow_any_instance_of
(
Gitlab
::
CycleAnalytics
::
BaseEvent
).
to
receive
(
:event_result
).
and_return
({})
allow_any_instance_of
(
Gitlab
::
CycleAnalytics
::
BaseEvent
Fetcher
).
to
receive
(
:event_result
).
and_return
({})
end
it
'it generates payload for single object'
do
...
...
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