Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
4a726bd1
Commit
4a726bd1
authored
Jun 28, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
c70d390b
fd5772a8
Changes
13
Show whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
162 additions
and
100 deletions
+162
-100
app/assets/javascripts/lib/graphql.js
app/assets/javascripts/lib/graphql.js
+1
-1
app/assets/javascripts/repository/components/last_commit.vue
app/assets/javascripts/repository/components/last_commit.vue
+72
-63
app/assets/javascripts/repository/index.js
app/assets/javascripts/repository/index.js
+13
-17
app/assets/javascripts/repository/queries/pathLastCommit.query.graphql
...vascripts/repository/queries/pathLastCommit.query.graphql
+3
-3
app/views/projects/_files.html.haml
app/views/projects/_files.html.haml
+3
-1
changelogs/unreleased/transaction-metrics.yml
changelogs/unreleased/transaction-metrics.yml
+5
-0
config/initializers/transaction_metrics.rb
config/initializers/transaction_metrics.rb
+3
-0
lib/gitlab/database.rb
lib/gitlab/database.rb
+33
-0
lib/gitlab/optimistic_locking.rb
lib/gitlab/optimistic_locking.rb
+1
-0
spec/features/projects/files/user_reads_pipeline_status_spec.rb
...eatures/projects/files/user_reads_pipeline_status_spec.rb
+2
-0
spec/features/projects/show/user_sees_last_commit_ci_status_spec.rb
...res/projects/show/user_sees_last_commit_ci_status_spec.rb
+4
-0
spec/frontend/repository/components/__snapshots__/last_commit_spec.js.snap
...ository/components/__snapshots__/last_commit_spec.js.snap
+8
-8
spec/frontend/repository/components/last_commit_spec.js
spec/frontend/repository/components/last_commit_spec.js
+14
-7
No files found.
app/assets/javascripts/lib/graphql.js
View file @
4a726bd1
...
...
@@ -22,7 +22,7 @@ export default (resolvers = {}, config = {}) => {
return
new
ApolloClient
({
link
:
ApolloLink
.
split
(
operation
=>
operation
.
getContext
().
hasUpload
,
operation
=>
operation
.
getContext
().
hasUpload
||
operation
.
getContext
().
isSingleRequest
,
createUploadLink
(
httpOptions
),
new
BatchHttpLink
(
httpOptions
),
),
...
...
app/assets/javascripts/repository/components/last_commit.vue
View file @
4a726bd1
<
script
>
import
{
GlTooltipDirective
,
GlLink
,
GlButton
}
from
'
@gitlab/ui
'
;
import
{
GlTooltipDirective
,
GlLink
,
GlButton
,
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
sprintf
,
s__
}
from
'
~/locale
'
;
import
Icon
from
'
../../vue_shared/components/icon.vue
'
;
import
UserAvatarLink
from
'
../../vue_shared/components/user_avatar/user_avatar_link.vue
'
;
import
TimeagoTooltip
from
'
../../vue_shared/components/time_ago_tooltip.vue
'
;
import
CommitPipelineStatus
from
'
../../projects/tree/components/commit_pipeline_status_component.vue
'
;
import
CiIcon
from
'
../../vue_shared/components/ci_icon.vue
'
;
import
ClipboardButton
from
'
../../vue_shared/components/clipboard_button.vue
'
;
import
getRefMixin
from
'
../mixins/get_ref
'
;
...
...
@@ -16,11 +15,11 @@ export default {
Icon
,
UserAvatarLink
,
TimeagoTooltip
,
CommitPipelineStatus
,
ClipboardButton
,
CiIcon
,
GlLink
,
GlButton
,
GlLoadingIcon
,
},
directives
:
{
GlTooltip
:
GlTooltipDirective
,
...
...
@@ -39,7 +38,10 @@ export default {
path
:
this
.
currentPath
.
replace
(
/^
\/
/
,
''
),
};
},
update
:
data
=>
data
.
project
.
repository
.
tree
.
commit
,
update
:
data
=>
data
.
project
.
repository
.
tree
.
lastCommit
,
context
:
{
isSingleRequest
:
true
,
},
},
},
props
:
{
...
...
@@ -59,14 +61,14 @@ export default {
computed
:
{
statusTitle
()
{
return
sprintf
(
s__
(
'
Commits|Commit: %{commitText}
'
),
{
commitText
:
this
.
commit
.
p
ipeline
.
detailedStatus
.
text
,
commitText
:
this
.
commit
.
latestP
ipeline
.
detailedStatus
.
text
,
});
},
isLoading
()
{
return
this
.
$apollo
.
queries
.
commit
.
loading
;
},
showCommitId
()
{
return
this
.
commit
.
id
.
substr
(
0
,
8
);
return
this
.
commit
.
sha
.
substr
(
0
,
8
);
},
},
methods
:
{
...
...
@@ -78,7 +80,9 @@ export default {
</
script
>
<
template
>
<div
v-if=
"!isLoading"
class=
"info-well d-none d-sm-flex project-last-commit commit p-3"
>
<div
class=
"info-well d-none d-sm-flex project-last-commit commit p-3"
>
<gl-loading-icon
v-if=
"isLoading"
size=
"md"
class=
"mx-auto"
/>
<template
v-else
>
<user-avatar-link
v-if=
"commit.author"
:link-href=
"commit.author.webUrl"
...
...
@@ -121,25 +125,30 @@ export default {
</div>
<div
class=
"commit-actions flex-row"
>
<gl-link
v-if=
"commit.p
ipeline"
v-if=
"commit.latestP
ipeline"
v-gl-tooltip
:href=
"commit.p
ipeline.detailedStatus.detailsPath"
:href=
"commit.latestP
ipeline.detailedStatus.detailsPath"
:title=
"statusTitle"
class=
"js-commit-pipeline"
>
<ci-icon
:status=
"commit.pipeline.detailedStatus"
:size=
"24"
:aria-label=
"statusTitle"
/>
<ci-icon
:status=
"commit.latestPipeline.detailedStatus"
:size=
"24"
:aria-label=
"statusTitle"
/>
</gl-link>
<div
class=
"commit-sha-group d-flex"
>
<div
class=
"label label-monospace monospace"
>
{{
showCommitId
}}
</div>
<clipboard-button
:text=
"commit.id
"
:text=
"commit.sha
"
:title=
"__('Copy commit SHA to clipboard')"
tooltip-placement=
"bottom"
/>
</div>
</div>
</div>
</
template
>
</div>
</template>
app/assets/javascripts/repository/index.js
View file @
4a726bd1
...
...
@@ -50,12 +50,9 @@ export default function setupVueRepositoryList() {
},
});
const
commitEl
=
document
.
getElementById
(
'
js-last-commit
'
);
if
(
commitEl
)
{
// eslint-disable-next-line no-new
new
Vue
({
el
:
commitEl
,
el
:
document
.
getElementById
(
'
js-last-commit
'
)
,
router
,
apolloProvider
,
render
(
h
)
{
...
...
@@ -66,7 +63,6 @@ export default function setupVueRepositoryList() {
});
},
});
}
return
new
Vue
({
el
,
...
...
app/assets/javascripts/repository/queries/pathLastCommit.query.graphql
View file @
4a726bd1
...
...
@@ -2,8 +2,8 @@ query pathLastCommit($projectPath: ID!, $path: String, $ref: String!) {
project
(
fullPath
:
$projectPath
)
{
repository
{
tree
(
path
:
$path
,
ref
:
$ref
)
{
c
ommit
{
id
lastC
ommit
{
sha
title
message
webUrl
...
...
@@ -13,7 +13,7 @@ query pathLastCommit($projectPath: ID!, $path: String, $ref: String!) {
avatarUrl
webUrl
}
p
ipeline
{
latestP
ipeline
{
detailedStatus
{
detailsPath
icon
...
...
app/views/projects/_files.html.haml
View file @
4a726bd1
...
...
@@ -9,7 +9,9 @@
.nav-block
=
render
'projects/tree/tree_header'
,
tree:
@tree
-
if
commit
-
if
vue_file_list_enabled?
#js-last-commit
-
elsif
commit
=
render
'shared/commit_well'
,
commit:
commit
,
ref:
ref
,
project:
project
-
if
is_project_overview
...
...
changelogs/unreleased/transaction-metrics.yml
0 → 100644
View file @
4a726bd1
---
title
:
Adds metrics to measure cost of expensive operations
merge_request
:
29928
author
:
type
:
other
config/initializers/transaction_metrics.rb
0 → 100644
View file @
4a726bd1
# frozen_string_literal: true
Gitlab
::
Database
.
install_monkey_patches
lib/gitlab/database.rb
View file @
4a726bd1
...
...
@@ -2,6 +2,8 @@
module
Gitlab
module
Database
include
Gitlab
::
Metrics
::
Methods
# The max value of INTEGER type is the same between MySQL and PostgreSQL:
# https://www.postgresql.org/docs/9.2/static/datatype-numeric.html
# http://dev.mysql.com/doc/refman/5.7/en/integer-types.html
...
...
@@ -11,6 +13,10 @@ module Gitlab
# https://dev.mysql.com/doc/refman/5.7/en/datetime.html
MAX_TIMESTAMP_VALUE
=
Time
.
at
((
1
<<
31
)
-
1
).
freeze
define_histogram
:gitlab_database_transaction_seconds
do
docstring
"Time spent in database transactions, in seconds"
end
def
self
.
config
ActiveRecord
::
Base
.
configurations
[
Rails
.
env
]
end
...
...
@@ -286,6 +292,33 @@ module Gitlab
0
end
private_class_method
:open_transactions_baseline
# Monkeypatch rails with upgraded database observability
def
self
.
install_monkey_patches
ActiveRecord
::
Base
.
prepend
(
ActiveRecordBaseTransactionMetrics
)
end
# observe_transaction_duration is called from ActiveRecordBaseTransactionMetrics.transaction and used to
# record transaction durations.
def
self
.
observe_transaction_duration
(
duration_seconds
)
labels
=
Gitlab
::
Metrics
::
Transaction
.
current
&
.
labels
||
{}
gitlab_database_transaction_seconds
.
observe
(
labels
,
duration_seconds
)
rescue
Prometheus
::
Client
::
LabelSetValidator
::
LabelSetError
=>
err
# Ensure that errors in recording these metrics don't affect the operation of the application
Rails
.
logger
.
error
(
"Unable to observe database transaction duration:
#{
err
}
"
)
end
# MonkeyPatch for ActiveRecord::Base for adding observability
module
ActiveRecordBaseTransactionMetrics
# A monkeypatch over ActiveRecord::Base.transaction.
# It provides observability into transactional methods.
def
transaction
(
options
=
{},
&
block
)
start_time
=
Gitlab
::
Metrics
::
System
.
monotonic_time
super
(
options
,
&
block
)
ensure
Gitlab
::
Database
.
observe_transaction_duration
(
Gitlab
::
Metrics
::
System
.
monotonic_time
-
start_time
)
end
end
end
end
...
...
lib/gitlab/optimistic_locking.rb
View file @
4a726bd1
...
...
@@ -5,6 +5,7 @@ module Gitlab
module_function
def
retry_lock
(
subject
,
retries
=
100
,
&
block
)
# TODO(Observability): We should be recording details of the number of retries and the duration of the total execution here
ActiveRecord
::
Base
.
transaction
do
yield
(
subject
)
end
...
...
spec/features/projects/files/user_reads_pipeline_status_spec.rb
View file @
4a726bd1
...
...
@@ -7,6 +7,8 @@ describe 'user reads pipeline status', :js do
let
(
:x110_pipeline
)
{
create_pipeline
(
'x1.1.0'
,
'failed'
)
}
before
do
stub_feature_flags
(
vue_file_list:
false
)
project
.
add_maintainer
(
user
)
project
.
repository
.
add_tag
(
user
,
'x1.1.0'
,
'v1.1.0'
)
...
...
spec/features/projects/show/user_sees_last_commit_ci_status_spec.rb
View file @
4a726bd1
...
...
@@ -3,6 +3,10 @@ require 'spec_helper'
describe
'Projects > Show > User sees last commit CI status'
do
set
(
:project
)
{
create
(
:project
,
:repository
,
:public
)
}
before
do
stub_feature_flags
(
vue_file_list:
false
)
end
it
'shows the project README'
,
:js
do
project
.
enable_ci
pipeline
=
create
(
:ci_pipeline
,
project:
project
,
sha:
project
.
commit
.
sha
,
ref:
'master'
)
...
...
spec/frontend/repository/components/__snapshots__/last_commit_spec.js.snap
View file @
4a726bd1
spec/frontend/repository/components/last_commit_spec.js
View file @
4a726bd1
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
LastCommit
from
'
~/repository/components/last_commit.vue
'
;
import
UserAvatarLink
from
'
~/vue_shared/components/user_avatar/user_avatar_link.vue
'
;
...
...
@@ -6,7 +7,7 @@ let vm;
function
createCommitData
(
data
=
{})
{
return
{
id
:
'
123456789
'
,
sha
:
'
123456789
'
,
title
:
'
Commit title
'
,
message
:
'
Commit message
'
,
webUrl
:
'
https://test.com/commit/123
'
,
...
...
@@ -16,7 +17,7 @@ function createCommitData(data = {}) {
avatarUrl
:
'
https://test.com
'
,
webUrl
:
'
https://test.com/test
'
,
},
p
ipeline
:
{
latestP
ipeline
:
{
detailedStatus
:
{
detailsPath
:
'
https://test.com/pipeline
'
,
icon
:
'
failed
'
,
...
...
@@ -52,12 +53,12 @@ describe('Repository last commit component', () => {
it
.
each
`
loading | label
${
true
}
|
${
'
hide
s
'
}
${
false
}
|
${
'
show
s
'
}
`
(
'
$label when $loading is true
'
,
({
loading
})
=>
{
${
true
}
|
${
'
show
s
'
}
${
false
}
|
${
'
hide
s
'
}
`
(
'
$label when
loading icon
$loading is true
'
,
({
loading
})
=>
{
factory
(
createCommitData
(),
loading
);
expect
(
vm
.
isEmpty
()).
toBe
(
loading
);
expect
(
vm
.
find
(
GlLoadingIcon
).
exists
()).
toBe
(
loading
);
});
it
(
'
renders commit widget
'
,
()
=>
{
...
...
@@ -73,11 +74,17 @@ describe('Repository last commit component', () => {
});
it
(
'
hides pipeline components when pipeline does not exist
'
,
()
=>
{
factory
(
createCommitData
({
p
ipeline
:
null
}));
factory
(
createCommitData
({
latestP
ipeline
:
null
}));
expect
(
vm
.
find
(
'
.js-commit-pipeline
'
).
exists
()).
toBe
(
false
);
});
it
(
'
renders pipeline components
'
,
()
=>
{
factory
();
expect
(
vm
.
find
(
'
.js-commit-pipeline
'
).
exists
()).
toBe
(
true
);
});
it
(
'
hides author component when author does not exist
'
,
()
=>
{
factory
(
createCommitData
({
author
:
null
}));
...
...
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