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
ed39d61d
Commit
ed39d61d
authored
Nov 17, 2016
by
James Lopez
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactor events facade so it uses separate classes and refactor query stuff
parent
f9de157e
Changes
33
Hide whitespace changes
Inline
Side-by-side
Showing
33 changed files
with
928 additions
and
675 deletions
+928
-675
app/controllers/projects/cycle_analytics/events_controller.rb
...controllers/projects/cycle_analytics/events_controller.rb
+1
-1
app/models/cycle_analytics.rb
app/models/cycle_analytics.rb
+8
-9
app/serializers/analytics_generic_serializer.rb
app/serializers/analytics_generic_serializer.rb
+0
-2
app/serializers/analytics_issue_entity.rb
app/serializers/analytics_issue_entity.rb
+2
-3
app/serializers/analytics_issue_serializer.rb
app/serializers/analytics_issue_serializer.rb
+3
-0
app/serializers/analytics_merge_request_entity.rb
app/serializers/analytics_merge_request_entity.rb
+7
-0
app/serializers/analytics_merge_request_serializer.rb
app/serializers/analytics_merge_request_serializer.rb
+3
-0
db/schema.rb
db/schema.rb
+689
-509
lib/gitlab/cycle_analytics/base_config.rb
lib/gitlab/cycle_analytics/base_config.rb
+0
-17
lib/gitlab/cycle_analytics/base_event.rb
lib/gitlab/cycle_analytics/base_event.rb
+27
-0
lib/gitlab/cycle_analytics/code_event.rb
lib/gitlab/cycle_analytics/code_event.rb
+8
-1
lib/gitlab/cycle_analytics/event_config.rb
lib/gitlab/cycle_analytics/event_config.rb
+1
-1
lib/gitlab/cycle_analytics/events.rb
lib/gitlab/cycle_analytics/events.rb
+8
-46
lib/gitlab/cycle_analytics/events_fetcher.rb
lib/gitlab/cycle_analytics/events_fetcher.rb
+1
-3
lib/gitlab/cycle_analytics/events_query.rb
lib/gitlab/cycle_analytics/events_query.rb
+9
-13
lib/gitlab/cycle_analytics/issue_event.rb
lib/gitlab/cycle_analytics/issue_event.rb
+8
-1
lib/gitlab/cycle_analytics/metrics_fetcher.rb
lib/gitlab/cycle_analytics/metrics_fetcher.rb
+8
-34
lib/gitlab/cycle_analytics/metrics_tables.rb
lib/gitlab/cycle_analytics/metrics_tables.rb
+37
-0
lib/gitlab/cycle_analytics/plan_config.rb
lib/gitlab/cycle_analytics/plan_config.rb
+0
-17
lib/gitlab/cycle_analytics/plan_event.rb
lib/gitlab/cycle_analytics/plan_event.rb
+44
-0
lib/gitlab/cycle_analytics/production_event.rb
lib/gitlab/cycle_analytics/production_event.rb
+8
-1
lib/gitlab/cycle_analytics/review_event.rb
lib/gitlab/cycle_analytics/review_event.rb
+21
-0
lib/gitlab/cycle_analytics/staging_event.rb
lib/gitlab/cycle_analytics/staging_event.rb
+8
-1
lib/gitlab/cycle_analytics/test_event.rb
lib/gitlab/cycle_analytics/test_event.rb
+8
-1
spec/lib/gitlab/cycle_analytics/code_event_spec.rb
spec/lib/gitlab/cycle_analytics/code_event_spec.rb
+2
-2
spec/lib/gitlab/cycle_analytics/issue_event_spec.rb
spec/lib/gitlab/cycle_analytics/issue_event_spec.rb
+2
-2
spec/lib/gitlab/cycle_analytics/plan_event_spec.rb
spec/lib/gitlab/cycle_analytics/plan_event_spec.rb
+2
-2
spec/lib/gitlab/cycle_analytics/production_event_spec.rb
spec/lib/gitlab/cycle_analytics/production_event_spec.rb
+2
-2
spec/lib/gitlab/cycle_analytics/review_event_spec.rb
spec/lib/gitlab/cycle_analytics/review_event_spec.rb
+2
-2
spec/lib/gitlab/cycle_analytics/shared_event_spec.rb
spec/lib/gitlab/cycle_analytics/shared_event_spec.rb
+4
-0
spec/lib/gitlab/cycle_analytics/staging_event_spec.rb
spec/lib/gitlab/cycle_analytics/staging_event_spec.rb
+2
-2
spec/lib/gitlab/cycle_analytics/test_event_spec.rb
spec/lib/gitlab/cycle_analytics/test_event_spec.rb
+2
-2
spec/serializers/analytics_generic_entity_spec.rb
spec/serializers/analytics_generic_entity_spec.rb
+1
-1
No files found.
app/controllers/projects/cycle_analytics/events_controller.rb
View file @
ed39d61d
...
...
@@ -19,7 +19,7 @@ module Projects
end
def
test
@options
=
{
from:
start_date
(
events_params
),
branch:
events_params
[
:branch_name
]
}
@options
[
:branch
]
=
events_params
[
:branch_name
]
render_events
(
events
.
test_events
)
end
...
...
app/models/cycle_analytics.rb
View file @
ed39d61d
class
CycleAnalytics
include
Gitlab
::
CycleAnalytics
::
MetricsFetcher
def
initialize
(
project
,
from
:)
@project
=
project
@from
=
from
@fetcher
=
Gitlab
::
CycleAnalytics
::
MetricsFetcher
.
new
(
project:
project
,
from:
from
,
branch:
nil
)
end
def
summary
...
...
@@ -11,45 +10,45 @@ class CycleAnalytics
end
def
issue
calculate_metric
(
:issue
,
@fetcher
.
calculate_metric
(
:issue
,
Issue
.
arel_table
[
:created_at
],
[
Issue
::
Metrics
.
arel_table
[
:first_associated_with_milestone_at
],
Issue
::
Metrics
.
arel_table
[
:first_added_to_board_at
]])
end
def
plan
calculate_metric
(
:plan
,
@fetcher
.
calculate_metric
(
: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
])
end
def
code
calculate_metric
(
:code
,
@fetcher
.
calculate_metric
(
:code
,
Issue
::
Metrics
.
arel_table
[
:first_mentioned_in_commit_at
],
MergeRequest
.
arel_table
[
:created_at
])
end
def
test
calculate_metric
(
:test
,
@fetcher
.
calculate_metric
(
:test
,
MergeRequest
::
Metrics
.
arel_table
[
:latest_build_started_at
],
MergeRequest
::
Metrics
.
arel_table
[
:latest_build_finished_at
])
end
def
review
calculate_metric
(
:review
,
@fetcher
.
calculate_metric
(
:review
,
MergeRequest
.
arel_table
[
:created_at
],
MergeRequest
::
Metrics
.
arel_table
[
:merged_at
])
end
def
staging
calculate_metric
(
:staging
,
@fetcher
.
calculate_metric
(
:staging
,
MergeRequest
::
Metrics
.
arel_table
[
:merged_at
],
MergeRequest
::
Metrics
.
arel_table
[
:first_deployed_to_production_at
])
end
def
production
calculate_metric
(
:production
,
@fetcher
.
calculate_metric
(
:production
,
Issue
.
arel_table
[
:created_at
],
MergeRequest
::
Metrics
.
arel_table
[
:first_deployed_to_production_at
])
end
...
...
app/serializers/analytics_generic_serializer.rb
View file @
ed39d61d
class
AnalyticsGenericSerializer
<
BaseSerializer
entity
AnalyticsGenericEntity
def
represent
(
resource
,
opts
=
{})
resource
.
symbolize_keys!
...
...
app/serializers/analytics_
generic
_entity.rb
→
app/serializers/analytics_
issue
_entity.rb
View file @
ed39d61d
class
Analytics
Generic
Entity
<
Grape
::
Entity
class
Analytics
Issue
Entity
<
Grape
::
Entity
include
RequestAwareEntity
include
EntityDateHelper
expose
:title
expose
:state
,
if:
->
(
_instance
,
options
)
{
options
[
:request
].
entity
==
:merge_request
}
expose
:author
,
using:
UserEntity
expose
:iid
do
|
object
|
...
...
@@ -19,7 +18,7 @@ class AnalyticsGenericEntity < Grape::Entity
end
expose
:url
do
|
object
|
url_to
(
"namespace_project_
#{
request
.
entity
}
"
.
to_sym
,
id:
object
[
:iid
].
to_s
)
url_to
(
:namespace_project_issue
,
id:
object
[
:iid
].
to_s
)
end
private
...
...
app/serializers/analytics_issue_serializer.rb
0 → 100644
View file @
ed39d61d
class
AnalyticsIssueSerializer
<
AnalyticsGenericSerializer
entity
AnalyticsIssueEntity
end
app/serializers/analytics_merge_request_entity.rb
0 → 100644
View file @
ed39d61d
class
AnalyticsMergeRequestEntity
<
AnalyticsIssueEntity
expose
:state
expose
:url
do
|
object
|
url_to
(
:namespace_project_merge_request
,
id:
object
[
:iid
].
to_s
)
end
end
app/serializers/analytics_merge_request_serializer.rb
0 → 100644
View file @
ed39d61d
class
AnalyticsMergeRequestSerializer
<
AnalyticsGenericSerializer
entity
AnalyticsMergeRequestEntity
end
db/schema.rb
View file @
ed39d61d
...
...
@@ -13,107 +13,142 @@
ActiveRecord
::
Schema
.
define
(
version:
20161109150329
)
do
# These are extensions that must be enabled in order to support this database
enable_extension
"plpgsql"
enable_extension
"pg_trgm"
create_table
"abuse_reports"
,
force: :cascade
do
|
t
|
t
.
integer
"reporter_id"
t
.
integer
"user_id"
t
.
text
"message"
t
.
integer
"reporter_id"
,
limit:
4
t
.
integer
"user_id"
,
limit:
4
t
.
text
"message"
,
limit:
65535
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
text
"message_html"
t
.
text
"message_html"
,
limit:
65535
end
create_table
"appearances"
,
force: :cascade
do
|
t
|
t
.
string
"title"
t
.
text
"description"
t
.
string
"header_logo"
t
.
string
"logo"
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
text
"description_html"
t
.
string
"title"
,
limit:
255
t
.
text
"description"
,
limit:
65535
t
.
string
"logo"
,
limit:
255
t
.
integer
"updated_by"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"header_logo"
,
limit:
255
t
.
text
"description_html"
,
limit:
65535
end
create_table
"application_settings"
,
force: :cascade
do
|
t
|
t
.
integer
"default_projects_limit"
t
.
integer
"default_projects_limit"
,
limit:
4
t
.
boolean
"signup_enabled"
t
.
boolean
"signin_enabled"
t
.
boolean
"gravatar_enabled"
t
.
text
"sign_in_text"
t
.
text
"sign_in_text"
,
limit:
65535
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"home_page_url"
t
.
integer
"default_branch_protection"
,
default:
2
t
.
text
"restricted_visibility_levels"
t
.
string
"home_page_url"
,
limit:
255
t
.
integer
"default_branch_protection"
,
limit:
4
,
default:
2
t
.
text
"help_text"
,
limit:
65535
t
.
text
"restricted_visibility_levels"
,
limit:
65535
t
.
boolean
"version_check_enabled"
,
default:
true
t
.
integer
"max_attachment_size"
,
default:
10
,
null:
false
t
.
integer
"default_project_visibility"
t
.
integer
"default_snippet_visibility"
t
.
text
"domain_whitelist"
t
.
integer
"max_attachment_size"
,
limit:
4
,
default:
10
,
null:
false
t
.
integer
"default_project_visibility"
,
limit:
4
t
.
integer
"default_snippet_visibility"
,
limit:
4
t
.
text
"domain_whitelist"
,
limit:
65535
t
.
boolean
"user_oauth_applications"
,
default:
true
t
.
string
"after_sign_out_path"
t
.
integer
"session_expire_delay"
,
default:
10080
,
null:
false
t
.
text
"import_sources"
t
.
text
"help_page_text"
t
.
string
"admin_notification_email"
t
.
string
"after_sign_out_path"
,
limit:
255
t
.
integer
"session_expire_delay"
,
limit:
4
,
default:
10080
,
null:
false
t
.
text
"import_sources"
,
limit:
65535
t
.
text
"help_page_text"
,
limit:
65535
t
.
string
"admin_notification_email"
,
limit:
255
t
.
boolean
"shared_runners_enabled"
,
default:
true
,
null:
false
t
.
integer
"max_artifacts_size"
,
default:
100
,
null:
false
t
.
string
"runners_registration_token"
t
.
integer
"max_artifacts_size"
,
limit:
4
,
default:
100
,
null:
false
t
.
string
"runners_registration_token"
,
limit:
255
t
.
integer
"max_pages_size"
,
limit:
4
,
default:
100
,
null:
false
t
.
boolean
"require_two_factor_authentication"
,
default:
false
t
.
integer
"two_factor_grace_period"
,
default:
48
t
.
integer
"two_factor_grace_period"
,
limit:
4
,
default:
48
t
.
boolean
"metrics_enabled"
,
default:
false
t
.
string
"metrics_host"
,
default:
"localhost"
t
.
integer
"metrics_pool_size"
,
default:
16
t
.
integer
"metrics_timeout"
,
default:
10
t
.
integer
"metrics_method_call_threshold"
,
default:
10
t
.
string
"metrics_host"
,
limit:
255
,
default:
"localhost"
t
.
integer
"metrics_pool_size"
,
limit:
4
,
default:
16
t
.
integer
"metrics_timeout"
,
limit:
4
,
default:
10
t
.
integer
"metrics_method_call_threshold"
,
limit:
4
,
default:
10
t
.
boolean
"recaptcha_enabled"
,
default:
false
t
.
string
"recaptcha_site_key"
t
.
string
"recaptcha_private_key"
t
.
integer
"metrics_port"
,
default:
8089
t
.
string
"recaptcha_site_key"
,
limit:
255
t
.
string
"recaptcha_private_key"
,
limit:
255
t
.
integer
"metrics_port"
,
limit:
4
,
default:
8089
t
.
boolean
"akismet_enabled"
,
default:
false
t
.
string
"akismet_api_key"
t
.
integer
"metrics_sample_interval"
,
default:
15
t
.
string
"akismet_api_key"
,
limit:
255
t
.
integer
"metrics_sample_interval"
,
limit:
4
,
default:
15
t
.
boolean
"sentry_enabled"
,
default:
false
t
.
string
"sentry_dsn"
t
.
string
"sentry_dsn"
,
limit:
255
t
.
boolean
"email_author_in_body"
,
default:
false
t
.
integer
"default_group_visibility"
t
.
integer
"default_group_visibility"
,
limit:
4
t
.
boolean
"repository_checks_enabled"
,
default:
false
t
.
text
"shared_runners_text"
t
.
integer
"metrics_packet_size"
,
default:
1
t
.
text
"disabled_oauth_sign_in_sources"
t
.
string
"health_check_access_token"
t
.
text
"shared_runners_text"
,
limit:
65535
t
.
integer
"metrics_packet_size"
,
limit:
4
,
default:
1
t
.
text
"disabled_oauth_sign_in_sources"
,
limit:
65535
t
.
string
"health_check_access_token"
,
limit:
255
t
.
boolean
"send_user_confirmation_email"
,
default:
false
t
.
integer
"container_registry_token_expire_delay"
,
default:
5
t
.
text
"after_sign_up_text"
t
.
integer
"container_registry_token_expire_delay"
,
limit:
4
,
default:
5
t
.
text
"after_sign_up_text"
,
limit:
65535
t
.
boolean
"user_default_external"
,
default:
false
,
null:
false
t
.
string
"repository_storages"
,
default:
"default"
t
.
string
"enabled_git_access_protocol"
t
.
boolean
"elasticsearch_indexing"
,
default:
false
,
null:
false
t
.
boolean
"elasticsearch_search"
,
default:
false
,
null:
false
t
.
string
"elasticsearch_host"
,
limit:
255
,
default:
"localhost"
t
.
string
"elasticsearch_port"
,
limit:
255
,
default:
"9200"
t
.
string
"repository_storages"
,
limit:
255
,
default:
"default"
t
.
string
"enabled_git_access_protocol"
,
limit:
255
t
.
boolean
"domain_blacklist_enabled"
,
default:
false
t
.
text
"domain_blacklist"
t
.
text
"domain_blacklist"
,
limit:
65535
t
.
boolean
"usage_ping_enabled"
,
default:
true
,
null:
false
t
.
boolean
"koding_enabled"
t
.
string
"koding_url"
t
.
text
"sign_in_text_html"
t
.
text
"help_page_text_html"
t
.
text
"shared_runners_text_html"
t
.
text
"after_sign_up_text_html"
t
.
boolean
"sidekiq_throttling_enabled"
,
default:
false
t
.
string
"sidekiq_throttling_queues"
t
.
decimal
"sidekiq_throttling_factor"
t
.
string
"koding_url"
,
limit:
255
t
.
integer
"repository_size_limit"
,
limit:
4
,
default:
0
t
.
text
"sign_in_text_html"
,
limit:
65535
t
.
text
"help_page_text_html"
,
limit:
65535
t
.
text
"shared_runners_text_html"
,
limit:
65535
t
.
text
"after_sign_up_text_html"
,
limit:
65535
t
.
boolean
"user_activity_enabled"
,
default:
true
,
null:
false
t
.
boolean
"housekeeping_enabled"
,
default:
true
,
null:
false
t
.
boolean
"housekeeping_bitmaps_enabled"
,
default:
true
,
null:
false
t
.
integer
"housekeeping_incremental_repack_period"
,
default:
10
,
null:
false
t
.
integer
"housekeeping_full_repack_period"
,
default:
50
,
null:
false
t
.
integer
"housekeeping_gc_period"
,
default:
200
,
null:
false
t
.
integer
"housekeeping_incremental_repack_period"
,
limit:
4
,
default:
10
,
null:
false
t
.
integer
"housekeeping_full_repack_period"
,
limit:
4
,
default:
50
,
null:
false
t
.
integer
"housekeeping_gc_period"
,
limit:
4
,
default:
200
,
null:
false
t
.
boolean
"sidekiq_throttling_enabled"
,
default:
false
t
.
string
"sidekiq_throttling_queues"
,
limit:
255
t
.
decimal
"sidekiq_throttling_factor"
,
precision:
10
end
create_table
"approvals"
,
force: :cascade
do
|
t
|
t
.
integer
"merge_request_id"
,
limit:
4
,
null:
false
t
.
integer
"user_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
create_table
"approver_groups"
,
force: :cascade
do
|
t
|
t
.
integer
"target_id"
,
limit:
4
,
null:
false
t
.
string
"target_type"
,
limit:
255
,
null:
false
t
.
integer
"group_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
add_index
"approver_groups"
,
[
"group_id"
],
name:
"index_approver_groups_on_group_id"
,
using: :btree
add_index
"approver_groups"
,
[
"target_id"
,
"target_type"
],
name:
"index_approver_groups_on_target_id_and_target_type"
,
using: :btree
create_table
"approvers"
,
force: :cascade
do
|
t
|
t
.
integer
"target_id"
,
limit:
4
,
null:
false
t
.
string
"target_type"
,
limit:
255
t
.
integer
"user_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
add_index
"approvers"
,
[
"target_id"
,
"target_type"
],
name:
"index_approvers_on_target_id_and_target_type"
,
using: :btree
add_index
"approvers"
,
[
"user_id"
],
name:
"index_approvers_on_user_id"
,
using: :btree
create_table
"audit_events"
,
force: :cascade
do
|
t
|
t
.
integer
"author_id"
,
null:
false
t
.
string
"type"
,
null:
false
t
.
integer
"entity_id"
,
null:
false
t
.
string
"entity_type"
,
null:
false
t
.
text
"details"
t
.
integer
"author_id"
,
limit:
4
,
null:
false
t
.
string
"type"
,
limit:
255
,
null:
false
t
.
integer
"entity_id"
,
limit:
4
,
null:
false
t
.
string
"entity_type"
,
limit:
255
,
null:
false
t
.
text
"details"
,
limit:
65535
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
...
...
@@ -121,10 +156,10 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"audit_events"
,
[
"entity_id"
,
"entity_type"
],
name:
"index_audit_events_on_entity_id_and_entity_type"
,
using: :btree
create_table
"award_emoji"
,
force: :cascade
do
|
t
|
t
.
string
"name"
t
.
integer
"user_id"
t
.
integer
"awardable_id"
t
.
string
"awardable_type"
t
.
string
"name"
,
limit:
255
t
.
integer
"user_id"
,
limit:
4
t
.
integer
"awardable_id"
,
limit:
4
t
.
string
"awardable_type"
,
limit:
255
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
...
...
@@ -134,22 +169,23 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"award_emoji"
,
[
"user_id"
],
name:
"index_award_emoji_on_user_id"
,
using: :btree
create_table
"boards"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
string
"name"
,
limit:
255
,
default:
"Development"
,
null:
false
end
add_index
"boards"
,
[
"project_id"
],
name:
"index_boards_on_project_id"
,
using: :btree
create_table
"broadcast_messages"
,
force: :cascade
do
|
t
|
t
.
text
"message"
,
null:
false
t
.
text
"message"
,
limit:
65535
,
null:
false
t
.
datetime
"starts_at"
t
.
datetime
"ends_at"
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"color"
t
.
string
"font"
t
.
text
"message_html"
t
.
string
"color"
,
limit:
255
t
.
string
"font"
,
limit:
255
t
.
text
"message_html"
,
limit:
65535
end
create_table
"ci_application_settings"
,
force: :cascade
do
|
t
|
...
...
@@ -160,44 +196,44 @@ ActiveRecord::Schema.define(version: 20161109150329) do
end
create_table
"ci_builds"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
t
.
string
"status"
t
.
integer
"project_id"
,
limit:
4
t
.
string
"status"
,
limit:
255
t
.
datetime
"finished_at"
t
.
text
"trace"
t
.
text
"trace"
,
limit:
65535
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
datetime
"started_at"
t
.
integer
"runner_id"
t
.
float
"coverage"
t
.
integer
"commit_id"
t
.
text
"commands"
t
.
integer
"job_id"
t
.
string
"name"
t
.
integer
"runner_id"
,
limit:
4
t
.
float
"coverage"
,
limit:
24
t
.
integer
"commit_id"
,
limit:
4
t
.
text
"commands"
,
limit:
65535
t
.
integer
"job_id"
,
limit:
4
t
.
string
"name"
,
limit:
255
t
.
boolean
"deploy"
,
default:
false
t
.
text
"options"
t
.
text
"options"
,
limit:
65535
t
.
boolean
"allow_failure"
,
default:
false
,
null:
false
t
.
string
"stage"
t
.
integer
"trigger_request_id"
t
.
integer
"stage_idx"
t
.
string
"stage"
,
limit:
255
t
.
integer
"trigger_request_id"
,
limit:
4
t
.
integer
"stage_idx"
,
limit:
4
t
.
boolean
"tag"
t
.
string
"ref"
t
.
integer
"user_id"
t
.
string
"type"
t
.
string
"target_url"
t
.
string
"description"
t
.
text
"artifacts_file"
t
.
integer
"gl_project_id"
t
.
text
"artifacts_metadata"
t
.
integer
"erased_by_id"
t
.
string
"ref"
,
limit:
255
t
.
integer
"user_id"
,
limit:
4
t
.
string
"type"
,
limit:
255
t
.
string
"target_url"
,
limit:
255
t
.
string
"description"
,
limit:
255
t
.
text
"artifacts_file"
,
limit:
65535
t
.
integer
"gl_project_id"
,
limit:
4
t
.
text
"artifacts_metadata"
,
limit:
65535
t
.
integer
"erased_by_id"
,
limit:
4
t
.
datetime
"erased_at"
t
.
datetime
"artifacts_expire_at"
t
.
string
"environment"
t
.
string
"environment"
,
limit:
255
t
.
integer
"artifacts_size"
,
limit:
8
t
.
string
"when"
t
.
text
"yaml_variables"
t
.
string
"when"
,
limit:
255
t
.
text
"yaml_variables"
,
limit:
65535
t
.
datetime
"queued_at"
t
.
string
"token"
t
.
integer
"lock_version"
t
.
string
"token"
,
limit:
255
t
.
integer
"lock_version"
,
limit:
4
end
add_index
"ci_builds"
,
[
"commit_id"
,
"stage_idx"
,
"created_at"
],
name:
"index_ci_builds_on_commit_id_and_stage_idx_and_created_at"
,
using: :btree
...
...
@@ -212,23 +248,23 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"ci_builds"
,
[
"token"
],
name:
"index_ci_builds_on_token"
,
unique:
true
,
using: :btree
create_table
"ci_commits"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
t
.
string
"ref"
t
.
string
"sha"
t
.
string
"before_sha"
t
.
text
"push_data"
t
.
integer
"project_id"
,
limit:
4
t
.
string
"ref"
,
limit:
255
t
.
string
"sha"
,
limit:
255
t
.
string
"before_sha"
,
limit:
255
t
.
text
"push_data"
,
limit:
65535
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
boolean
"tag"
,
default:
false
t
.
text
"yaml_errors"
t
.
text
"yaml_errors"
,
limit:
65535
t
.
datetime
"committed_at"
t
.
integer
"gl_project_id"
t
.
string
"status"
t
.
integer
"gl_project_id"
,
limit:
4
t
.
string
"status"
,
limit:
255
t
.
datetime
"started_at"
t
.
datetime
"finished_at"
t
.
integer
"duration"
t
.
integer
"user_id"
t
.
integer
"lock_version"
t
.
integer
"duration"
,
limit:
4
t
.
integer
"user_id"
,
limit:
4
t
.
integer
"lock_version"
,
limit:
4
end
add_index
"ci_commits"
,
[
"gl_project_id"
,
"sha"
],
name:
"index_ci_commits_on_gl_project_id_and_sha"
,
using: :btree
...
...
@@ -238,75 +274,75 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"ci_commits"
,
[
"user_id"
],
name:
"index_ci_commits_on_user_id"
,
using: :btree
create_table
"ci_events"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
t
.
integer
"user_id"
t
.
integer
"is_admin"
t
.
text
"description"
t
.
integer
"project_id"
,
limit:
4
t
.
integer
"user_id"
,
limit:
4
t
.
integer
"is_admin"
,
limit:
4
t
.
text
"description"
,
limit:
65535
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
create_table
"ci_jobs"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
null:
false
t
.
text
"commands"
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
text
"commands"
,
limit:
65535
t
.
boolean
"active"
,
default:
true
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"name"
t
.
string
"name"
,
limit:
255
t
.
boolean
"build_branches"
,
default:
true
,
null:
false
t
.
boolean
"build_tags"
,
default:
false
,
null:
false
t
.
string
"job_type"
,
default:
"parallel"
t
.
string
"refs"
t
.
string
"job_type"
,
limit:
255
,
default:
"parallel"
t
.
string
"refs"
,
limit:
255
t
.
datetime
"deleted_at"
end
create_table
"ci_projects"
,
force: :cascade
do
|
t
|
t
.
string
"name"
t
.
integer
"timeout"
,
default:
3600
,
null:
false
t
.
string
"name"
,
limit:
255
t
.
integer
"timeout"
,
limit:
4
,
default:
3600
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"token"
t
.
string
"default_ref"
t
.
string
"path"
t
.
string
"token"
,
limit:
255
t
.
string
"default_ref"
,
limit:
255
t
.
string
"path"
,
limit:
255
t
.
boolean
"always_build"
,
default:
false
,
null:
false
t
.
integer
"polling_interval"
t
.
integer
"polling_interval"
,
limit:
4
t
.
boolean
"public"
,
default:
false
,
null:
false
t
.
string
"ssh_url_to_repo"
t
.
integer
"gitlab_id"
t
.
string
"ssh_url_to_repo"
,
limit:
255
t
.
integer
"gitlab_id"
,
limit:
4
t
.
boolean
"allow_git_fetch"
,
default:
true
,
null:
false
t
.
string
"email_recipients"
,
default:
""
,
null:
false
t
.
string
"email_recipients"
,
limit:
255
,
default:
""
,
null:
false
t
.
boolean
"email_add_pusher"
,
default:
true
,
null:
false
t
.
boolean
"email_only_broken_builds"
,
default:
true
,
null:
false
t
.
string
"skip_refs"
t
.
string
"coverage_regex"
t
.
string
"skip_refs"
,
limit:
255
t
.
string
"coverage_regex"
,
limit:
255
t
.
boolean
"shared_runners_enabled"
,
default:
false
t
.
text
"generated_yaml_config"
t
.
text
"generated_yaml_config"
,
limit:
65535
end
create_table
"ci_runner_projects"
,
force: :cascade
do
|
t
|
t
.
integer
"runner_id"
,
null:
false
t
.
integer
"project_id"
t
.
integer
"runner_id"
,
limit:
4
,
null:
false
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"gl_project_id"
t
.
integer
"gl_project_id"
,
limit:
4
end
add_index
"ci_runner_projects"
,
[
"gl_project_id"
],
name:
"index_ci_runner_projects_on_gl_project_id"
,
using: :btree
add_index
"ci_runner_projects"
,
[
"runner_id"
],
name:
"index_ci_runner_projects_on_runner_id"
,
using: :btree
create_table
"ci_runners"
,
force: :cascade
do
|
t
|
t
.
string
"token"
t
.
string
"token"
,
limit:
255
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"description"
t
.
string
"description"
,
limit:
255
t
.
datetime
"contacted_at"
t
.
boolean
"active"
,
default:
true
,
null:
false
t
.
boolean
"is_shared"
,
default:
false
t
.
string
"name"
t
.
string
"version"
t
.
string
"revision"
t
.
string
"platform"
t
.
string
"architecture"
t
.
string
"name"
,
limit:
255
t
.
string
"version"
,
limit:
255
t
.
string
"revision"
,
limit:
255
t
.
string
"platform"
,
limit:
255
t
.
string
"architecture"
,
limit:
255
t
.
boolean
"run_untagged"
,
default:
true
,
null:
false
t
.
boolean
"locked"
,
default:
false
,
null:
false
end
...
...
@@ -315,18 +351,18 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"ci_runners"
,
[
"token"
],
name:
"index_ci_runners_on_token"
,
using: :btree
create_table
"ci_sessions"
,
force: :cascade
do
|
t
|
t
.
string
"session_id"
,
null:
false
t
.
text
"data"
t
.
string
"session_id"
,
limit:
255
,
null:
false
t
.
text
"data"
,
limit:
65535
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
create_table
"ci_taggings"
,
force: :cascade
do
|
t
|
t
.
integer
"tag_id"
t
.
integer
"taggable_id"
t
.
string
"taggable_type"
t
.
integer
"tagger_id"
t
.
string
"tagger_type"
t
.
integer
"tag_id"
,
limit:
4
t
.
integer
"taggable_id"
,
limit:
4
t
.
string
"taggable_type"
,
limit:
255
t
.
integer
"tagger_id"
,
limit:
4
t
.
string
"tagger_type"
,
limit:
255
t
.
string
"context"
,
limit:
128
t
.
datetime
"created_at"
end
...
...
@@ -334,44 +370,44 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"ci_taggings"
,
[
"taggable_id"
,
"taggable_type"
,
"context"
],
name:
"index_ci_taggings_on_taggable_id_and_taggable_type_and_context"
,
using: :btree
create_table
"ci_tags"
,
force: :cascade
do
|
t
|
t
.
string
"name"
t
.
integer
"taggings_count"
,
default:
0
t
.
string
"name"
,
limit:
255
t
.
integer
"taggings_count"
,
limit:
4
,
default:
0
end
create_table
"ci_trigger_requests"
,
force: :cascade
do
|
t
|
t
.
integer
"trigger_id"
,
null:
false
t
.
text
"variables"
t
.
integer
"trigger_id"
,
limit:
4
,
null:
false
t
.
text
"variables"
,
limit:
65535
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"commit_id"
t
.
integer
"commit_id"
,
limit:
4
end
create_table
"ci_triggers"
,
force: :cascade
do
|
t
|
t
.
string
"token"
t
.
integer
"project_id"
t
.
string
"token"
,
limit:
255
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"deleted_at"
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"gl_project_id"
t
.
integer
"gl_project_id"
,
limit:
4
end
add_index
"ci_triggers"
,
[
"gl_project_id"
],
name:
"index_ci_triggers_on_gl_project_id"
,
using: :btree
create_table
"ci_variables"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
t
.
string
"key"
t
.
text
"value"
t
.
text
"encrypted_value"
t
.
string
"encrypted_value_salt"
t
.
string
"encrypted_value_iv"
t
.
integer
"gl_project_id"
t
.
integer
"project_id"
,
limit:
4
t
.
string
"key"
,
limit:
255
t
.
text
"value"
,
limit:
65535
t
.
text
"encrypted_value"
,
limit:
65535
t
.
string
"encrypted_value_salt"
,
limit:
255
t
.
string
"encrypted_value_iv"
,
limit:
255
t
.
integer
"gl_project_id"
,
limit:
4
end
add_index
"ci_variables"
,
[
"gl_project_id"
],
name:
"index_ci_variables_on_gl_project_id"
,
using: :btree
create_table
"deploy_keys_projects"
,
force: :cascade
do
|
t
|
t
.
integer
"deploy_key_id"
,
null:
false
t
.
integer
"project_id"
,
null:
false
t
.
integer
"deploy_key_id"
,
limit:
4
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
...
...
@@ -379,18 +415,18 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"deploy_keys_projects"
,
[
"project_id"
],
name:
"index_deploy_keys_projects_on_project_id"
,
using: :btree
create_table
"deployments"
,
force: :cascade
do
|
t
|
t
.
integer
"iid"
,
null:
false
t
.
integer
"project_id"
,
null:
false
t
.
integer
"environment_id"
,
null:
false
t
.
string
"ref"
,
null:
false
t
.
integer
"iid"
,
limit:
4
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
integer
"environment_id"
,
limit:
4
,
null:
false
t
.
string
"ref"
,
limit:
255
,
null:
false
t
.
boolean
"tag"
,
null:
false
t
.
string
"sha"
,
null:
false
t
.
integer
"user_id"
t
.
integer
"deployable_id"
t
.
string
"deployable_type"
t
.
string
"sha"
,
limit:
255
,
null:
false
t
.
integer
"user_id"
,
limit:
4
t
.
integer
"deployable_id"
,
limit:
4
t
.
string
"deployable_type"
,
limit:
255
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"on_stop"
t
.
string
"on_stop"
,
limit:
255
end
add_index
"deployments"
,
[
"project_id"
,
"environment_id"
,
"iid"
],
name:
"index_deployments_on_project_id_and_environment_id_and_iid"
,
using: :btree
...
...
@@ -399,8 +435,8 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"deployments"
,
[
"project_id"
],
name:
"index_deployments_on_project_id"
,
using: :btree
create_table
"emails"
,
force: :cascade
do
|
t
|
t
.
integer
"user_id"
,
null:
false
t
.
string
"email"
,
null:
false
t
.
integer
"user_id"
,
limit:
4
,
null:
false
t
.
string
"email"
,
limit:
255
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
...
...
@@ -409,27 +445,27 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"emails"
,
[
"user_id"
],
name:
"index_emails_on_user_id"
,
using: :btree
create_table
"environments"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
t
.
string
"name"
,
null:
false
t
.
integer
"project_id"
,
limit:
4
t
.
string
"name"
,
limit:
255
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"external_url"
t
.
string
"environment_type"
t
.
string
"state"
,
default:
"available"
,
null:
false
t
.
string
"external_url"
,
limit:
255
t
.
string
"environment_type"
,
limit:
255
t
.
string
"state"
,
limit:
255
,
default:
"available"
,
null:
false
end
add_index
"environments"
,
[
"project_id"
,
"name"
],
name:
"index_environments_on_project_id_and_name"
,
using: :btree
create_table
"events"
,
force: :cascade
do
|
t
|
t
.
string
"target_type"
t
.
integer
"target_id"
t
.
string
"title"
t
.
text
"data"
t
.
integer
"project_id"
t
.
string
"target_type"
,
limit:
255
t
.
integer
"target_id"
,
limit:
4
t
.
string
"title"
,
limit:
255
t
.
text
"data"
,
limit:
4294967295
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"action"
t
.
integer
"author_id"
t
.
integer
"action"
,
limit:
4
t
.
integer
"author_id"
,
limit:
4
end
add_index
"events"
,
[
"action"
],
name:
"index_events_on_action"
,
using: :btree
...
...
@@ -440,26 +476,59 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"events"
,
[
"target_type"
],
name:
"index_events_on_target_type"
,
using: :btree
create_table
"forked_project_links"
,
force: :cascade
do
|
t
|
t
.
integer
"forked_to_project_id"
,
null:
false
t
.
integer
"forked_from_project_id"
,
null:
false
t
.
integer
"forked_to_project_id"
,
limit:
4
,
null:
false
t
.
integer
"forked_from_project_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
add_index
"forked_project_links"
,
[
"forked_to_project_id"
],
name:
"index_forked_project_links_on_forked_to_project_id"
,
unique:
true
,
using: :btree
create_table
"geo_nodes"
,
force: :cascade
do
|
t
|
t
.
string
"schema"
,
limit:
255
t
.
string
"host"
,
limit:
255
t
.
integer
"port"
,
limit:
4
t
.
string
"relative_url_root"
,
limit:
255
t
.
boolean
"primary"
t
.
integer
"geo_node_key_id"
,
limit:
4
t
.
integer
"oauth_application_id"
,
limit:
4
t
.
integer
"system_hook_id"
,
limit:
4
end
add_index
"geo_nodes"
,
[
"host"
],
name:
"index_geo_nodes_on_host"
,
using: :btree
add_index
"geo_nodes"
,
[
"primary"
],
name:
"index_geo_nodes_on_primary"
,
using: :btree
create_table
"historical_data"
,
force: :cascade
do
|
t
|
t
.
date
"date"
,
null:
false
t
.
integer
"active_user_count"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
create_table
"identities"
,
force: :cascade
do
|
t
|
t
.
string
"extern_uid"
t
.
string
"provider"
t
.
integer
"user_id"
t
.
string
"extern_uid"
,
limit:
255
t
.
string
"provider"
,
limit:
255
t
.
integer
"user_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"secondary_extern_uid"
,
limit:
255
end
add_index
"identities"
,
[
"user_id"
],
name:
"index_identities_on_user_id"
,
using: :btree
create_table
"index_statuses"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
datetime
"indexed_at"
t
.
text
"note"
,
limit:
65535
t
.
string
"last_commit"
,
limit:
255
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
end
add_index
"index_statuses"
,
[
"project_id"
],
name:
"index_index_statuses_on_project_id"
,
unique:
true
,
using: :btree
create_table
"issue_metrics"
,
force: :cascade
do
|
t
|
t
.
integer
"issue_id"
,
null:
false
t
.
integer
"issue_id"
,
limit:
4
,
null:
false
t
.
datetime
"first_mentioned_in_commit_at"
t
.
datetime
"first_associated_with_milestone_at"
t
.
datetime
"first_added_to_board_at"
...
...
@@ -470,26 +539,27 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"issue_metrics"
,
[
"issue_id"
],
name:
"index_issue_metrics"
,
using: :btree
create_table
"issues"
,
force: :cascade
do
|
t
|
t
.
string
"title"
t
.
integer
"assignee_id"
t
.
integer
"author_id"
t
.
integer
"project_id"
t
.
string
"title"
,
limit:
255
t
.
integer
"assignee_id"
,
limit:
4
t
.
integer
"author_id"
,
limit:
4
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"position"
,
default:
0
t
.
string
"branch_name"
t
.
text
"description"
t
.
integer
"milestone_id"
t
.
string
"state"
t
.
integer
"iid"
t
.
integer
"updated_by_id"
t
.
integer
"position"
,
limit:
4
,
default:
0
t
.
string
"branch_name"
,
limit:
255
t
.
text
"description"
,
limit:
65535
t
.
integer
"milestone_id"
,
limit:
4
t
.
string
"state"
,
limit:
255
t
.
integer
"iid"
,
limit:
4
t
.
integer
"updated_by_id"
,
limit:
4
t
.
integer
"weight"
,
limit:
4
t
.
boolean
"confidential"
,
default:
false
t
.
datetime
"deleted_at"
t
.
date
"due_date"
t
.
integer
"moved_to_id"
t
.
integer
"lock_version"
t
.
text
"title_html"
t
.
text
"description_html"
t
.
integer
"moved_to_id"
,
limit:
4
t
.
integer
"lock_version"
,
limit:
4
t
.
text
"title_html"
,
limit:
65535
t
.
text
"description_html"
,
limit:
65535
end
add_index
"issues"
,
[
"assignee_id"
],
name:
"index_issues_on_assignee_id"
,
using: :btree
...
...
@@ -497,21 +567,19 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"issues"
,
[
"confidential"
],
name:
"index_issues_on_confidential"
,
using: :btree
add_index
"issues"
,
[
"created_at"
],
name:
"index_issues_on_created_at"
,
using: :btree
add_index
"issues"
,
[
"deleted_at"
],
name:
"index_issues_on_deleted_at"
,
using: :btree
add_index
"issues"
,
[
"description"
],
name:
"index_issues_on_description_trigram"
,
using: :gin
,
opclasses:
{
"description"
=>
"gin_trgm_ops"
}
add_index
"issues"
,
[
"due_date"
],
name:
"index_issues_on_due_date"
,
using: :btree
add_index
"issues"
,
[
"milestone_id"
],
name:
"index_issues_on_milestone_id"
,
using: :btree
add_index
"issues"
,
[
"project_id"
,
"iid"
],
name:
"index_issues_on_project_id_and_iid"
,
unique:
true
,
using: :btree
add_index
"issues"
,
[
"state"
],
name:
"index_issues_on_state"
,
using: :btree
add_index
"issues"
,
[
"title"
],
name:
"index_issues_on_title_trigram"
,
using: :gin
,
opclasses:
{
"title"
=>
"gin_trgm_ops"
}
create_table
"keys"
,
force: :cascade
do
|
t
|
t
.
integer
"user_id"
t
.
integer
"user_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
text
"key"
t
.
string
"title"
t
.
string
"type"
t
.
string
"fingerprint"
t
.
text
"key"
,
limit:
65535
t
.
string
"title"
,
limit:
255
t
.
string
"type"
,
limit:
255
t
.
string
"fingerprint"
,
limit:
255
t
.
boolean
"public"
,
default:
false
,
null:
false
end
...
...
@@ -519,9 +587,9 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"keys"
,
[
"user_id"
],
name:
"index_keys_on_user_id"
,
using: :btree
create_table
"label_links"
,
force: :cascade
do
|
t
|
t
.
integer
"label_id"
t
.
integer
"target_id"
t
.
string
"target_type"
t
.
integer
"label_id"
,
limit:
4
t
.
integer
"target_id"
,
limit:
4
t
.
string
"target_type"
,
limit:
255
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
...
...
@@ -530,56 +598,72 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"label_links"
,
[
"target_id"
,
"target_type"
],
name:
"index_label_links_on_target_id_and_target_type"
,
using: :btree
create_table
"label_priorities"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
null:
false
t
.
integer
"label_id"
,
null:
false
t
.
integer
"priority"
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
integer
"label_id"
,
limit:
4
,
null:
false
t
.
integer
"priority"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
end
add_index
"label_priorities"
,
[
"label_id"
],
name:
"fk_rails_e161058b0f"
,
using: :btree
add_index
"label_priorities"
,
[
"priority"
],
name:
"index_label_priorities_on_priority"
,
using: :btree
add_index
"label_priorities"
,
[
"project_id"
,
"label_id"
],
name:
"index_label_priorities_on_project_id_and_label_id"
,
unique:
true
,
using: :btree
create_table
"labels"
,
force: :cascade
do
|
t
|
t
.
string
"title"
t
.
string
"color"
t
.
integer
"project_id"
t
.
string
"title"
,
limit:
255
t
.
string
"color"
,
limit:
255
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
boolean
"template"
,
default:
false
t
.
string
"description"
t
.
text
"description_html"
t
.
string
"type"
t
.
integer
"group_id"
t
.
string
"description"
,
limit:
255
t
.
text
"description_html"
,
limit:
65535
t
.
string
"type"
,
limit:
255
t
.
integer
"group_id"
,
limit:
4
end
add_index
"labels"
,
[
"group_id"
,
"project_id"
,
"title"
],
name:
"index_labels_on_group_id_and_project_id_and_title"
,
unique:
true
,
using: :btree
add_index
"labels"
,
[
"group_id"
],
name:
"index_labels_on_group_id"
,
using: :btree
create_table
"ldap_group_links"
,
force: :cascade
do
|
t
|
t
.
string
"cn"
,
limit:
255
,
null:
false
t
.
integer
"group_access"
,
limit:
4
,
null:
false
t
.
integer
"group_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"provider"
,
limit:
255
end
create_table
"lfs_objects"
,
force: :cascade
do
|
t
|
t
.
string
"oid"
,
null:
false
t
.
string
"oid"
,
limit:
255
,
null:
false
t
.
integer
"size"
,
limit:
8
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"file"
t
.
string
"file"
,
limit:
255
end
add_index
"lfs_objects"
,
[
"oid"
],
name:
"index_lfs_objects_on_oid"
,
unique:
true
,
using: :btree
create_table
"lfs_objects_projects"
,
force: :cascade
do
|
t
|
t
.
integer
"lfs_object_id"
,
null:
false
t
.
integer
"project_id"
,
null:
false
t
.
integer
"lfs_object_id"
,
limit:
4
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
add_index
"lfs_objects_projects"
,
[
"project_id"
],
name:
"index_lfs_objects_projects_on_project_id"
,
using: :btree
create_table
"licenses"
,
force: :cascade
do
|
t
|
t
.
text
"data"
,
limit:
65535
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
create_table
"lists"
,
force: :cascade
do
|
t
|
t
.
integer
"board_id"
,
null:
false
t
.
integer
"label_id"
t
.
integer
"list_type"
,
default:
1
,
null:
false
t
.
integer
"position"
t
.
integer
"board_id"
,
limit:
4
,
null:
false
t
.
integer
"label_id"
,
limit:
4
t
.
integer
"list_type"
,
limit:
4
,
default:
1
,
null:
false
t
.
integer
"position"
,
limit:
4
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
end
...
...
@@ -589,20 +673,22 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"lists"
,
[
"label_id"
],
name:
"index_lists_on_label_id"
,
using: :btree
create_table
"members"
,
force: :cascade
do
|
t
|
t
.
integer
"access_level"
,
null:
false
t
.
integer
"source_id"
,
null:
false
t
.
string
"source_type"
,
null:
false
t
.
integer
"user_id"
t
.
integer
"notification_level"
,
null:
false
t
.
string
"type"
t
.
integer
"access_level"
,
limit:
4
,
null:
false
t
.
integer
"source_id"
,
limit:
4
,
null:
false
t
.
string
"source_type"
,
limit:
255
,
null:
false
t
.
integer
"user_id"
,
limit:
4
t
.
integer
"notification_level"
,
limit:
4
,
null:
false
t
.
string
"type"
,
limit:
255
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"created_by_id"
t
.
string
"invite_email"
t
.
string
"invite_token"
t
.
integer
"created_by_id"
,
limit:
4
t
.
string
"invite_email"
,
limit:
255
t
.
string
"invite_token"
,
limit:
255
t
.
datetime
"invite_accepted_at"
t
.
datetime
"requested_at"
t
.
date
"expires_at"
t
.
boolean
"ldap"
,
default:
false
,
null:
false
t
.
boolean
"override"
,
default:
false
,
null:
false
end
add_index
"members"
,
[
"access_level"
],
name:
"index_members_on_access_level"
,
using: :btree
...
...
@@ -612,29 +698,29 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"members"
,
[
"user_id"
],
name:
"index_members_on_user_id"
,
using: :btree
create_table
"merge_request_diffs"
,
force: :cascade
do
|
t
|
t
.
string
"state"
t
.
text
"st_commits"
t
.
text
"st_diffs"
t
.
integer
"merge_request_id"
,
null:
false
t
.
string
"state"
,
limit:
255
t
.
text
"st_commits"
,
limit:
4294967295
t
.
text
"st_diffs"
,
limit:
4294967295
t
.
integer
"merge_request_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"base_commit_sha"
t
.
string
"real_size"
t
.
string
"head_commit_sha"
t
.
string
"start_commit_sha"
t
.
string
"base_commit_sha"
,
limit:
255
t
.
string
"real_size"
,
limit:
255
t
.
string
"head_commit_sha"
,
limit:
255
t
.
string
"start_commit_sha"
,
limit:
255
end
add_index
"merge_request_diffs"
,
[
"merge_request_id"
],
name:
"index_merge_request_diffs_on_merge_request_id"
,
using: :btree
create_table
"merge_request_metrics"
,
force: :cascade
do
|
t
|
t
.
integer
"merge_request_id"
,
null:
false
t
.
integer
"merge_request_id"
,
limit:
4
,
null:
false
t
.
datetime
"latest_build_started_at"
t
.
datetime
"latest_build_finished_at"
t
.
datetime
"first_deployed_to_production_at"
t
.
datetime
"merged_at"
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
integer
"pipeline_id"
t
.
integer
"pipeline_id"
,
limit:
4
end
add_index
"merge_request_metrics"
,
[
"first_deployed_to_production_at"
],
name:
"index_merge_request_metrics_on_first_deployed_to_production_at"
,
using: :btree
...
...
@@ -642,51 +728,51 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"merge_request_metrics"
,
[
"pipeline_id"
],
name:
"index_merge_request_metrics_on_pipeline_id"
,
using: :btree
create_table
"merge_requests"
,
force: :cascade
do
|
t
|
t
.
string
"target_branch"
,
null:
false
t
.
string
"source_branch"
,
null:
false
t
.
integer
"source_project_id"
,
null:
false
t
.
integer
"author_id"
t
.
integer
"assignee_id"
t
.
string
"title"
t
.
string
"target_branch"
,
limit:
255
,
null:
false
t
.
string
"source_branch"
,
limit:
255
,
null:
false
t
.
integer
"source_project_id"
,
limit:
4
,
null:
false
t
.
integer
"author_id"
,
limit:
4
t
.
integer
"assignee_id"
,
limit:
4
t
.
string
"title"
,
limit:
255
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"milestone_id"
t
.
string
"state"
t
.
string
"merge_status"
t
.
integer
"target_project_id"
,
null:
false
t
.
integer
"iid"
t
.
text
"description"
t
.
integer
"position"
,
default:
0
t
.
integer
"milestone_id"
,
limit:
4
t
.
string
"state"
,
limit:
255
t
.
string
"merge_status"
,
limit:
255
t
.
integer
"target_project_id"
,
limit:
4
,
null:
false
t
.
integer
"iid"
,
limit:
4
t
.
text
"description"
,
limit:
65535
t
.
integer
"position"
,
limit:
4
,
default:
0
t
.
datetime
"locked_at"
t
.
integer
"updated_by_id"
t
.
text
"merge_error"
t
.
text
"merge_params"
t
.
integer
"updated_by_id"
,
limit:
4
t
.
text
"merge_error"
,
limit:
65535
t
.
text
"merge_params"
,
limit:
65535
t
.
boolean
"merge_when_build_succeeds"
,
default:
false
,
null:
false
t
.
integer
"merge_user_id"
t
.
string
"merge_commit_sha"
t
.
integer
"merge_user_id"
,
limit:
4
t
.
string
"merge_commit_sha"
,
limit:
255
t
.
datetime
"deleted_at"
t
.
string
"in_progress_merge_commit_sha"
t
.
integer
"lock_version"
t
.
text
"title_html"
t
.
text
"description_html"
t
.
integer
"approvals_before_merge"
,
limit:
4
t
.
string
"rebase_commit_sha"
,
limit:
255
t
.
string
"in_progress_merge_commit_sha"
,
limit:
255
t
.
integer
"lock_version"
,
limit:
4
t
.
text
"title_html"
,
limit:
65535
t
.
text
"description_html"
,
limit:
65535
end
add_index
"merge_requests"
,
[
"assignee_id"
],
name:
"index_merge_requests_on_assignee_id"
,
using: :btree
add_index
"merge_requests"
,
[
"author_id"
],
name:
"index_merge_requests_on_author_id"
,
using: :btree
add_index
"merge_requests"
,
[
"created_at"
],
name:
"index_merge_requests_on_created_at"
,
using: :btree
add_index
"merge_requests"
,
[
"deleted_at"
],
name:
"index_merge_requests_on_deleted_at"
,
using: :btree
add_index
"merge_requests"
,
[
"description"
],
name:
"index_merge_requests_on_description_trigram"
,
using: :gin
,
opclasses:
{
"description"
=>
"gin_trgm_ops"
}
add_index
"merge_requests"
,
[
"milestone_id"
],
name:
"index_merge_requests_on_milestone_id"
,
using: :btree
add_index
"merge_requests"
,
[
"source_branch"
],
name:
"index_merge_requests_on_source_branch"
,
using: :btree
add_index
"merge_requests"
,
[
"source_project_id"
],
name:
"index_merge_requests_on_source_project_id"
,
using: :btree
add_index
"merge_requests"
,
[
"target_branch"
],
name:
"index_merge_requests_on_target_branch"
,
using: :btree
add_index
"merge_requests"
,
[
"target_project_id"
,
"iid"
],
name:
"index_merge_requests_on_target_project_id_and_iid"
,
unique:
true
,
using: :btree
add_index
"merge_requests"
,
[
"title"
],
name:
"index_merge_requests_on_title"
,
using: :btree
add_index
"merge_requests"
,
[
"title"
],
name:
"index_merge_requests_on_title_trigram"
,
using: :gin
,
opclasses:
{
"title"
=>
"gin_trgm_ops"
}
create_table
"merge_requests_closing_issues"
,
force: :cascade
do
|
t
|
t
.
integer
"merge_request_id"
,
null:
false
t
.
integer
"issue_id"
,
null:
false
t
.
integer
"merge_request_id"
,
limit:
4
,
null:
false
t
.
integer
"issue_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
end
...
...
@@ -695,73 +781,78 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"merge_requests_closing_issues"
,
[
"merge_request_id"
],
name:
"index_merge_requests_closing_issues_on_merge_request_id"
,
using: :btree
create_table
"milestones"
,
force: :cascade
do
|
t
|
t
.
string
"title"
,
null:
false
t
.
integer
"project_id"
,
null:
false
t
.
text
"description"
t
.
string
"title"
,
limit:
255
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
text
"description"
,
limit:
65535
t
.
date
"due_date"
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"state"
t
.
integer
"iid"
t
.
text
"title_html"
t
.
text
"description_html"
t
.
string
"state"
,
limit:
255
t
.
integer
"iid"
,
limit:
4
t
.
text
"title_html"
,
limit:
65535
t
.
text
"description_html"
,
limit:
65535
end
add_index
"milestones"
,
[
"description"
],
name:
"index_milestones_on_description_trigram"
,
using: :gin
,
opclasses:
{
"description"
=>
"gin_trgm_ops"
}
add_index
"milestones"
,
[
"due_date"
],
name:
"index_milestones_on_due_date"
,
using: :btree
add_index
"milestones"
,
[
"project_id"
,
"iid"
],
name:
"index_milestones_on_project_id_and_iid"
,
unique:
true
,
using: :btree
add_index
"milestones"
,
[
"project_id"
],
name:
"index_milestones_on_project_id"
,
using: :btree
add_index
"milestones"
,
[
"title"
],
name:
"index_milestones_on_title"
,
using: :btree
add_index
"milestones"
,
[
"title"
],
name:
"index_milestones_on_title_trigram"
,
using: :gin
,
opclasses:
{
"title"
=>
"gin_trgm_ops"
}
create_table
"namespaces"
,
force: :cascade
do
|
t
|
t
.
string
"name"
,
null:
false
t
.
string
"path"
,
null:
false
t
.
integer
"owner_id"
t
.
string
"name"
,
limit:
255
,
null:
false
t
.
string
"path"
,
limit:
255
,
null:
false
t
.
integer
"owner_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"type"
t
.
string
"description"
,
default:
""
,
null:
false
t
.
string
"avatar"
t
.
string
"type"
,
limit:
255
t
.
string
"description"
,
limit:
255
,
default:
""
,
null:
false
t
.
string
"avatar"
,
limit:
255
t
.
boolean
"membership_lock"
,
default:
false
t
.
boolean
"share_with_group_lock"
,
default:
false
t
.
integer
"visibility_level"
,
default:
20
,
null:
false
t
.
integer
"visibility_level"
,
limit:
4
,
default:
20
,
null:
false
t
.
boolean
"request_access_enabled"
,
default:
false
,
null:
false
t
.
datetime
"deleted_at"
t
.
string
"ldap_sync_status"
,
limit:
255
,
default:
"ready"
,
null:
false
t
.
string
"ldap_sync_error"
,
limit:
255
t
.
datetime
"ldap_sync_last_update_at"
t
.
datetime
"ldap_sync_last_successful_update_at"
t
.
datetime
"ldap_sync_last_sync_at"
t
.
boolean
"lfs_enabled"
t
.
text
"description_html"
t
.
integer
"repository_size_limit"
,
limit:
4
t
.
text
"description_html"
,
limit:
65535
end
add_index
"namespaces"
,
[
"created_at"
],
name:
"index_namespaces_on_created_at"
,
using: :btree
add_index
"namespaces"
,
[
"deleted_at"
],
name:
"index_namespaces_on_deleted_at"
,
using: :btree
add_index
"namespaces"
,
[
"ldap_sync_last_successful_update_at"
],
name:
"index_namespaces_on_ldap_sync_last_successful_update_at"
,
using: :btree
add_index
"namespaces"
,
[
"ldap_sync_last_update_at"
],
name:
"index_namespaces_on_ldap_sync_last_update_at"
,
using: :btree
add_index
"namespaces"
,
[
"name"
],
name:
"index_namespaces_on_name"
,
unique:
true
,
using: :btree
add_index
"namespaces"
,
[
"name"
],
name:
"index_namespaces_on_name_trigram"
,
using: :gin
,
opclasses:
{
"name"
=>
"gin_trgm_ops"
}
add_index
"namespaces"
,
[
"owner_id"
],
name:
"index_namespaces_on_owner_id"
,
using: :btree
add_index
"namespaces"
,
[
"path"
],
name:
"index_namespaces_on_path"
,
unique:
true
,
using: :btree
add_index
"namespaces"
,
[
"path"
],
name:
"index_namespaces_on_path_trigram"
,
using: :gin
,
opclasses:
{
"path"
=>
"gin_trgm_ops"
}
add_index
"namespaces"
,
[
"type"
],
name:
"index_namespaces_on_type"
,
using: :btree
create_table
"notes"
,
force: :cascade
do
|
t
|
t
.
text
"note"
t
.
string
"noteable_type"
t
.
integer
"author_id"
t
.
text
"note"
,
limit:
65535
t
.
string
"noteable_type"
,
limit:
255
t
.
integer
"author_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"project_id"
t
.
string
"attachment"
t
.
string
"line_code"
t
.
string
"commit_id"
t
.
integer
"noteable_id"
t
.
integer
"project_id"
,
limit:
4
t
.
string
"attachment"
,
limit:
255
t
.
string
"line_code"
,
limit:
255
t
.
string
"commit_id"
,
limit:
255
t
.
integer
"noteable_id"
,
limit:
4
t
.
boolean
"system"
,
default:
false
,
null:
false
t
.
text
"st_diff"
t
.
integer
"updated_by_id"
t
.
string
"type"
t
.
text
"position"
t
.
text
"original_position"
t
.
text
"st_diff"
,
limit:
4294967295
t
.
integer
"updated_by_id"
,
limit:
4
t
.
string
"type"
,
limit:
255
t
.
text
"position"
,
limit:
65535
t
.
text
"original_position"
,
limit:
65535
t
.
datetime
"resolved_at"
t
.
integer
"resolved_by_id"
t
.
string
"discussion_id"
t
.
string
"original_discussion_id"
t
.
text
"note_html"
t
.
integer
"resolved_by_id"
,
limit:
4
t
.
string
"discussion_id"
,
limit:
255
t
.
string
"original_discussion_id"
,
limit:
255
t
.
text
"note_html"
,
limit:
65535
end
add_index
"notes"
,
[
"author_id"
],
name:
"index_notes_on_author_id"
,
using: :btree
...
...
@@ -769,7 +860,6 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"notes"
,
[
"created_at"
],
name:
"index_notes_on_created_at"
,
using: :btree
add_index
"notes"
,
[
"discussion_id"
],
name:
"index_notes_on_discussion_id"
,
using: :btree
add_index
"notes"
,
[
"line_code"
],
name:
"index_notes_on_line_code"
,
using: :btree
add_index
"notes"
,
[
"note"
],
name:
"index_notes_on_note_trigram"
,
using: :gin
,
opclasses:
{
"note"
=>
"gin_trgm_ops"
}
add_index
"notes"
,
[
"noteable_id"
,
"noteable_type"
],
name:
"index_notes_on_noteable_id_and_noteable_type"
,
using: :btree
add_index
"notes"
,
[
"noteable_type"
],
name:
"index_notes_on_noteable_type"
,
using: :btree
add_index
"notes"
,
[
"project_id"
,
"noteable_type"
],
name:
"index_notes_on_project_id_and_noteable_type"
,
using: :btree
...
...
@@ -777,13 +867,13 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"notes"
,
[
"updated_at"
],
name:
"index_notes_on_updated_at"
,
using: :btree
create_table
"notification_settings"
,
force: :cascade
do
|
t
|
t
.
integer
"user_id"
,
null:
false
t
.
integer
"source_id"
t
.
string
"source_type"
t
.
integer
"level"
,
default:
0
,
null:
false
t
.
integer
"user_id"
,
limit:
4
,
null:
false
t
.
integer
"source_id"
,
limit:
4
t
.
string
"source_type"
,
limit:
255
t
.
integer
"level"
,
limit:
4
,
default:
0
,
null:
false
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
text
"events"
t
.
text
"events"
,
limit:
65535
end
add_index
"notification_settings"
,
[
"source_id"
,
"source_type"
],
name:
"index_notification_settings_on_source_id_and_source_type"
,
using: :btree
...
...
@@ -791,27 +881,27 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"notification_settings"
,
[
"user_id"
],
name:
"index_notification_settings_on_user_id"
,
using: :btree
create_table
"oauth_access_grants"
,
force: :cascade
do
|
t
|
t
.
integer
"resource_owner_id"
,
null:
false
t
.
integer
"application_id"
,
null:
false
t
.
string
"token"
,
null:
false
t
.
integer
"expires_in"
,
null:
false
t
.
text
"redirect_uri"
,
null:
false
t
.
integer
"resource_owner_id"
,
limit:
4
,
null:
false
t
.
integer
"application_id"
,
limit:
4
,
null:
false
t
.
string
"token"
,
limit:
255
,
null:
false
t
.
integer
"expires_in"
,
limit:
4
,
null:
false
t
.
text
"redirect_uri"
,
limit:
65535
,
null:
false
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"revoked_at"
t
.
string
"scopes"
t
.
string
"scopes"
,
limit:
255
end
add_index
"oauth_access_grants"
,
[
"token"
],
name:
"index_oauth_access_grants_on_token"
,
unique:
true
,
using: :btree
create_table
"oauth_access_tokens"
,
force: :cascade
do
|
t
|
t
.
integer
"resource_owner_id"
t
.
integer
"application_id"
t
.
string
"token"
,
null:
false
t
.
string
"refresh_token"
t
.
integer
"expires_in"
t
.
integer
"resource_owner_id"
,
limit:
4
t
.
integer
"application_id"
,
limit:
4
t
.
string
"token"
,
limit:
255
,
null:
false
t
.
string
"refresh_token"
,
limit:
255
t
.
integer
"expires_in"
,
limit:
4
t
.
datetime
"revoked_at"
t
.
datetime
"created_at"
,
null:
false
t
.
string
"scopes"
t
.
string
"scopes"
,
limit:
255
end
add_index
"oauth_access_tokens"
,
[
"refresh_token"
],
name:
"index_oauth_access_tokens_on_refresh_token"
,
unique:
true
,
using: :btree
...
...
@@ -819,24 +909,47 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"oauth_access_tokens"
,
[
"token"
],
name:
"index_oauth_access_tokens_on_token"
,
unique:
true
,
using: :btree
create_table
"oauth_applications"
,
force: :cascade
do
|
t
|
t
.
string
"name"
,
null:
false
t
.
string
"uid"
,
null:
false
t
.
string
"secret"
,
null:
false
t
.
text
"redirect_uri"
,
null:
false
t
.
string
"scopes"
,
default:
""
,
null:
false
t
.
string
"name"
,
limit:
255
,
null:
false
t
.
string
"uid"
,
limit:
255
,
null:
false
t
.
string
"secret"
,
limit:
255
,
null:
false
t
.
text
"redirect_uri"
,
limit:
65535
,
null:
false
t
.
string
"scopes"
,
limit:
255
,
default:
""
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"owner_id"
t
.
string
"owner_type"
t
.
integer
"owner_id"
,
limit:
4
t
.
string
"owner_type"
,
limit:
255
end
add_index
"oauth_applications"
,
[
"owner_id"
,
"owner_type"
],
name:
"index_oauth_applications_on_owner_id_and_owner_type"
,
using: :btree
add_index
"oauth_applications"
,
[
"uid"
],
name:
"index_oauth_applications_on_uid"
,
unique:
true
,
using: :btree
create_table
"pages_domains"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
limit:
4
t
.
text
"certificate"
,
limit:
65535
t
.
text
"encrypted_key"
,
limit:
65535
t
.
string
"encrypted_key_iv"
,
limit:
255
t
.
string
"encrypted_key_salt"
,
limit:
255
t
.
string
"domain"
,
limit:
255
end
add_index
"pages_domains"
,
[
"domain"
],
name:
"index_pages_domains_on_domain"
,
unique:
true
,
using: :btree
create_table
"path_locks"
,
force: :cascade
do
|
t
|
t
.
string
"path"
,
limit:
255
,
null:
false
t
.
integer
"project_id"
,
limit:
4
t
.
integer
"user_id"
,
limit:
4
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
end
add_index
"path_locks"
,
[
"path"
],
name:
"index_path_locks_on_path"
,
using: :btree
add_index
"path_locks"
,
[
"project_id"
],
name:
"index_path_locks_on_project_id"
,
using: :btree
add_index
"path_locks"
,
[
"user_id"
],
name:
"index_path_locks_on_user_id"
,
using: :btree
create_table
"personal_access_tokens"
,
force: :cascade
do
|
t
|
t
.
integer
"user_id"
,
null:
false
t
.
string
"token"
,
null:
false
t
.
string
"name"
,
null:
false
t
.
integer
"user_id"
,
limit:
4
,
null:
false
t
.
string
"token"
,
limit:
255
,
null:
false
t
.
string
"name"
,
limit:
255
,
null:
false
t
.
boolean
"revoked"
,
default:
false
t
.
datetime
"expires_at"
t
.
datetime
"created_at"
,
null:
false
...
...
@@ -847,64 +960,75 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"personal_access_tokens"
,
[
"user_id"
],
name:
"index_personal_access_tokens_on_user_id"
,
using: :btree
create_table
"project_features"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
t
.
integer
"merge_requests_access_level"
t
.
integer
"issues_access_level"
t
.
integer
"wiki_access_level"
t
.
integer
"snippets_access_level"
t
.
integer
"builds_access_level"
t
.
integer
"project_id"
,
limit:
4
t
.
integer
"merge_requests_access_level"
,
limit:
4
t
.
integer
"issues_access_level"
,
limit:
4
t
.
integer
"wiki_access_level"
,
limit:
4
t
.
integer
"snippets_access_level"
,
limit:
4
t
.
integer
"builds_access_level"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"repository_access_level"
,
default:
20
,
null:
false
t
.
integer
"repository_access_level"
,
limit:
4
,
default:
20
,
null:
false
end
add_index
"project_features"
,
[
"project_id"
],
name:
"index_project_features_on_project_id"
,
using: :btree
create_table
"project_group_links"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
null:
false
t
.
integer
"group_id"
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
integer
"group_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"group_access"
,
default:
30
,
null:
false
t
.
integer
"group_access"
,
limit:
4
,
default:
30
,
null:
false
t
.
date
"expires_at"
end
create_table
"project_import_data"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
t
.
text
"data"
t
.
text
"encrypted_credentials"
t
.
string
"encrypted_credentials_iv"
t
.
string
"encrypted_credentials_salt"
t
.
integer
"project_id"
,
limit:
4
t
.
text
"data"
,
limit:
65535
t
.
text
"encrypted_credentials"
,
limit:
65535
t
.
string
"encrypted_credentials_iv"
,
limit:
255
t
.
string
"encrypted_credentials_salt"
,
limit:
255
end
add_index
"project_import_data"
,
[
"project_id"
],
name:
"index_project_import_data_on_project_id"
,
using: :btree
create_table
"projects"
,
force: :cascade
do
|
t
|
t
.
string
"name"
t
.
string
"path"
t
.
text
"description"
t
.
string
"name"
,
limit:
255
t
.
string
"path"
,
limit:
255
t
.
text
"description"
,
limit:
65535
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"creator_id"
t
.
integer
"namespace_id"
t
.
integer
"creator_id"
,
limit:
4
t
.
integer
"namespace_id"
,
limit:
4
t
.
datetime
"last_activity_at"
t
.
string
"import_url"
t
.
integer
"visibility_level"
,
default:
0
,
null:
false
t
.
string
"import_url"
,
limit:
255
t
.
integer
"visibility_level"
,
limit:
4
,
default:
0
,
null:
false
t
.
boolean
"archived"
,
default:
false
,
null:
false
t
.
string
"avatar"
t
.
string
"import_status"
t
.
float
"repository_size"
,
default:
0.0
t
.
integer
"star_count"
,
default:
0
,
null:
false
t
.
string
"import_type"
t
.
string
"import_source"
t
.
integer
"commit_count"
,
default:
0
t
.
text
"import_error"
t
.
integer
"ci_id"
t
.
string
"avatar"
,
limit:
255
t
.
string
"import_status"
,
limit:
255
t
.
float
"repository_size"
,
limit:
24
,
default:
0.0
t
.
text
"merge_requests_template"
,
limit:
65535
t
.
integer
"star_count"
,
limit:
4
,
default:
0
,
null:
false
t
.
boolean
"merge_requests_rebase_enabled"
,
default:
false
t
.
string
"import_type"
,
limit:
255
t
.
string
"import_source"
,
limit:
255
t
.
integer
"approvals_before_merge"
,
limit:
4
,
default:
0
,
null:
false
t
.
boolean
"reset_approvals_on_push"
,
default:
true
t
.
integer
"commit_count"
,
limit:
4
,
default:
0
t
.
boolean
"merge_requests_ff_only_enabled"
,
default:
false
t
.
text
"issues_template"
,
limit:
65535
t
.
boolean
"mirror"
,
default:
false
,
null:
false
t
.
datetime
"mirror_last_update_at"
t
.
datetime
"mirror_last_successful_update_at"
t
.
integer
"mirror_user_id"
,
limit:
4
t
.
text
"import_error"
,
limit:
65535
t
.
integer
"ci_id"
,
limit:
4
t
.
boolean
"shared_runners_enabled"
,
default:
true
,
null:
false
t
.
string
"runners_token"
t
.
string
"build_coverage_regex"
t
.
string
"runners_token"
,
limit:
255
t
.
string
"build_coverage_regex"
,
limit:
255
t
.
boolean
"build_allow_git_fetch"
,
default:
true
,
null:
false
t
.
integer
"build_timeout"
,
default:
3600
,
null:
false
t
.
integer
"build_timeout"
,
limit:
4
,
default:
3600
,
null:
false
t
.
boolean
"mirror_trigger_builds"
,
default:
false
,
null:
false
t
.
boolean
"pending_delete"
,
default:
false
t
.
boolean
"public_builds"
,
default:
true
,
null:
false
t
.
boolean
"last_repository_check_failed"
...
...
@@ -912,90 +1036,132 @@ ActiveRecord::Schema.define(version: 20161109150329) do
t
.
boolean
"container_registry_enabled"
t
.
boolean
"only_allow_merge_if_build_succeeds"
,
default:
false
,
null:
false
t
.
boolean
"has_external_issue_tracker"
t
.
string
"repository_storage"
,
default:
"default"
,
null:
false
t
.
string
"repository_storage"
,
limit:
255
,
default:
"default"
,
null:
false
t
.
boolean
"request_access_enabled"
,
default:
false
,
null:
false
t
.
boolean
"has_external_wiki"
t
.
boolean
"repository_read_only"
t
.
boolean
"lfs_enabled"
t
.
text
"description_html"
t
.
boolean
"only_allow_merge_if_all_discussions_are_resolved"
t
.
integer
"repository_size_limit"
,
limit:
4
t
.
text
"description_html"
,
limit:
65535
t
.
boolean
"only_allow_merge_if_all_discussions_are_resolved"
,
default:
false
,
null:
false
end
add_index
"projects"
,
[
"ci_id"
],
name:
"index_projects_on_ci_id"
,
using: :btree
add_index
"projects"
,
[
"created_at"
],
name:
"index_projects_on_created_at"
,
using: :btree
add_index
"projects"
,
[
"creator_id"
],
name:
"index_projects_on_creator_id"
,
using: :btree
add_index
"projects"
,
[
"description"
],
name:
"index_projects_on_description_trigram"
,
using: :gin
,
opclasses:
{
"description"
=>
"gin_trgm_ops"
}
add_index
"projects"
,
[
"last_activity_at"
],
name:
"index_projects_on_last_activity_at"
,
using: :btree
add_index
"projects"
,
[
"last_repository_check_failed"
],
name:
"index_projects_on_last_repository_check_failed"
,
using: :btree
add_index
"projects"
,
[
"name"
],
name:
"index_projects_on_name_trigram"
,
using: :gin
,
opclasses:
{
"name"
=>
"gin_trgm_ops"
}
add_index
"projects"
,
[
"namespace_id"
],
name:
"index_projects_on_namespace_id"
,
using: :btree
add_index
"projects"
,
[
"path"
],
name:
"index_projects_on_path"
,
using: :btree
add_index
"projects"
,
[
"path"
],
name:
"index_projects_on_path_trigram"
,
using: :gin
,
opclasses:
{
"path"
=>
"gin_trgm_ops"
}
add_index
"projects"
,
[
"pending_delete"
],
name:
"index_projects_on_pending_delete"
,
using: :btree
add_index
"projects"
,
[
"runners_token"
],
name:
"index_projects_on_runners_token"
,
using: :btree
add_index
"projects"
,
[
"star_count"
],
name:
"index_projects_on_star_count"
,
using: :btree
add_index
"projects"
,
[
"visibility_level"
],
name:
"index_projects_on_visibility_level"
,
using: :btree
create_table
"protected_branch_merge_access_levels"
,
force: :cascade
do
|
t
|
t
.
integer
"protected_branch_id"
,
null:
false
t
.
integer
"access_level"
,
default:
40
,
null:
false
t
.
integer
"protected_branch_id"
,
limit:
4
,
null:
false
t
.
integer
"access_level"
,
limit:
4
,
default:
40
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
integer
"user_id"
,
limit:
4
t
.
integer
"group_id"
,
limit:
4
end
add_index
"protected_branch_merge_access_levels"
,
[
"group_id"
],
name:
"fk_rails_98f3d044fe"
,
using: :btree
add_index
"protected_branch_merge_access_levels"
,
[
"protected_branch_id"
],
name:
"index_protected_branch_merge_access"
,
using: :btree
add_index
"protected_branch_merge_access_levels"
,
[
"user_id"
],
name:
"index_protected_branch_merge_access_levels_on_user_id"
,
using: :btree
create_table
"protected_branch_push_access_levels"
,
force: :cascade
do
|
t
|
t
.
integer
"protected_branch_id"
,
null:
false
t
.
integer
"access_level"
,
default:
40
,
null:
false
t
.
integer
"protected_branch_id"
,
limit:
4
,
null:
false
t
.
integer
"access_level"
,
limit:
4
,
default:
40
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
integer
"user_id"
,
limit:
4
t
.
integer
"group_id"
,
limit:
4
end
add_index
"protected_branch_push_access_levels"
,
[
"group_id"
],
name:
"fk_rails_7111b68cdb"
,
using: :btree
add_index
"protected_branch_push_access_levels"
,
[
"protected_branch_id"
],
name:
"index_protected_branch_push_access"
,
using: :btree
add_index
"protected_branch_push_access_levels"
,
[
"user_id"
],
name:
"index_protected_branch_push_access_levels_on_user_id"
,
using: :btree
create_table
"protected_branches"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
null:
false
t
.
string
"name"
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
string
"name"
,
limit:
255
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
add_index
"protected_branches"
,
[
"project_id"
],
name:
"index_protected_branches_on_project_id"
,
using: :btree
create_table
"push_rules"
,
force: :cascade
do
|
t
|
t
.
string
"force_push_regex"
,
limit:
255
t
.
string
"delete_branch_regex"
,
limit:
255
t
.
string
"commit_message_regex"
,
limit:
255
t
.
boolean
"deny_delete_tag"
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"author_email_regex"
,
limit:
255
t
.
boolean
"member_check"
,
default:
false
,
null:
false
t
.
string
"file_name_regex"
,
limit:
255
t
.
boolean
"is_sample"
,
default:
false
t
.
integer
"max_file_size"
,
limit:
4
,
default:
0
,
null:
false
t
.
boolean
"prevent_secrets"
,
default:
false
,
null:
false
end
add_index
"push_rules"
,
[
"project_id"
],
name:
"index_push_rules_on_project_id"
,
using: :btree
create_table
"releases"
,
force: :cascade
do
|
t
|
t
.
string
"tag"
t
.
text
"description"
t
.
integer
"project_id"
t
.
string
"tag"
,
limit:
255
t
.
text
"description"
,
limit:
65535
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
text
"description_html"
t
.
text
"description_html"
,
limit:
65535
end
add_index
"releases"
,
[
"project_id"
,
"tag"
],
name:
"index_releases_on_project_id_and_tag"
,
using: :btree
add_index
"releases"
,
[
"project_id"
],
name:
"index_releases_on_project_id"
,
using: :btree
create_table
"remote_mirrors"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
limit:
4
t
.
string
"url"
,
limit:
255
t
.
boolean
"enabled"
,
default:
false
t
.
string
"update_status"
,
limit:
255
t
.
datetime
"last_update_at"
t
.
datetime
"last_successful_update_at"
t
.
string
"last_error"
,
limit:
255
t
.
text
"encrypted_credentials"
,
limit:
65535
t
.
string
"encrypted_credentials_iv"
,
limit:
255
t
.
string
"encrypted_credentials_salt"
,
limit:
255
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
end
add_index
"remote_mirrors"
,
[
"project_id"
],
name:
"index_remote_mirrors_on_project_id"
,
using: :btree
create_table
"sent_notifications"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
t
.
integer
"noteable_id"
t
.
string
"noteable_type"
t
.
integer
"recipient_id"
t
.
string
"commit_id"
t
.
string
"reply_key"
,
null:
false
t
.
string
"line_code"
t
.
string
"note_type"
t
.
text
"position"
t
.
integer
"project_id"
,
limit:
4
t
.
integer
"noteable_id"
,
limit:
4
t
.
string
"noteable_type"
,
limit:
255
t
.
integer
"recipient_id"
,
limit:
4
t
.
string
"commit_id"
,
limit:
255
t
.
string
"reply_key"
,
limit:
255
,
null:
false
t
.
string
"line_code"
,
limit:
255
t
.
string
"note_type"
,
limit:
255
t
.
text
"position"
,
limit:
65535
end
add_index
"sent_notifications"
,
[
"reply_key"
],
name:
"index_sent_notifications_on_reply_key"
,
unique:
true
,
using: :btree
create_table
"services"
,
force: :cascade
do
|
t
|
t
.
string
"type"
t
.
string
"title"
t
.
integer
"project_id"
t
.
string
"type"
,
limit:
255
t
.
string
"title"
,
limit:
255
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
boolean
"active"
,
default:
false
,
null:
false
t
.
text
"properties"
t
.
text
"properties"
,
limit:
65535
t
.
boolean
"template"
,
default:
false
t
.
boolean
"push_events"
,
default:
true
t
.
boolean
"issues_events"
,
default:
true
...
...
@@ -1003,7 +1169,7 @@ ActiveRecord::Schema.define(version: 20161109150329) do
t
.
boolean
"tag_push_events"
,
default:
true
t
.
boolean
"note_events"
,
default:
true
,
null:
false
t
.
boolean
"build_events"
,
default:
false
,
null:
false
t
.
string
"category"
,
default:
"common"
,
null:
false
t
.
string
"category"
,
limit:
255
,
default:
"common"
,
null:
false
t
.
boolean
"default"
,
default:
false
t
.
boolean
"wiki_page_events"
,
default:
true
t
.
boolean
"pipeline_events"
,
default:
false
,
null:
false
...
...
@@ -1014,43 +1180,41 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"services"
,
[
"template"
],
name:
"index_services_on_template"
,
using: :btree
create_table
"snippets"
,
force: :cascade
do
|
t
|
t
.
string
"title"
t
.
text
"content"
t
.
integer
"author_id"
,
null:
false
t
.
integer
"project_id"
t
.
string
"title"
,
limit:
255
t
.
text
"content"
,
limit:
4294967295
t
.
integer
"author_id"
,
limit:
4
,
null:
false
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"file_name"
t
.
string
"type"
t
.
integer
"visibility_level"
,
default:
0
,
null:
false
t
.
text
"title_html"
t
.
text
"content_html"
t
.
string
"file_name"
,
limit:
255
t
.
string
"type"
,
limit:
255
t
.
integer
"visibility_level"
,
limit:
4
,
default:
0
,
null:
false
t
.
text
"title_html"
,
limit:
65535
t
.
text
"content_html"
,
limit:
65535
end
add_index
"snippets"
,
[
"author_id"
],
name:
"index_snippets_on_author_id"
,
using: :btree
add_index
"snippets"
,
[
"file_name"
],
name:
"index_snippets_on_file_name_trigram"
,
using: :gin
,
opclasses:
{
"file_name"
=>
"gin_trgm_ops"
}
add_index
"snippets"
,
[
"project_id"
],
name:
"index_snippets_on_project_id"
,
using: :btree
add_index
"snippets"
,
[
"title"
],
name:
"index_snippets_on_title_trigram"
,
using: :gin
,
opclasses:
{
"title"
=>
"gin_trgm_ops"
}
add_index
"snippets"
,
[
"updated_at"
],
name:
"index_snippets_on_updated_at"
,
using: :btree
add_index
"snippets"
,
[
"visibility_level"
],
name:
"index_snippets_on_visibility_level"
,
using: :btree
create_table
"spam_logs"
,
force: :cascade
do
|
t
|
t
.
integer
"user_id"
t
.
string
"source_ip"
t
.
string
"user_agent"
t
.
integer
"user_id"
,
limit:
4
t
.
string
"source_ip"
,
limit:
255
t
.
string
"user_agent"
,
limit:
255
t
.
boolean
"via_api"
t
.
string
"noteable_type"
t
.
string
"title"
t
.
text
"description"
t
.
string
"noteable_type"
,
limit:
255
t
.
string
"title"
,
limit:
255
t
.
text
"description"
,
limit:
65535
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
boolean
"submitted_as_ham"
,
default:
false
,
null:
false
end
create_table
"subscriptions"
,
force: :cascade
do
|
t
|
t
.
integer
"user_id"
t
.
integer
"subscribable_id"
t
.
string
"subscribable_type"
t
.
integer
"user_id"
,
limit:
4
t
.
integer
"subscribable_id"
,
limit:
4
t
.
string
"subscribable_type"
,
limit:
255
t
.
boolean
"subscribed"
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
...
...
@@ -1059,12 +1223,12 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"subscriptions"
,
[
"subscribable_id"
,
"subscribable_type"
,
"user_id"
],
name:
"subscriptions_user_id_and_ref_fields"
,
unique:
true
,
using: :btree
create_table
"taggings"
,
force: :cascade
do
|
t
|
t
.
integer
"tag_id"
t
.
integer
"taggable_id"
t
.
string
"taggable_type"
t
.
integer
"tagger_id"
t
.
string
"tagger_type"
t
.
string
"context"
t
.
integer
"tag_id"
,
limit:
4
t
.
integer
"taggable_id"
,
limit:
4
t
.
string
"taggable_type"
,
limit:
255
t
.
integer
"tagger_id"
,
limit:
4
t
.
string
"tagger_type"
,
limit:
255
t
.
string
"context"
,
limit:
255
t
.
datetime
"created_at"
end
...
...
@@ -1072,24 +1236,24 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"taggings"
,
[
"taggable_id"
,
"taggable_type"
,
"context"
],
name:
"index_taggings_on_taggable_id_and_taggable_type_and_context"
,
using: :btree
create_table
"tags"
,
force: :cascade
do
|
t
|
t
.
string
"name"
t
.
integer
"taggings_count"
,
default:
0
t
.
string
"name"
,
limit:
255
t
.
integer
"taggings_count"
,
limit:
4
,
default:
0
end
add_index
"tags"
,
[
"name"
],
name:
"index_tags_on_name"
,
unique:
true
,
using: :btree
create_table
"todos"
,
force: :cascade
do
|
t
|
t
.
integer
"user_id"
,
null:
false
t
.
integer
"project_id"
,
null:
false
t
.
integer
"target_id"
t
.
string
"target_type"
,
null:
false
t
.
integer
"author_id"
t
.
integer
"action"
,
null:
false
t
.
string
"state"
,
null:
false
t
.
integer
"user_id"
,
limit:
4
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
integer
"target_id"
,
limit:
4
t
.
string
"target_type"
,
limit:
255
,
null:
false
t
.
integer
"author_id"
,
limit:
4
t
.
integer
"action"
,
limit:
4
,
null:
false
t
.
string
"state"
,
limit:
255
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"note_id"
t
.
string
"commit_id"
t
.
integer
"note_id"
,
limit:
4
t
.
string
"commit_id"
,
limit:
255
end
add_index
"todos"
,
[
"author_id"
],
name:
"index_todos_on_author_id"
,
using: :btree
...
...
@@ -1100,95 +1264,104 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"todos"
,
[
"user_id"
],
name:
"index_todos_on_user_id"
,
using: :btree
create_table
"trending_projects"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
end
add_index
"trending_projects"
,
[
"project_id"
],
name:
"index_trending_projects_on_project_id"
,
using: :btree
create_table
"u2f_registrations"
,
force: :cascade
do
|
t
|
t
.
text
"certificate"
t
.
string
"key_handle"
t
.
string
"public_key"
t
.
integer
"counter"
t
.
integer
"user_id"
t
.
text
"certificate"
,
limit:
65535
t
.
string
"key_handle"
,
limit:
255
t
.
string
"public_key"
,
limit:
255
t
.
integer
"counter"
,
limit:
4
t
.
integer
"user_id"
,
limit:
4
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
string
"name"
t
.
string
"name"
,
limit:
255
end
add_index
"u2f_registrations"
,
[
"key_handle"
],
name:
"index_u2f_registrations_on_key_handle"
,
using: :btree
add_index
"u2f_registrations"
,
[
"user_id"
],
name:
"index_u2f_registrations_on_user_id"
,
using: :btree
create_table
"user_activities"
,
force: :cascade
do
|
t
|
t
.
integer
"user_id"
,
limit:
4
t
.
datetime
"last_activity_at"
,
null:
false
end
add_index
"user_activities"
,
[
"user_id"
],
name:
"index_user_activities_on_user_id"
,
unique:
true
,
using: :btree
create_table
"user_agent_details"
,
force: :cascade
do
|
t
|
t
.
string
"user_agent"
,
null:
false
t
.
string
"ip_address"
,
null:
false
t
.
integer
"subject_id"
,
null:
false
t
.
string
"subject_type"
,
null:
false
t
.
string
"user_agent"
,
limit:
255
,
null:
false
t
.
string
"ip_address"
,
limit:
255
,
null:
false
t
.
integer
"subject_id"
,
limit:
4
,
null:
false
t
.
string
"subject_type"
,
limit:
255
,
null:
false
t
.
boolean
"submitted"
,
default:
false
,
null:
false
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
end
create_table
"users"
,
force: :cascade
do
|
t
|
t
.
string
"email"
,
default:
""
,
null:
false
t
.
string
"encrypted_password"
,
default:
""
,
null:
false
t
.
string
"reset_password_token"
t
.
string
"email"
,
limit:
255
,
default:
""
,
null:
false
t
.
string
"encrypted_password"
,
limit:
255
,
default:
""
,
null:
false
t
.
string
"reset_password_token"
,
limit:
255
t
.
datetime
"reset_password_sent_at"
t
.
datetime
"remember_created_at"
t
.
integer
"sign_in_count"
,
default:
0
t
.
integer
"sign_in_count"
,
limit:
4
,
default:
0
t
.
datetime
"current_sign_in_at"
t
.
datetime
"last_sign_in_at"
t
.
string
"current_sign_in_ip"
t
.
string
"last_sign_in_ip"
t
.
string
"current_sign_in_ip"
,
limit:
255
t
.
string
"last_sign_in_ip"
,
limit:
255
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"name"
t
.
string
"name"
,
limit:
255
t
.
boolean
"admin"
,
default:
false
,
null:
false
t
.
integer
"projects_limit"
,
default:
10
t
.
string
"skype"
,
default:
""
,
null:
false
t
.
string
"linkedin"
,
default:
""
,
null:
false
t
.
string
"twitter"
,
default:
""
,
null:
false
t
.
string
"authentication_token"
t
.
integer
"theme_id"
,
default:
1
,
null:
false
t
.
string
"bio"
t
.
integer
"failed_attempts"
,
default:
0
t
.
integer
"projects_limit"
,
limit:
4
,
default:
10
t
.
string
"skype"
,
limit:
255
,
default:
""
,
null:
false
t
.
string
"linkedin"
,
limit:
255
,
default:
""
,
null:
false
t
.
string
"twitter"
,
limit:
255
,
default:
""
,
null:
false
t
.
string
"authentication_token"
,
limit:
255
t
.
integer
"theme_id"
,
limit:
4
,
default:
1
,
null:
false
t
.
string
"bio"
,
limit:
255
t
.
integer
"failed_attempts"
,
limit:
4
,
default:
0
t
.
datetime
"locked_at"
t
.
string
"username"
t
.
string
"username"
,
limit:
255
t
.
boolean
"can_create_group"
,
default:
true
,
null:
false
t
.
boolean
"can_create_team"
,
default:
true
,
null:
false
t
.
string
"state"
t
.
integer
"color_scheme_id"
,
default:
1
,
null:
false
t
.
string
"state"
,
limit:
255
t
.
integer
"color_scheme_id"
,
limit:
4
,
default:
1
,
null:
false
t
.
datetime
"password_expires_at"
t
.
integer
"created_by_id"
t
.
integer
"created_by_id"
,
limit:
4
t
.
datetime
"last_credential_check_at"
t
.
string
"avatar"
t
.
string
"confirmation_token"
t
.
string
"avatar"
,
limit:
255
t
.
string
"confirmation_token"
,
limit:
255
t
.
datetime
"confirmed_at"
t
.
datetime
"confirmation_sent_at"
t
.
string
"unconfirmed_email"
t
.
string
"unconfirmed_email"
,
limit:
255
t
.
boolean
"hide_no_ssh_key"
,
default:
false
t
.
string
"website_url"
,
default:
""
,
null:
false
t
.
string
"notification_email"
t
.
string
"website_url"
,
limit:
255
,
default:
""
,
null:
false
t
.
datetime
"admin_email_unsubscribed_at"
t
.
string
"notification_email"
,
limit:
255
t
.
boolean
"hide_no_password"
,
default:
false
t
.
boolean
"password_automatically_set"
,
default:
false
t
.
string
"location"
t
.
string
"encrypted_otp_secret"
t
.
string
"encrypted_otp_secret_iv"
t
.
string
"encrypted_otp_secret_salt"
t
.
string
"location"
,
limit:
255
t
.
string
"encrypted_otp_secret"
,
limit:
255
t
.
string
"encrypted_otp_secret_iv"
,
limit:
255
t
.
string
"encrypted_otp_secret_salt"
,
limit:
255
t
.
boolean
"otp_required_for_login"
,
default:
false
,
null:
false
t
.
text
"otp_backup_codes"
t
.
string
"public_email"
,
default:
""
,
null:
false
t
.
integer
"dashboard"
,
default:
0
t
.
integer
"project_view"
,
default:
0
t
.
integer
"consumed_timestep"
t
.
integer
"layout"
,
default:
0
t
.
text
"otp_backup_codes"
,
limit:
65535
t
.
string
"public_email"
,
limit:
255
,
default:
""
,
null:
false
t
.
integer
"dashboard"
,
limit:
4
,
default:
0
t
.
integer
"project_view"
,
limit:
4
,
default:
0
t
.
integer
"consumed_timestep"
,
limit:
4
t
.
integer
"layout"
,
limit:
4
,
default:
0
t
.
boolean
"hide_project_limit"
,
default:
false
t
.
string
"unlock_token"
t
.
text
"note"
,
limit:
65535
t
.
string
"unlock_token"
,
limit:
255
t
.
datetime
"otp_grace_period_started_at"
t
.
boolean
"ldap_email"
,
default:
false
,
null:
false
t
.
boolean
"external"
,
default:
false
t
.
string
"organization"
t
.
string
"incoming_email_token"
t
.
string
"organization"
,
limit:
255
t
.
string
"incoming_email_token"
,
limit:
255
end
add_index
"users"
,
[
"admin"
],
name:
"index_users_on_admin"
,
using: :btree
...
...
@@ -1197,18 +1370,15 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_index
"users"
,
[
"created_at"
],
name:
"index_users_on_created_at"
,
using: :btree
add_index
"users"
,
[
"current_sign_in_at"
],
name:
"index_users_on_current_sign_in_at"
,
using: :btree
add_index
"users"
,
[
"email"
],
name:
"index_users_on_email"
,
unique:
true
,
using: :btree
add_index
"users"
,
[
"email"
],
name:
"index_users_on_email_trigram"
,
using: :gin
,
opclasses:
{
"email"
=>
"gin_trgm_ops"
}
add_index
"users"
,
[
"incoming_email_token"
],
name:
"index_users_on_incoming_email_token"
,
using: :btree
add_index
"users"
,
[
"name"
],
name:
"index_users_on_name"
,
using: :btree
add_index
"users"
,
[
"name"
],
name:
"index_users_on_name_trigram"
,
using: :gin
,
opclasses:
{
"name"
=>
"gin_trgm_ops"
}
add_index
"users"
,
[
"reset_password_token"
],
name:
"index_users_on_reset_password_token"
,
unique:
true
,
using: :btree
add_index
"users"
,
[
"state"
],
name:
"index_users_on_state"
,
using: :btree
add_index
"users"
,
[
"username"
],
name:
"index_users_on_username"
,
using: :btree
add_index
"users"
,
[
"username"
],
name:
"index_users_on_username_trigram"
,
using: :gin
,
opclasses:
{
"username"
=>
"gin_trgm_ops"
}
create_table
"users_star_projects"
,
force: :cascade
do
|
t
|
t
.
integer
"project_id"
,
null:
false
t
.
integer
"user_id"
,
null:
false
t
.
integer
"project_id"
,
limit:
4
,
null:
false
t
.
integer
"user_id"
,
limit:
4
,
null:
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
end
...
...
@@ -1219,26 +1389,28 @@ ActiveRecord::Schema.define(version: 20161109150329) do
create_table
"web_hooks"
,
force: :cascade
do
|
t
|
t
.
string
"url"
,
limit:
2000
t
.
integer
"project_id"
t
.
integer
"project_id"
,
limit:
4
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"type"
,
default:
"ProjectHook"
t
.
integer
"service_id"
t
.
string
"type"
,
limit:
255
,
default:
"ProjectHook"
t
.
integer
"service_id"
,
limit:
4
t
.
boolean
"push_events"
,
default:
true
,
null:
false
t
.
boolean
"issues_events"
,
default:
false
,
null:
false
t
.
boolean
"merge_requests_events"
,
default:
false
,
null:
false
t
.
boolean
"tag_push_events"
,
default:
false
t
.
integer
"group_id"
,
limit:
4
t
.
boolean
"note_events"
,
default:
false
,
null:
false
t
.
boolean
"enable_ssl_verification"
,
default:
true
t
.
boolean
"build_events"
,
default:
false
,
null:
false
t
.
string
"token"
,
limit:
255
t
.
boolean
"wiki_page_events"
,
default:
false
,
null:
false
t
.
string
"token"
t
.
boolean
"pipeline_events"
,
default:
false
,
null:
false
t
.
boolean
"confidential_issues_events"
,
default:
false
,
null:
false
end
add_index
"web_hooks"
,
[
"project_id"
],
name:
"index_web_hooks_on_project_id"
,
using: :btree
add_foreign_key
"approver_groups"
,
"namespaces"
,
column:
"group_id"
,
on_delete: :cascade
add_foreign_key
"boards"
,
"projects"
add_foreign_key
"issue_metrics"
,
"issues"
,
on_delete: :cascade
add_foreign_key
"label_priorities"
,
"labels"
,
on_delete: :cascade
...
...
@@ -1250,9 +1422,17 @@ ActiveRecord::Schema.define(version: 20161109150329) do
add_foreign_key
"merge_request_metrics"
,
"merge_requests"
,
on_delete: :cascade
add_foreign_key
"merge_requests_closing_issues"
,
"issues"
,
on_delete: :cascade
add_foreign_key
"merge_requests_closing_issues"
,
"merge_requests"
,
on_delete: :cascade
add_foreign_key
"path_locks"
,
"projects"
add_foreign_key
"path_locks"
,
"users"
add_foreign_key
"personal_access_tokens"
,
"users"
add_foreign_key
"protected_branch_merge_access_levels"
,
"namespaces"
,
column:
"group_id"
add_foreign_key
"protected_branch_merge_access_levels"
,
"protected_branches"
add_foreign_key
"protected_branch_merge_access_levels"
,
"users"
add_foreign_key
"protected_branch_push_access_levels"
,
"namespaces"
,
column:
"group_id"
add_foreign_key
"protected_branch_push_access_levels"
,
"protected_branches"
add_foreign_key
"protected_branch_push_access_levels"
,
"users"
add_foreign_key
"remote_mirrors"
,
"projects"
add_foreign_key
"trending_projects"
,
"projects"
,
on_delete: :cascade
add_foreign_key
"u2f_registrations"
,
"users"
add_foreign_key
"user_activities"
,
"users"
,
on_delete: :cascade
end
lib/gitlab/cycle_analytics/base_config.rb
deleted
100644 → 0
View file @
f9de157e
module
Gitlab
module
CycleAnalytics
class
BaseConfig
extend
MetricsFetcher
class
<<
self
attr_reader
:start_time_attrs
,
:end_time_attrs
,
:projections
end
def
self
.
order
@order
||
@start_time_attrs
end
def
self
.
query
(
base_query
);
end
end
end
end
lib/gitlab/cycle_analytics/base_event.rb
0 → 100644
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
BaseEvent
extend
MetricsTables
class
<<
self
attr_reader
:stage
,
:start_time_attrs
,
:end_time_attrs
,
:projections
def
order
@order
||
@start_time_attrs
end
def
query
(
base_query
);
end
def
fetch
(
query
)
query
.
execute
(
self
).
map
{
|
event
|
serialize
(
event
,
query
)
}
end
private
def
serialize
(
event
,
query
)
raise
NotImplementedError
.
new
(
"Expected
#{
self
.
name
}
to implement serialize(event)"
)
end
end
end
end
end
lib/gitlab/cycle_analytics/code_
config
.rb
→
lib/gitlab/cycle_analytics/code_
event
.rb
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
CodeConfig
<
BaseConfig
class
CodeEvent
<
BaseEvent
@stage
=
:code
@start_time_attrs
=
issue_metrics_table
[
:first_mentioned_in_commit_at
]
@end_time_attrs
=
mr_table
[
:created_at
]
...
...
@@ -13,6 +14,12 @@ module Gitlab
mr_table
[
:author_id
]]
@order
=
mr_table
[
:created_at
]
def
self
.
serialize
(
event
,
query
)
event
[
'author'
]
=
User
.
find
(
event
.
delete
(
'author_id'
))
AnalyticsMergeRequestSerializer
.
new
(
project:
query
.
project
).
represent
(
event
).
as_json
end
end
end
end
lib/gitlab/cycle_analytics/
review
_config.rb
→
lib/gitlab/cycle_analytics/
event
_config.rb
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
ReviewConfig
<
BaseConfig
class
TestEvent
<
BaseEvent
@start_time_attrs
=
mr_table
[
:created_at
]
@end_time_attrs
=
mr_metrics_table
[
:merged_at
]
...
...
lib/gitlab/cycle_analytics/events.rb
View file @
ed39d61d
...
...
@@ -3,73 +3,35 @@ module Gitlab
class
Events
def
initialize
(
project
:,
options
:)
@project
=
project
@
fetcher
=
EventsFetcher
.
new
(
project:
project
,
options:
options
)
@
query
=
EventsQuery
.
new
(
project:
project
,
options:
options
)
end
def
issue_events
@fetcher
.
fetch
(
stage: :issue
).
map
{
|
event
|
serialize_event
(
event
)
}
IssueEvent
.
fetch
(
@query
)
end
def
plan_events
@fetcher
.
fetch
(
stage: :plan
).
map
do
|
event
|
st_commit
=
first_time_reference_commit
(
event
.
delete
(
'commits'
),
event
)
next
unless
st_commit
serialize_commit
(
event
,
st_commit
)
end
PlanEvent
.
fetch
(
@query
)
end
def
code_events
@fetcher
.
fetch
(
stage: :code
).
map
{
|
event
|
serialize_event
(
event
,
entity: :merge_request
)
}
CodeEvent
.
fetch
(
@query
)
end
def
test_events
@fetcher
.
fetch
(
stage: :test
).
map
{
|
event
|
serialize_build_event
(
event
)
}
TestEvent
.
fetch
(
@query
)
end
def
review_events
@fetcher
.
fetch
(
stage: :review
).
map
{
|
event
|
serialize_event
(
event
,
entity: :merge_request
)
}
ReviewEvent
.
fetch
(
@query
)
end
def
staging_events
@fetcher
.
fetch
(
stage: :staging
).
map
{
|
event
|
serialize_build_event
(
event
)
}
StagingEvent
.
fetch
(
@query
)
end
def
production_events
@fetcher
.
fetch
(
stage: :production
).
map
{
|
event
|
serialize_event
(
event
)
}
end
private
def
serialize_event
(
event
,
entity: :issue
)
event
[
'author'
]
=
User
.
find
(
event
.
delete
(
'author_id'
))
AnalyticsGenericSerializer
.
new
(
project:
@project
,
entity:
entity
).
represent
(
event
).
as_json
end
def
serialize_build_event
(
event
)
build
=
::
Ci
::
Build
.
find
(
event
[
'id'
])
AnalyticsBuildSerializer
.
new
.
represent
(
build
).
as_json
end
def
first_time_reference_commit
(
commits
,
event
)
YAML
.
load
(
commits
).
find
do
|
commit
|
next
unless
commit
[
:committed_date
]
&&
event
[
'first_mentioned_in_commit_at'
]
commit
[
:committed_date
].
to_i
==
DateTime
.
parse
(
event
[
'first_mentioned_in_commit_at'
].
to_s
).
to_i
end
end
def
serialize_commit
(
event
,
st_commit
)
commit
=
Commit
.
new
(
Gitlab
::
Git
::
Commit
.
new
(
st_commit
),
@project
)
AnalyticsCommitSerializer
.
new
(
project:
@project
,
total_time:
event
[
'total_time'
]).
represent
(
commit
).
as_json
end
def
interval_in_words
(
diff
)
"
#{
distance_of_time_in_words
(
diff
.
to_f
)
}
ago"
ProductionEvent
.
fetch
(
@query
)
end
end
end
...
...
lib/gitlab/cycle_analytics/events_fetcher.rb
View file @
ed39d61d
...
...
@@ -6,9 +6,7 @@ module Gitlab
end
def
fetch
(
stage
:)
@query
.
execute
(
stage
)
do
|
stage_class
,
base_query
|
stage_class
.
query
(
base_query
)
end
@query
.
execute
(
stage
)
end
end
end
...
...
lib/gitlab/cycle_analytics/events_query.rb
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
EventsQuery
include
MetricsFetcher
attr_reader
:project
def
initialize
(
project
:,
options:
{})
@project
=
project
@from
=
options
[
:from
]
@branch
=
options
[
:branch
]
@fetcher
=
Gitlab
::
CycleAnalytics
::
MetricsFetcher
.
new
(
project:
project
,
from:
@from
,
branch:
@branch
)
end
def
execute
(
stage
,
&
block
)
@stage
=
stage
query
=
build_query
(
&
block
)
def
execute
(
stage_class
)
@stage_class
=
stage_class
ActiveRecord
::
Base
.
connection
.
exec_query
(
query
.
to_sql
)
end
private
def
build_
query
base_query
=
base_query_for
(
@
stage
)
diff_fn
=
subtract_datetimes_diff
(
base_query
,
stage_class
.
start_time_attrs
,
stage_class
.
end_time_attrs
)
def
query
base_query
=
@fetcher
.
base_query_for
(
@stage_class
.
stage
)
diff_fn
=
@fetcher
.
subtract_datetimes_diff
(
base_query
,
@stage_class
.
start_time_attrs
,
@
stage_class
.
end_time_attrs
)
yield
(
stage_class
,
base_query
)
if
block_given?
@stage_class
.
query
(
base_query
)
base_query
.
project
(
extract_epoch
(
diff_fn
).
as
(
'total_time'
),
*
stage_class
.
projections
).
order
(
stage_class
.
order
.
desc
)
base_query
.
project
(
extract_epoch
(
diff_fn
).
as
(
'total_time'
),
*
@stage_class
.
projections
).
order
(
@
stage_class
.
order
.
desc
)
end
def
extract_epoch
(
arel_attribute
)
...
...
@@ -32,10 +32,6 @@ module Gitlab
Arel
.
sql
(
%Q{EXTRACT(EPOCH FROM (
#{
arel_attribute
.
to_sql
}
))}
)
end
def
stage_class
@stage_class
||=
"Gitlab::CycleAnalytics::
#{
@stage
.
to_s
.
camelize
}
Config"
.
constantize
end
end
end
end
lib/gitlab/cycle_analytics/issue_
config
.rb
→
lib/gitlab/cycle_analytics/issue_
event
.rb
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
IssueConfig
<
BaseConfig
class
IssueEvent
<
BaseEvent
@stage
=
:issue
@start_time_attrs
=
issue_table
[
:created_at
]
@end_time_attrs
=
[
issue_metrics_table
[
:first_associated_with_milestone_at
],
...
...
@@ -11,6 +12,12 @@ module Gitlab
issue_table
[
:id
],
issue_table
[
:created_at
],
issue_table
[
:author_id
]]
def
self
.
serialize
(
event
,
query
)
event
[
'author'
]
=
User
.
find
(
event
.
delete
(
'author_id'
))
AnalyticsIssueSerializer
.
new
(
project:
query
.
project
).
represent
(
event
).
as_json
end
end
end
end
lib/gitlab/cycle_analytics/metrics_fetcher.rb
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
module
MetricsFetcher
class
MetricsFetcher
include
Gitlab
::
Database
::
Median
include
Gitlab
::
Database
::
DateTime
include
MetricsTables
DEPLOYMENT_METRIC_STAGES
=
%i[production staging]
private
def
initialize
(
project
:,
from
:,
branch
:)
@project
=
project
@project
=
project
@from
=
from
@branch
=
branch
end
def
calculate_metric
(
name
,
start_time_attrs
,
end_time_attrs
)
cte_table
=
Arel
::
Table
.
new
(
"cte_table_for_
#{
name
}
"
)
...
...
@@ -49,38 +55,6 @@ module Gitlab
query
end
def
mr_metrics_table
MergeRequest
::
Metrics
.
arel_table
end
def
mr_table
MergeRequest
.
arel_table
end
def
mr_diff_table
MergeRequestDiff
.
arel_table
end
def
mr_closing_issues_table
MergeRequestsClosingIssues
.
arel_table
end
def
issue_table
Issue
.
arel_table
end
def
issue_metrics_table
Issue
::
Metrics
.
arel_table
end
def
user_table
User
.
arel_table
end
def
build_table
::
CommitStatus
.
arel_table
end
end
end
end
lib/gitlab/cycle_analytics/metrics_tables.rb
0 → 100644
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
module
MetricsTables
def
mr_metrics_table
MergeRequest
::
Metrics
.
arel_table
end
def
mr_table
MergeRequest
.
arel_table
end
def
mr_diff_table
MergeRequestDiff
.
arel_table
end
def
mr_closing_issues_table
MergeRequestsClosingIssues
.
arel_table
end
def
issue_table
Issue
.
arel_table
end
def
issue_metrics_table
Issue
::
Metrics
.
arel_table
end
def
user_table
User
.
arel_table
end
def
build_table
::
CommitStatus
.
arel_table
end
end
end
end
lib/gitlab/cycle_analytics/plan_config.rb
deleted
100644 → 0
View file @
f9de157e
module
Gitlab
module
CycleAnalytics
class
PlanConfig
<
BaseConfig
@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
]]
def
self
.
query
(
base_query
)
base_query
.
join
(
mr_diff_table
).
on
(
mr_diff_table
[
:merge_request_id
].
eq
(
mr_table
[
:id
]))
end
end
end
end
lib/gitlab/cycle_analytics/plan_event.rb
0 → 100644
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
PlanEvent
<
BaseEvent
@stage
=
:plan
@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
]]
class
<<
self
def
query
(
base_query
)
base_query
.
join
(
mr_diff_table
).
on
(
mr_diff_table
[
:merge_request_id
].
eq
(
mr_table
[
:id
]))
end
private
def
serialize
(
event
,
query
)
st_commit
=
first_time_reference_commit
(
event
.
delete
(
'commits'
),
event
)
return
unless
st_commit
serialize_commit
(
event
,
st_commit
,
query
)
end
def
first_time_reference_commit
(
commits
,
event
)
YAML
.
load
(
commits
).
find
do
|
commit
|
next
unless
commit
[
:committed_date
]
&&
event
[
'first_mentioned_in_commit_at'
]
commit
[
:committed_date
].
to_i
==
DateTime
.
parse
(
event
[
'first_mentioned_in_commit_at'
].
to_s
).
to_i
end
end
def
serialize_commit
(
event
,
st_commit
,
query
)
commit
=
Commit
.
new
(
Gitlab
::
Git
::
Commit
.
new
(
st_commit
),
@project
)
AnalyticsCommitSerializer
.
new
(
project:
query
.
project
,
total_time:
event
[
'total_time'
]).
represent
(
commit
).
as_json
end
end
end
end
end
\ No newline at end of file
lib/gitlab/cycle_analytics/production_
config
.rb
→
lib/gitlab/cycle_analytics/production_
event
.rb
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
ProductionConfig
<
BaseConfig
class
ProductionEvent
<
BaseEvent
@stage
=
:production
@start_time_attrs
=
issue_table
[
:created_at
]
@end_time_attrs
=
mr_metrics_table
[
:first_deployed_to_production_at
]
...
...
@@ -10,6 +11,12 @@ module Gitlab
issue_table
[
:id
],
issue_table
[
:created_at
],
issue_table
[
:author_id
]]
def
self
.
serialize
(
event
,
query
)
event
[
'author'
]
=
User
.
find
(
event
.
delete
(
'author_id'
))
AnalyticsIssueSerializer
.
new
(
project:
query
.
project
).
represent
(
event
).
as_json
end
end
end
end
lib/gitlab/cycle_analytics/review_event.rb
0 → 100644
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
ReviewEvent
<
BaseEvent
@stage
=
:review
@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
]]
def
self
.
serialize
(
event
,
_query
)
event
[
'author'
]
=
User
.
find
(
event
.
delete
(
'author_id'
))
AnalyticsMergeRequestSerializer
.
new
(
project:
query
.
project
).
represent
(
event
).
as_json
end
end
end
end
lib/gitlab/cycle_analytics/staging_
config
.rb
→
lib/gitlab/cycle_analytics/staging_
event
.rb
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
StagingConfig
<
BaseConfig
class
StagingEvent
<
BaseEvent
@stage
=
:staging
@start_time_attrs
=
mr_metrics_table
[
:merged_at
]
@end_time_attrs
=
mr_metrics_table
[
:first_deployed_to_production_at
]
@projections
=
[
build_table
[
:id
]]
...
...
@@ -9,6 +10,12 @@ module Gitlab
def
self
.
query
(
base_query
)
base_query
.
join
(
build_table
).
on
(
mr_metrics_table
[
:pipeline_id
].
eq
(
build_table
[
:commit_id
]))
end
def
self
.
serialize
(
event
,
_query
)
build
=
::
Ci
::
Build
.
find
(
event
[
'id'
])
AnalyticsBuildSerializer
.
new
.
represent
(
build
).
as_json
end
end
end
end
lib/gitlab/cycle_analytics/test_
config
.rb
→
lib/gitlab/cycle_analytics/test_
event
.rb
View file @
ed39d61d
module
Gitlab
module
CycleAnalytics
class
TestConfig
<
BaseConfig
class
TestEvent
<
BaseEvent
@stage
=
:test
@start_time_attrs
=
mr_metrics_table
[
:latest_build_started_at
]
@end_time_attrs
=
mr_metrics_table
[
:latest_build_finished_at
]
@projections
=
[
build_table
[
:id
]]
...
...
@@ -9,6 +10,12 @@ module Gitlab
def
self
.
query
(
base_query
)
base_query
.
join
(
build_table
).
on
(
mr_metrics_table
[
:pipeline_id
].
eq
(
build_table
[
:commit_id
]))
end
def
self
.
serialize
(
event
,
_query
)
build
=
::
Ci
::
Build
.
find
(
event
[
'id'
])
AnalyticsBuildSerializer
.
new
.
represent
(
build
).
as_json
end
end
end
end
spec/lib/gitlab/cycle_analytics/code_
config
_spec.rb
→
spec/lib/gitlab/cycle_analytics/code_
event
_spec.rb
View file @
ed39d61d
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_
config
_spec'
require
'lib/gitlab/cycle_analytics/shared_
event
_spec'
describe
Gitlab
::
CycleAnalytics
::
Code
Config
do
describe
Gitlab
::
CycleAnalytics
::
Code
Event
do
it_behaves_like
'default query config'
it
'has the default order'
do
...
...
spec/lib/gitlab/cycle_analytics/issue_
config
_spec.rb
→
spec/lib/gitlab/cycle_analytics/issue_
event
_spec.rb
View file @
ed39d61d
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_
config
_spec'
require
'lib/gitlab/cycle_analytics/shared_
event
_spec'
describe
Gitlab
::
CycleAnalytics
::
Issue
Config
do
describe
Gitlab
::
CycleAnalytics
::
Issue
Event
do
it_behaves_like
'default query config'
it
'has the default order'
do
...
...
spec/lib/gitlab/cycle_analytics/plan_
config
_spec.rb
→
spec/lib/gitlab/cycle_analytics/plan_
event
_spec.rb
View file @
ed39d61d
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_
config
_spec'
require
'lib/gitlab/cycle_analytics/shared_
event
_spec'
describe
Gitlab
::
CycleAnalytics
::
Plan
Config
do
describe
Gitlab
::
CycleAnalytics
::
Plan
Event
do
it_behaves_like
'default query config'
it
'has the default order'
do
...
...
spec/lib/gitlab/cycle_analytics/production_
config
_spec.rb
→
spec/lib/gitlab/cycle_analytics/production_
event
_spec.rb
View file @
ed39d61d
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_
config
_spec'
require
'lib/gitlab/cycle_analytics/shared_
event
_spec'
describe
Gitlab
::
CycleAnalytics
::
Production
Config
do
describe
Gitlab
::
CycleAnalytics
::
Production
Event
do
it_behaves_like
'default query config'
it
'has the default order'
do
...
...
spec/lib/gitlab/cycle_analytics/review_
config
_spec.rb
→
spec/lib/gitlab/cycle_analytics/review_
event
_spec.rb
View file @
ed39d61d
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_
config
_spec'
require
'lib/gitlab/cycle_analytics/shared_
event
_spec'
describe
Gitlab
::
CycleAnalytics
::
Review
Config
do
describe
Gitlab
::
CycleAnalytics
::
Review
Event
do
it_behaves_like
'default query config'
it
'has the default order'
do
...
...
spec/lib/gitlab/cycle_analytics/shared_
config
_spec.rb
→
spec/lib/gitlab/cycle_analytics/shared_
event
_spec.rb
View file @
ed39d61d
...
...
@@ -12,4 +12,8 @@ shared_examples 'default query config' do
it
'has the projection attributes'
do
expect
(
described_class
.
projections
).
not_to
be_nil
end
it
'implements the fetch method'
do
expect
(
described_class
.
fetch
).
not_to
raise_error
end
end
spec/lib/gitlab/cycle_analytics/staging_
config
_spec.rb
→
spec/lib/gitlab/cycle_analytics/staging_
event
_spec.rb
View file @
ed39d61d
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_
config
_spec'
require
'lib/gitlab/cycle_analytics/shared_
event
_spec'
describe
Gitlab
::
CycleAnalytics
::
Staging
Config
do
describe
Gitlab
::
CycleAnalytics
::
Staging
Event
do
it_behaves_like
'default query config'
it
'has the default order'
do
...
...
spec/lib/gitlab/cycle_analytics/test_
config
_spec.rb
→
spec/lib/gitlab/cycle_analytics/test_
event
_spec.rb
View file @
ed39d61d
require
'spec_helper'
require
'lib/gitlab/cycle_analytics/shared_
config
_spec'
require
'lib/gitlab/cycle_analytics/shared_
event
_spec'
describe
Gitlab
::
CycleAnalytics
::
Test
Config
do
describe
Gitlab
::
CycleAnalytics
::
Test
Event
do
it_behaves_like
'default query config'
it
'has the default order'
do
...
...
spec/serializers/analytics_generic_entity_spec.rb
View file @
ed39d61d
require
'spec_helper'
describe
Analytics
Generic
Entity
do
describe
Analytics
Issue
Entity
do
let
(
:user
)
{
create
(
:user
)
}
let
(
:entity_hash
)
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