Commit 81f7adf0 authored by GitLab Bot's avatar GitLab Bot

Add latest changes from gitlab-org/gitlab@master

parent 383daa12
...@@ -47,7 +47,7 @@ ...@@ -47,7 +47,7 @@
- rm -f /etc/apt/sources.list.d/google*.list # We don't need to update Chrome here - rm -f /etc/apt/sources.list.d/google*.list # We don't need to update Chrome here
only: only:
variables: variables:
- $CI_SERVER_HOST == "gitlab.com" && $CI_PROJECT_NAMESPACE == "gitlab-org" - $CI_SERVER_HOST == "gitlab.com" && $CI_PROJECT_NAMESPACE =~ /^gitlab-org($|\/)/ # Matches the gitlab-org group and its subgroups
- $CI_SERVER_HOST == "dev.gitlab.org" - $CI_SERVER_HOST == "dev.gitlab.org"
tags: tags:
- gitlab-org - gitlab-org
......
...@@ -33,6 +33,7 @@ ...@@ -33,6 +33,7 @@
- master - master
- /^[\d-]+-stable(-ee)?$/ - /^[\d-]+-stable(-ee)?$/
- /^\d+-\d+-auto-deploy-\d+$/ - /^\d+-\d+-auto-deploy-\d+$/
- /^security\//
- merge_requests - merge_requests
- tags - tags
......
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
- ./scripts/trigger-build omnibus - ./scripts/trigger-build omnibus
only: only:
variables: variables:
- $CI_SERVER_HOST == "gitlab.com" && $CI_PROJECT_NAMESPACE == "gitlab-org" - $CI_SERVER_HOST == "gitlab.com" && $CI_PROJECT_NAMESPACE =~ /^gitlab-org($|\/)/ # Matches the gitlab-org group or its subgroups
package-and-qa-manual: package-and-qa-manual:
extends: extends:
......
...@@ -252,6 +252,10 @@ Please view this file on the master branch, on stable branches it's out of date. ...@@ -252,6 +252,10 @@ Please view this file on the master branch, on stable branches it's out of date.
- Fix alignment of activity dropdown in epic tabs; add counter to discussion tab. - Fix alignment of activity dropdown in epic tabs; add counter to discussion tab.
## 12.1.10
- No changes.
## 12.1.5 ## 12.1.5
- No changes. - No changes.
......
...@@ -320,10 +320,6 @@ entry. ...@@ -320,10 +320,6 @@ entry.
- Update Packer.gitlab-ci.yml to use latest image. (Kelly Hair) - Update Packer.gitlab-ci.yml to use latest image. (Kelly Hair)
## 12.1.11
- No changes.
## 12.1.10 ## 12.1.10
- No changes. - No changes.
......
...@@ -2,9 +2,9 @@ ...@@ -2,9 +2,9 @@
## Canonical source ## Canonical source
The canonical source of GitLab Community Edition is [hosted on GitLab.com](https://gitlab.com/gitlab-org/gitlab-ce/). The canonical source of GitLab where development takes place is [hosted on GitLab.com](https://gitlab.com/gitlab-org/gitlab).
The source of GitLab Enterprise Edition is [hosted on GitLab.com](https://gitlab.com/gitlab-org/gitlab-ee). A FOSS source of GitLab is hosted on a [mirrored, read-only project on GitLab.com](https://gitlab.com/gitlab-org/gitlab-foss/).
## Free trial ## Free trial
......
<script>
import LogLine from './line.vue';
import LogLineHeader from './line_header.vue';
export default {
name: 'CollpasibleLogSection',
components: {
LogLine,
LogLineHeader,
},
props: {
section: {
type: Object,
required: true,
},
traceEndpoint: {
type: String,
required: true,
},
},
computed: {
badgeDuration() {
return this.section.line && this.section.line.section_duration;
},
},
methods: {
handleOnClickCollapsibleLine(section) {
this.$emit('onClickCollapsibleLine', section);
},
},
};
</script>
<template>
<div>
<log-line-header
:line="section.line"
:duration="badgeDuration"
:path="traceEndpoint"
:is-closed="section.isClosed"
@toggleLine="handleOnClickCollapsibleLine(section)"
/>
<template v-if="!section.isClosed">
<template v-for="line in section.lines">
<collpasible-log-section
v-if="line.isHeader"
:key="`collapsible-nested-${line.offset}`"
:section="line"
:trace-endpoint="traceEndpoint"
@toggleLine="handleOnClickCollapsibleLine"
/>
<log-line v-else :key="line.offset" :line="line" :path="traceEndpoint" />
</template>
</template>
</div>
</template>
<script> <script>
import { mapState, mapActions } from 'vuex'; import { mapState, mapActions } from 'vuex';
import CollpasibleLogSection from './collapsible_section.vue';
import LogLine from './line.vue'; import LogLine from './line.vue';
import LogLineHeader from './line_header.vue';
export default { export default {
components: { components: {
CollpasibleLogSection,
LogLine, LogLine,
LogLineHeader,
}, },
computed: { computed: {
...mapState(['traceEndpoint', 'trace', 'isTraceComplete']), ...mapState(['traceEndpoint', 'trace', 'isTraceComplete']),
...@@ -22,24 +22,13 @@ export default { ...@@ -22,24 +22,13 @@ export default {
<template> <template>
<code class="job-log d-block"> <code class="job-log d-block">
<template v-for="(section, index) in trace"> <template v-for="(section, index) in trace">
<template v-if="section.isHeader"> <collpasible-log-section
<log-line-header v-if="section.isHeader"
:key="`collapsible-${index}`" :key="`collapsible-${index}`"
:line="section.line" :section="section"
:duration="section.section_duration" :trace-endpoint="traceEndpoint"
:path="traceEndpoint" @onClickCollapsibleLine="handleOnClickCollapsibleLine"
:is-closed="section.isClosed"
@toggleLine="handleOnClickCollapsibleLine(section)"
/> />
<template v-if="!section.isClosed">
<log-line
v-for="line in section.lines"
:key="line.offset"
:line="line"
:path="traceEndpoint"
/>
</template>
</template>
<log-line v-else :key="section.offset" :line="section" :path="traceEndpoint" /> <log-line v-else :key="section.offset" :line="section" :path="traceEndpoint" />
</template> </template>
......
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
@import 'framework/issue_box'; @import 'framework/issue_box';
@import 'framework/lists'; @import 'framework/lists';
@import 'framework/logo'; @import 'framework/logo';
@import 'framework/job_log';
@import 'framework/markdown_area'; @import 'framework/markdown_area';
@import 'framework/media_object'; @import 'framework/media_object';
@import 'framework/modal'; @import 'framework/modal';
......
...@@ -46,12 +46,12 @@ ...@@ -46,12 +46,12 @@
= form.radio_button :deploy_strategy, 'timed_incremental', class: 'form-check-input' = form.radio_button :deploy_strategy, 'timed_incremental', class: 'form-check-input'
= form.label :deploy_strategy_timed_incremental, class: 'form-check-label' do = form.label :deploy_strategy_timed_incremental, class: 'form-check-label' do
= s_('CICD|Continuous deployment to production using timed incremental rollout') = s_('CICD|Continuous deployment to production using timed incremental rollout')
= link_to icon('question-circle'), help_page_path('topics/autodevops/index.md', anchor: 'timed-incremental-rollout-to-production'), target: '_blank' = link_to icon('question-circle'), help_page_path('topics/autodevops/index.md', anchor: 'timed-incremental-rollout-to-production-premium'), target: '_blank'
.form-check .form-check
= form.radio_button :deploy_strategy, 'manual', class: 'form-check-input' = form.radio_button :deploy_strategy, 'manual', class: 'form-check-input'
= form.label :deploy_strategy_manual, class: 'form-check-label' do = form.label :deploy_strategy_manual, class: 'form-check-label' do
= s_('CICD|Automatic deployment to staging, manual deployment to production') = s_('CICD|Automatic deployment to staging, manual deployment to production')
= link_to icon('question-circle'), help_page_path('topics/autodevops/index.md', anchor: 'incremental-rollout-to-production'), target: '_blank' = link_to icon('question-circle'), help_page_path('topics/autodevops/index.md', anchor: 'incremental-rollout-to-production-premium'), target: '_blank'
= f.submit _('Save changes'), class: "btn btn-success prepend-top-15", data: { qa_selector: 'save_changes_button' } = f.submit _('Save changes'), class: "btn btn-success prepend-top-15", data: { qa_selector: 'save_changes_button' }
---
title: Add timeouts for each RPC call
merge_request: 31766
author:
type: changed
...@@ -5,24 +5,8 @@ class ScheduleProductivityAnalyticsBackfill < ActiveRecord::Migration[5.2] ...@@ -5,24 +5,8 @@ class ScheduleProductivityAnalyticsBackfill < ActiveRecord::Migration[5.2]
DOWNTIME = false DOWNTIME = false
BATCH_SIZE = 10_000
INTERVAL = 3.minutes
MIGRATION = 'Gitlab::BackgroundMigration::RecalculateProductivityAnalytics'.freeze
disable_ddl_transaction!
def up def up
return unless Gitlab.ee? # no-op since the scheduling times out on GitLab.com
metrics_model = Class.new(ActiveRecord::Base) do
self.table_name = 'merge_request_metrics'
include ::EachBatch
end
scope = metrics_model.where("merged_at >= ?", 3.months.ago)
queue_background_migration_jobs_by_range_at_intervals(scope, MIGRATION, INTERVAL, batch_size: BATCH_SIZE)
end end
def down def down
......
...@@ -84,6 +84,28 @@ NOTE: **Note:** ...@@ -84,6 +84,28 @@ NOTE: **Note:**
If you encounter an error message with [Yarn](https://yarnpkg.com/en/), see the If you encounter an error message with [Yarn](https://yarnpkg.com/en/), see the
[troubleshooting section](#troubleshooting). [troubleshooting section](#troubleshooting).
### Using variables to avoid hard-coding auth token values
To avoid hard-coding the `authToken` value, you may use a variables in its place.
In your `.npmrc` file, you would add:
```ini
@foo:registry=https://gitlab.com/api/v4/packages/npm/
//gitlab.com/api/v4/packages/npm/:_authToken=${NPM_TOKEN}
//gitlab.com/api/v4/projects/<your_project_id>/packages/npm/:_authToken=${NPM_TOKEN}
```
Then, you could run `npm publish` either locally or via GitLab CI/CD:
- **Locally:** Export `NPM_TOKEN` before publishing:
```sh
NPM_TOKEN=<your_token> npm publish
```
- **GitLab CI/CD:** Set an `NPM_TOKEN` [variable](../../../ci/variables/README.md)
under your project's **Settings > CI/CD > Variables**.
## Uploading packages ## Uploading packages
Before you will be able to upload a package, you need to specify the registry Before you will be able to upload a package, you need to specify the registry
...@@ -145,3 +167,29 @@ with your with your OAuth or personal access token): ...@@ -145,3 +167,29 @@ with your with your OAuth or personal access token):
```text ```text
//gitlab.com/api/v4/projects/:_authToken=<your_oauth_token> //gitlab.com/api/v4/projects/:_authToken=<your_oauth_token>
``` ```
### `npm publish` targets default NPM registry (`registry.npmjs.org`)
Ensure that your package scope is set consistently in your `package.json` and `.npmrc` files.
For example, if your project name in GitLab is `foo/my-package`, then your `package.json` file
should look like:
```json
{
"name": "@foo/my-package",
"version": "1.0.0",
"description": "Example package for GitLab NPM registry",
"publishConfig": {
"@foo:registry":"https://gitlab.com/api/v4/projects/<your_project_id>/packages/npm/"
}
}
```
And the `.npmrc` file should look like:
```ini
//gitlab.com/api/v4/projects/<your_project_id>/packages/npm/:_authToken=<your_oauth_token>
//gitlab.com/api/v4/packages/npm/:_authToken=<your_oauth_token>
@foo:registry=https://gitlab.com/api/v4/packages/npm/
```
...@@ -142,13 +142,13 @@ module Gitlab ...@@ -142,13 +142,13 @@ module Gitlab
# kwargs.merge(deadline: Time.now + 10) # kwargs.merge(deadline: Time.now + 10)
# end # end
# #
def self.call(storage, service, rpc, request, remote_storage: nil, timeout: nil) def self.call(storage, service, rpc, request, remote_storage: nil, timeout: default_timeout)
start = Gitlab::Metrics::System.monotonic_time start = Gitlab::Metrics::System.monotonic_time
request_hash = request.is_a?(Google::Protobuf::MessageExts) ? request.to_h : {} request_hash = request.is_a?(Google::Protobuf::MessageExts) ? request.to_h : {}
enforce_gitaly_request_limits(:call) enforce_gitaly_request_limits(:call)
kwargs = request_kwargs(storage, timeout, remote_storage: remote_storage) kwargs = request_kwargs(storage, timeout: timeout.to_f, remote_storage: remote_storage)
kwargs = yield(kwargs) if block_given? kwargs = yield(kwargs) if block_given?
stub(service, storage).__send__(rpc, request, kwargs) # rubocop:disable GitlabSecurity/PublicSend stub(service, storage).__send__(rpc, request, kwargs) # rubocop:disable GitlabSecurity/PublicSend
...@@ -200,7 +200,7 @@ module Gitlab ...@@ -200,7 +200,7 @@ module Gitlab
end end
private_class_method :authorization_token private_class_method :authorization_token
def self.request_kwargs(storage, timeout, remote_storage: nil) def self.request_kwargs(storage, timeout:, remote_storage: nil)
metadata = { metadata = {
'authorization' => "Bearer #{authorization_token(storage)}", 'authorization' => "Bearer #{authorization_token(storage)}",
'client_name' => CLIENT_NAME 'client_name' => CLIENT_NAME
...@@ -216,14 +216,7 @@ module Gitlab ...@@ -216,14 +216,7 @@ module Gitlab
result = { metadata: metadata } result = { metadata: metadata }
# nil timeout indicates that we should use the default result[:deadline] = real_time + timeout if timeout > 0
timeout = default_timeout if timeout.nil?
return result unless timeout > 0
deadline = real_time + timeout
result[:deadline] = deadline
result result
end end
...@@ -357,8 +350,6 @@ module Gitlab ...@@ -357,8 +350,6 @@ module Gitlab
# The default timeout on all Gitaly calls # The default timeout on all Gitaly calls
def self.default_timeout def self.default_timeout
return no_timeout if Sidekiq.server?
timeout(:gitaly_timeout_default) timeout(:gitaly_timeout_default)
end end
...@@ -370,8 +361,12 @@ module Gitlab ...@@ -370,8 +361,12 @@ module Gitlab
timeout(:gitaly_timeout_medium) timeout(:gitaly_timeout_medium)
end end
def self.no_timeout def self.long_timeout
0 if Sidekiq.server?
6.hours
else
55.seconds
end
end end
def self.storage_metadata_file_path(storage) def self.storage_metadata_file_path(storage)
......
...@@ -18,7 +18,7 @@ module Gitlab ...@@ -18,7 +18,7 @@ module Gitlab
:cleanup_service, :cleanup_service,
:apply_bfg_object_map_stream, :apply_bfg_object_map_stream,
build_object_map_enum(io), build_object_map_enum(io),
timeout: GitalyClient.no_timeout timeout: GitalyClient.long_timeout
) )
responses.each(&blk) responses.each(&blk)
......
...@@ -254,7 +254,7 @@ module Gitlab ...@@ -254,7 +254,7 @@ module Gitlab
def languages(ref = nil) def languages(ref = nil)
request = Gitaly::CommitLanguagesRequest.new(repository: @gitaly_repo, revision: ref || '') request = Gitaly::CommitLanguagesRequest.new(repository: @gitaly_repo, revision: ref || '')
response = GitalyClient.call(@repository.storage, :commit_service, :commit_languages, request) response = GitalyClient.call(@repository.storage, :commit_service, :commit_languages, request, timeout: GitalyClient.long_timeout)
response.languages.map { |l| { value: l.share.round(2), label: l.name, color: l.color, highlight: l.color } } response.languages.map { |l| { value: l.share.round(2), label: l.name, color: l.color, highlight: l.color } }
end end
...@@ -360,7 +360,7 @@ module Gitlab ...@@ -360,7 +360,7 @@ module Gitlab
def extract_signature(commit_id) def extract_signature(commit_id)
request = Gitaly::ExtractCommitSignatureRequest.new(repository: @gitaly_repo, commit_id: commit_id) request = Gitaly::ExtractCommitSignatureRequest.new(repository: @gitaly_repo, commit_id: commit_id)
response = GitalyClient.call(@repository.storage, :commit_service, :extract_commit_signature, request) response = GitalyClient.call(@repository.storage, :commit_service, :extract_commit_signature, request, timeout: GitalyClient.fast_timeout)
signature = +''.b signature = +''.b
signed_text = +''.b signed_text = +''.b
......
...@@ -20,7 +20,7 @@ module Gitlab ...@@ -20,7 +20,7 @@ module Gitlab
our_commit_oid: @our_commit_oid, our_commit_oid: @our_commit_oid,
their_commit_oid: @their_commit_oid their_commit_oid: @their_commit_oid
) )
response = GitalyClient.call(@repository.storage, :conflicts_service, :list_conflict_files, request) response = GitalyClient.call(@repository.storage, :conflicts_service, :list_conflict_files, request, timeout: GitalyClient.long_timeout)
GitalyClient::ConflictFilesStitcher.new(response) GitalyClient::ConflictFilesStitcher.new(response)
end end
......
...@@ -22,7 +22,7 @@ module Gitlab ...@@ -22,7 +22,7 @@ module Gitlab
def remove(name) def remove(name)
request = Gitaly::RemoveNamespaceRequest.new(storage_name: @storage, name: name) request = Gitaly::RemoveNamespaceRequest.new(storage_name: @storage, name: name)
gitaly_client_call(:remove_namespace, request, timeout: nil) gitaly_client_call(:remove_namespace, request, timeout: GitalyClient.long_timeout)
end end
def rename(from, to) def rename(from, to)
......
...@@ -15,13 +15,15 @@ module Gitlab ...@@ -15,13 +15,15 @@ module Gitlab
object_pool: object_pool, object_pool: object_pool,
origin: repository.gitaly_repository) origin: repository.gitaly_repository)
GitalyClient.call(storage, :object_pool_service, :create_object_pool, request) GitalyClient.call(storage, :object_pool_service, :create_object_pool,
request, timeout: GitalyClient.medium_timeout)
end end
def delete def delete
request = Gitaly::DeleteObjectPoolRequest.new(object_pool: object_pool) request = Gitaly::DeleteObjectPoolRequest.new(object_pool: object_pool)
GitalyClient.call(storage, :object_pool_service, :delete_object_pool, request) GitalyClient.call(storage, :object_pool_service, :delete_object_pool,
request, timeout: GitalyClient.long_timeout)
end end
def link_repository(repository) def link_repository(repository)
...@@ -40,7 +42,8 @@ module Gitlab ...@@ -40,7 +42,8 @@ module Gitlab
origin: repository.gitaly_repository origin: repository.gitaly_repository
) )
GitalyClient.call(storage, :object_pool_service, :fetch_into_object_pool, request) GitalyClient.call(storage, :object_pool_service, :fetch_into_object_pool,
request, timeout: GitalyClient.long_timeout)
end end
end end
end end
......
...@@ -19,7 +19,7 @@ module Gitlab ...@@ -19,7 +19,7 @@ module Gitlab
user: Gitlab::Git::User.from_gitlab(user).to_gitaly user: Gitlab::Git::User.from_gitlab(user).to_gitaly
) )
response = GitalyClient.call(@repository.storage, :operation_service, :user_delete_tag, request, timeout: GitalyClient.medium_timeout) response = GitalyClient.call(@repository.storage, :operation_service, :user_delete_tag, request, timeout: GitalyClient.long_timeout)
if pre_receive_error = response.pre_receive_error.presence if pre_receive_error = response.pre_receive_error.presence
raise Gitlab::Git::PreReceiveError, pre_receive_error raise Gitlab::Git::PreReceiveError, pre_receive_error
...@@ -35,7 +35,7 @@ module Gitlab ...@@ -35,7 +35,7 @@ module Gitlab
message: encode_binary(message.to_s) message: encode_binary(message.to_s)
) )
response = GitalyClient.call(@repository.storage, :operation_service, :user_create_tag, request, timeout: GitalyClient.medium_timeout) response = GitalyClient.call(@repository.storage, :operation_service, :user_create_tag, request, timeout: GitalyClient.long_timeout)
if pre_receive_error = response.pre_receive_error.presence if pre_receive_error = response.pre_receive_error.presence
raise Gitlab::Git::PreReceiveError, pre_receive_error raise Gitlab::Git::PreReceiveError, pre_receive_error
elsif response.exists elsif response.exists
...@@ -55,7 +55,7 @@ module Gitlab ...@@ -55,7 +55,7 @@ module Gitlab
start_point: encode_binary(start_point) start_point: encode_binary(start_point)
) )
response = GitalyClient.call(@repository.storage, :operation_service, response = GitalyClient.call(@repository.storage, :operation_service,
:user_create_branch, request) :user_create_branch, request, timeout: GitalyClient.long_timeout)
if response.pre_receive_error.present? if response.pre_receive_error.present?
raise Gitlab::Git::PreReceiveError.new(response.pre_receive_error) raise Gitlab::Git::PreReceiveError.new(response.pre_receive_error)
...@@ -79,7 +79,8 @@ module Gitlab ...@@ -79,7 +79,8 @@ module Gitlab
oldrev: encode_binary(oldrev) oldrev: encode_binary(oldrev)
) )
response = GitalyClient.call(@repository.storage, :operation_service, :user_update_branch, request) response = GitalyClient.call(@repository.storage, :operation_service,
:user_update_branch, request, timeout: GitalyClient.long_timeout)
if pre_receive_error = response.pre_receive_error.presence if pre_receive_error = response.pre_receive_error.presence
raise Gitlab::Git::PreReceiveError, pre_receive_error raise Gitlab::Git::PreReceiveError, pre_receive_error
...@@ -93,7 +94,8 @@ module Gitlab ...@@ -93,7 +94,8 @@ module Gitlab
user: Gitlab::Git::User.from_gitlab(user).to_gitaly user: Gitlab::Git::User.from_gitlab(user).to_gitaly
) )
response = GitalyClient.call(@repository.storage, :operation_service, :user_delete_branch, request) response = GitalyClient.call(@repository.storage, :operation_service,
:user_delete_branch, request, timeout: GitalyClient.long_timeout)
if pre_receive_error = response.pre_receive_error.presence if pre_receive_error = response.pre_receive_error.presence
raise Gitlab::Git::PreReceiveError, pre_receive_error raise Gitlab::Git::PreReceiveError, pre_receive_error
...@@ -111,7 +113,8 @@ module Gitlab ...@@ -111,7 +113,8 @@ module Gitlab
first_parent_ref: encode_binary(first_parent_ref) first_parent_ref: encode_binary(first_parent_ref)
) )
response = GitalyClient.call(@repository.storage, :operation_service, :user_merge_to_ref, request) response = GitalyClient.call(@repository.storage, :operation_service,
:user_merge_to_ref, request, timeout: GitalyClient.long_timeout)
if pre_receive_error = response.pre_receive_error.presence if pre_receive_error = response.pre_receive_error.presence
raise Gitlab::Git::PreReceiveError, pre_receive_error raise Gitlab::Git::PreReceiveError, pre_receive_error
...@@ -126,7 +129,8 @@ module Gitlab ...@@ -126,7 +129,8 @@ module Gitlab
@repository.storage, @repository.storage,
:operation_service, :operation_service,
:user_merge_branch, :user_merge_branch,
request_enum.each request_enum.each,
timeout: GitalyClient.long_timeout
) )
request_enum.push( request_enum.push(
...@@ -170,7 +174,8 @@ module Gitlab ...@@ -170,7 +174,8 @@ module Gitlab
@repository.storage, @repository.storage,
:operation_service, :operation_service,
:user_ff_branch, :user_ff_branch,
request request,
timeout: GitalyClient.long_timeout
) )
Gitlab::Git::OperationService::BranchUpdate.from_gitaly(response.branch_update) Gitlab::Git::OperationService::BranchUpdate.from_gitaly(response.branch_update)
...@@ -215,6 +220,7 @@ module Gitlab ...@@ -215,6 +220,7 @@ module Gitlab
:operation_service, :operation_service,
:user_rebase, :user_rebase,
request, request,
timeout: GitalyClient.long_timeout,
remote_storage: remote_repository.storage remote_storage: remote_repository.storage
) )
...@@ -236,6 +242,7 @@ module Gitlab ...@@ -236,6 +242,7 @@ module Gitlab
:operation_service, :operation_service,
:user_rebase_confirmable, :user_rebase_confirmable,
request_enum.each, request_enum.each,
timeout: GitalyClient.long_timeout,
remote_storage: remote_repository.storage remote_storage: remote_repository.storage
) )
...@@ -286,7 +293,8 @@ module Gitlab ...@@ -286,7 +293,8 @@ module Gitlab
@repository.storage, @repository.storage,
:operation_service, :operation_service,
:user_squash, :user_squash,
request request,
timeout: GitalyClient.long_timeout
) )
if response.git_error.presence if response.git_error.presence
...@@ -310,7 +318,8 @@ module Gitlab ...@@ -310,7 +318,8 @@ module Gitlab
@repository.storage, @repository.storage,
:operation_service, :operation_service,
:user_update_submodule, :user_update_submodule,
request request,
timeout: GitalyClient.long_timeout
) )
if response.pre_receive_error.present? if response.pre_receive_error.present?
...@@ -352,7 +361,8 @@ module Gitlab ...@@ -352,7 +361,8 @@ module Gitlab
end end
response = GitalyClient.call(@repository.storage, :operation_service, response = GitalyClient.call(@repository.storage, :operation_service,
:user_commit_files, req_enum, remote_storage: start_repository.storage) :user_commit_files, req_enum, timeout: GitalyClient.long_timeout,
remote_storage: start_repository.storage)
if (pre_receive_error = response.pre_receive_error.presence) if (pre_receive_error = response.pre_receive_error.presence)
raise Gitlab::Git::PreReceiveError, pre_receive_error raise Gitlab::Git::PreReceiveError, pre_receive_error
...@@ -384,7 +394,8 @@ module Gitlab ...@@ -384,7 +394,8 @@ module Gitlab
end end
end end
response = GitalyClient.call(@repository.storage, :operation_service, :user_apply_patch, chunks) response = GitalyClient.call(@repository.storage, :operation_service,
:user_apply_patch, chunks, timeout: GitalyClient.long_timeout)
Gitlab::Git::OperationService::BranchUpdate.from_gitaly(response.branch_update) Gitlab::Git::OperationService::BranchUpdate.from_gitaly(response.branch_update)
end end
...@@ -424,7 +435,7 @@ module Gitlab ...@@ -424,7 +435,7 @@ module Gitlab
:"user_#{rpc}", :"user_#{rpc}",
request, request,
remote_storage: start_repository.storage, remote_storage: start_repository.storage,
timeout: GitalyClient.medium_timeout timeout: GitalyClient.long_timeout
) )
handle_cherry_pick_or_revert_response(response) handle_cherry_pick_or_revert_response(response)
......
...@@ -21,7 +21,7 @@ module Gitlab ...@@ -21,7 +21,7 @@ module Gitlab
def remote_branches(remote_name) def remote_branches(remote_name)
request = Gitaly::FindAllRemoteBranchesRequest.new(repository: @gitaly_repo, remote_name: remote_name) request = Gitaly::FindAllRemoteBranchesRequest.new(repository: @gitaly_repo, remote_name: remote_name)
response = GitalyClient.call(@repository.storage, :ref_service, :find_all_remote_branches, request) response = GitalyClient.call(@repository.storage, :ref_service, :find_all_remote_branches, request, timeout: GitalyClient.medium_timeout)
consume_find_all_remote_branches_response(remote_name, response) consume_find_all_remote_branches_response(remote_name, response)
end end
...@@ -158,7 +158,7 @@ module Gitlab ...@@ -158,7 +158,7 @@ module Gitlab
start_point: encode_binary(start_point) start_point: encode_binary(start_point)
) )
response = GitalyClient.call(@repository.storage, :ref_service, :create_branch, request) response = GitalyClient.call(@repository.storage, :ref_service, :create_branch, request, timeout: GitalyClient.medium_timeout)
case response.status case response.status
when :OK when :OK
...@@ -182,7 +182,7 @@ module Gitlab ...@@ -182,7 +182,7 @@ module Gitlab
name: encode_binary(branch_name) name: encode_binary(branch_name)
) )
GitalyClient.call(@repository.storage, :ref_service, :delete_branch, request) GitalyClient.call(@repository.storage, :ref_service, :delete_branch, request, timeout: GitalyClient.medium_timeout)
end end
def delete_refs(refs: [], except_with_prefixes: []) def delete_refs(refs: [], except_with_prefixes: [])
...@@ -192,7 +192,7 @@ module Gitlab ...@@ -192,7 +192,7 @@ module Gitlab
except_with_prefix: except_with_prefixes.map { |r| encode_binary(r) } except_with_prefix: except_with_prefixes.map { |r| encode_binary(r) }
) )
response = GitalyClient.call(@repository.storage, :ref_service, :delete_refs, request, timeout: GitalyClient.default_timeout) response = GitalyClient.call(@repository.storage, :ref_service, :delete_refs, request, timeout: GitalyClient.medium_timeout)
raise Gitlab::Git::Repository::GitError, response.git_error if response.git_error.present? raise Gitlab::Git::Repository::GitError, response.git_error if response.git_error.present?
end end
...@@ -242,7 +242,7 @@ module Gitlab ...@@ -242,7 +242,7 @@ module Gitlab
def pack_refs def pack_refs
request = Gitaly::PackRefsRequest.new(repository: @gitaly_repo) request = Gitaly::PackRefsRequest.new(repository: @gitaly_repo)
GitalyClient.call(@storage, :ref_service, :pack_refs, request) GitalyClient.call(@storage, :ref_service, :pack_refs, request, timeout: GitalyClient.long_timeout)
end end
private private
......
...@@ -38,9 +38,7 @@ module Gitlab ...@@ -38,9 +38,7 @@ module Gitlab
def remove_remote(name) def remove_remote(name)
request = Gitaly::RemoveRemoteRequest.new(repository: @gitaly_repo, name: name) request = Gitaly::RemoveRemoteRequest.new(repository: @gitaly_repo, name: name)
response = GitalyClient.call(@storage, :remote_service, :remove_remote, request) GitalyClient.call(@storage, :remote_service, :remove_remote, request, timeout: GitalyClient.long_timeout).result
response.result
end end
def fetch_internal_remote(repository) def fetch_internal_remote(repository)
...@@ -51,6 +49,7 @@ module Gitlab ...@@ -51,6 +49,7 @@ module Gitlab
response = GitalyClient.call(@storage, :remote_service, response = GitalyClient.call(@storage, :remote_service,
:fetch_internal_remote, request, :fetch_internal_remote, request,
timeout: GitalyClient.medium_timeout,
remote_storage: repository.storage) remote_storage: repository.storage)
response.result response.result
...@@ -63,7 +62,7 @@ module Gitlab ...@@ -63,7 +62,7 @@ module Gitlab
) )
response = GitalyClient.call(@storage, :remote_service, response = GitalyClient.call(@storage, :remote_service,
:find_remote_root_ref, request) :find_remote_root_ref, request, timeout: GitalyClient.medium_timeout)
encode_utf8(response.ref) encode_utf8(response.ref)
end end
...@@ -95,7 +94,7 @@ module Gitlab ...@@ -95,7 +94,7 @@ module Gitlab
end end
end end
GitalyClient.call(@storage, :remote_service, :update_remote_mirror, req_enum) GitalyClient.call(@storage, :remote_service, :update_remote_mirror, req_enum, timeout: GitalyClient.long_timeout)
end end
end end
end end
......
...@@ -28,17 +28,17 @@ module Gitlab ...@@ -28,17 +28,17 @@ module Gitlab
def garbage_collect(create_bitmap) def garbage_collect(create_bitmap)
request = Gitaly::GarbageCollectRequest.new(repository: @gitaly_repo, create_bitmap: create_bitmap) request = Gitaly::GarbageCollectRequest.new(repository: @gitaly_repo, create_bitmap: create_bitmap)
GitalyClient.call(@storage, :repository_service, :garbage_collect, request) GitalyClient.call(@storage, :repository_service, :garbage_collect, request, timeout: GitalyClient.long_timeout)
end end
def repack_full(create_bitmap) def repack_full(create_bitmap)
request = Gitaly::RepackFullRequest.new(repository: @gitaly_repo, create_bitmap: create_bitmap) request = Gitaly::RepackFullRequest.new(repository: @gitaly_repo, create_bitmap: create_bitmap)
GitalyClient.call(@storage, :repository_service, :repack_full, request) GitalyClient.call(@storage, :repository_service, :repack_full, request, timeout: GitalyClient.long_timeout)
end end
def repack_incremental def repack_incremental
request = Gitaly::RepackIncrementalRequest.new(repository: @gitaly_repo) request = Gitaly::RepackIncrementalRequest.new(repository: @gitaly_repo)
GitalyClient.call(@storage, :repository_service, :repack_incremental, request) GitalyClient.call(@storage, :repository_service, :repack_incremental, request, timeout: GitalyClient.long_timeout)
end end
def repository_size def repository_size
...@@ -86,12 +86,12 @@ module Gitlab ...@@ -86,12 +86,12 @@ module Gitlab
end end
end end
GitalyClient.call(@storage, :repository_service, :fetch_remote, request) GitalyClient.call(@storage, :repository_service, :fetch_remote, request, timeout: GitalyClient.long_timeout)
end end
def create_repository def create_repository
request = Gitaly::CreateRepositoryRequest.new(repository: @gitaly_repo) request = Gitaly::CreateRepositoryRequest.new(repository: @gitaly_repo)
GitalyClient.call(@storage, :repository_service, :create_repository, request, timeout: GitalyClient.medium_timeout) GitalyClient.call(@storage, :repository_service, :create_repository, request, timeout: GitalyClient.fast_timeout)
end end
def has_local_branches? def has_local_branches?
...@@ -189,6 +189,7 @@ module Gitlab ...@@ -189,6 +189,7 @@ module Gitlab
:repository_service, :repository_service,
:fetch_source_branch, :fetch_source_branch,
request, request,
timeout: GitalyClient.default_timeout,
remote_storage: source_repository.storage remote_storage: source_repository.storage
) )
...@@ -197,7 +198,7 @@ module Gitlab ...@@ -197,7 +198,7 @@ module Gitlab
def fsck def fsck
request = Gitaly::FsckRequest.new(repository: @gitaly_repo) request = Gitaly::FsckRequest.new(repository: @gitaly_repo)
response = GitalyClient.call(@storage, :repository_service, :fsck, request, timeout: GitalyClient.no_timeout) response = GitalyClient.call(@storage, :repository_service, :fsck, request, timeout: GitalyClient.long_timeout)
if response.error.empty? if response.error.empty?
return "", 0 return "", 0
...@@ -211,7 +212,7 @@ module Gitlab ...@@ -211,7 +212,7 @@ module Gitlab
save_path, save_path,
:create_bundle, :create_bundle,
Gitaly::CreateBundleRequest, Gitaly::CreateBundleRequest,
GitalyClient.no_timeout GitalyClient.long_timeout
) )
end end
...@@ -229,7 +230,7 @@ module Gitlab ...@@ -229,7 +230,7 @@ module Gitlab
bundle_path, bundle_path,
:create_repository_from_bundle, :create_repository_from_bundle,
Gitaly::CreateRepositoryFromBundleRequest, Gitaly::CreateRepositoryFromBundleRequest,
GitalyClient.no_timeout GitalyClient.long_timeout
) )
end end
...@@ -254,7 +255,7 @@ module Gitlab ...@@ -254,7 +255,7 @@ module Gitlab
:repository_service, :repository_service,
:create_repository_from_snapshot, :create_repository_from_snapshot,
request, request,
timeout: GitalyClient.no_timeout timeout: GitalyClient.long_timeout
) )
end end
...@@ -333,7 +334,7 @@ module Gitlab ...@@ -333,7 +334,7 @@ module Gitlab
def search_files_by_content(ref, query) def search_files_by_content(ref, query)
request = Gitaly::SearchFilesByContentRequest.new(repository: @gitaly_repo, ref: ref, query: query) request = Gitaly::SearchFilesByContentRequest.new(repository: @gitaly_repo, ref: ref, query: query)
response = GitalyClient.call(@storage, :repository_service, :search_files_by_content, request) response = GitalyClient.call(@storage, :repository_service, :search_files_by_content, request, timeout: GitalyClient.default_timeout)
search_results_from_response(response) search_results_from_response(response)
end end
...@@ -343,7 +344,7 @@ module Gitlab ...@@ -343,7 +344,7 @@ module Gitlab
repository: @gitaly_repo repository: @gitaly_repo
) )
GitalyClient.call(@storage, :object_pool_service, :disconnect_git_alternates, request) GitalyClient.call(@storage, :object_pool_service, :disconnect_git_alternates, request, timeout: GitalyClient.long_timeout)
end end
private private
......
...@@ -11,14 +11,14 @@ module Gitlab ...@@ -11,14 +11,14 @@ module Gitlab
def list_directories(depth: 1) def list_directories(depth: 1)
request = Gitaly::ListDirectoriesRequest.new(storage_name: @storage, depth: depth) request = Gitaly::ListDirectoriesRequest.new(storage_name: @storage, depth: depth)
GitalyClient.call(@storage, :storage_service, :list_directories, request) GitalyClient.call(@storage, :storage_service, :list_directories, request, timeout: GitalyClient.medium_timeout)
.flat_map(&:paths) .flat_map(&:paths)
end end
# Delete all repositories in the storage. This is a slow and VERY DESTRUCTIVE operation. # Delete all repositories in the storage. This is a slow and VERY DESTRUCTIVE operation.
def delete_all_repositories def delete_all_repositories
request = Gitaly::DeleteAllRepositoriesRequest.new(storage_name: @storage) request = Gitaly::DeleteAllRepositoriesRequest.new(storage_name: @storage)
GitalyClient.call(@storage, :storage_service, :delete_all_repositories, request) GitalyClient.call(@storage, :storage_service, :delete_all_repositories, request, timeout: GitalyClient.long_timeout)
end end
end end
end end
......
...@@ -34,7 +34,7 @@ module Gitlab ...@@ -34,7 +34,7 @@ module Gitlab
end end
end end
response = GitalyClient.call(@repository.storage, :wiki_service, :wiki_write_page, enum) response = GitalyClient.call(@repository.storage, :wiki_service, :wiki_write_page, enum, timeout: GitalyClient.medium_timeout)
if error = response.duplicate_error.presence if error = response.duplicate_error.presence
raise Gitlab::Git::Wiki::DuplicatePageError, error raise Gitlab::Git::Wiki::DuplicatePageError, error
end end
...@@ -61,7 +61,7 @@ module Gitlab ...@@ -61,7 +61,7 @@ module Gitlab
end end
end end
GitalyClient.call(@repository.storage, :wiki_service, :wiki_update_page, enum) GitalyClient.call(@repository.storage, :wiki_service, :wiki_update_page, enum, timeout: GitalyClient.medium_timeout)
end end
def delete_page(page_path, commit_details) def delete_page(page_path, commit_details)
...@@ -187,7 +187,7 @@ module Gitlab ...@@ -187,7 +187,7 @@ module Gitlab
directory: encode_binary(dir) directory: encode_binary(dir)
) )
response = GitalyClient.call(@repository.storage, :wiki_service, :wiki_get_formatted_data, request) response = GitalyClient.call(@repository.storage, :wiki_service, :wiki_get_formatted_data, request, timeout: GitalyClient.medium_timeout)
response.reduce([]) { |memo, msg| memo << msg.data }.join response.reduce([]) { |memo, msg| memo << msg.data }.join
end end
......
...@@ -17,6 +17,9 @@ module Gitlab ...@@ -17,6 +17,9 @@ module Gitlab
CHECK_INTERVAL_SECONDS = [ENV.fetch('SIDEKIQ_MEMORY_KILLER_CHECK_INTERVAL', 3).to_i, 2].max CHECK_INTERVAL_SECONDS = [ENV.fetch('SIDEKIQ_MEMORY_KILLER_CHECK_INTERVAL', 3).to_i, 2].max
# Give Sidekiq up to 30 seconds to allow existing jobs to finish after exceeding the limit # Give Sidekiq up to 30 seconds to allow existing jobs to finish after exceeding the limit
SHUTDOWN_TIMEOUT_SECONDS = ENV.fetch('SIDEKIQ_MEMORY_KILLER_SHUTDOWN_WAIT', 30).to_i SHUTDOWN_TIMEOUT_SECONDS = ENV.fetch('SIDEKIQ_MEMORY_KILLER_SHUTDOWN_WAIT', 30).to_i
# Developer/admin should always set `memory_killer_max_memory_growth_kb` explicitly
# In case not set, default to 300M. This is for extra-safe.
DEFAULT_MAX_MEMORY_GROWTH_KB = 300_000
def initialize def initialize
super super
...@@ -90,7 +93,7 @@ module Gitlab ...@@ -90,7 +93,7 @@ module Gitlab
def rss_within_range? def rss_within_range?
current_rss = nil current_rss = nil
deadline = Time.now + GRACE_BALLOON_SECONDS.seconds deadline = Gitlab::Metrics::System.monotonic_time + GRACE_BALLOON_SECONDS.seconds
loop do loop do
return true unless enabled? return true unless enabled?
...@@ -103,7 +106,7 @@ module Gitlab ...@@ -103,7 +106,7 @@ module Gitlab
return true if current_rss < soft_limit_rss return true if current_rss < soft_limit_rss
# RSS did not go below the soft limit within deadline, restart # RSS did not go below the soft limit within deadline, restart
break if Time.now > deadline break if Gitlab::Metrics::System.monotonic_time > deadline
sleep(CHECK_INTERVAL_SECONDS) sleep(CHECK_INTERVAL_SECONDS)
end end
...@@ -159,11 +162,11 @@ module Gitlab ...@@ -159,11 +162,11 @@ module Gitlab
) )
Process.kill(signal, pid) Process.kill(signal, pid)
deadline = Time.now + time deadline = Gitlab::Metrics::System.monotonic_time + time
# we try to finish as early as all jobs finished # we try to finish as early as all jobs finished
# so we retest that in loop # so we retest that in loop
sleep(CHECK_INTERVAL_SECONDS) while enabled? && any_jobs? && Time.now < deadline sleep(CHECK_INTERVAL_SECONDS) while enabled? && any_jobs? && Gitlab::Metrics::System.monotonic_time < deadline
end end
def signal_pgroup(signal, explanation) def signal_pgroup(signal, explanation)
...@@ -192,11 +195,11 @@ module Gitlab ...@@ -192,11 +195,11 @@ module Gitlab
def rss_increase_by_job(job) def rss_increase_by_job(job)
memory_growth_kb = get_job_options(job, 'memory_killer_memory_growth_kb', 0).to_i memory_growth_kb = get_job_options(job, 'memory_killer_memory_growth_kb', 0).to_i
max_memory_growth_kb = get_job_options(job, 'memory_killer_max_memory_growth_kb', MAX_MEMORY_KB).to_i max_memory_growth_kb = get_job_options(job, 'memory_killer_max_memory_growth_kb', DEFAULT_MAX_MEMORY_GROWTH_KB).to_i
return 0 if memory_growth_kb.zero? return 0 if memory_growth_kb.zero?
time_elapsed = Time.now.to_i - job[:started_at] time_elapsed = [Gitlab::Metrics::System.monotonic_time - job[:started_at], 0].max
[memory_growth_kb * time_elapsed, max_memory_growth_kb].min [memory_growth_kb * time_elapsed, max_memory_growth_kb].min
end end
......
...@@ -26,7 +26,7 @@ module Gitlab ...@@ -26,7 +26,7 @@ module Gitlab
def within_job(worker_class, jid, queue) def within_job(worker_class, jid, queue)
jobs_mutex.synchronize do jobs_mutex.synchronize do
jobs[jid] = { worker_class: worker_class, thread: Thread.current, started_at: Time.now.to_i } jobs[jid] = { worker_class: worker_class, thread: Thread.current, started_at: Gitlab::Metrics::System.monotonic_time }
end end
if cancelled?(jid) if cancelled?(jid)
......
...@@ -11,6 +11,7 @@ module QA ...@@ -11,6 +11,7 @@ module QA
project = Resource::Project.fabricate_via_api! do |resource| project = Resource::Project.fabricate_via_api! do |resource|
resource.name = 'project-to-test-mention' resource.name = 'project-to-test-mention'
resource.visibility = 'private'
end end
project.visit! project.visit!
......
import { mount } from '@vue/test-utils';
import CollpasibleSection from '~/jobs/components/log/collapsible_section.vue';
import { nestedSectionOpened, nestedSectionClosed } from './mock_data';
describe('Job Log Collapsible Section', () => {
let wrapper;
const traceEndpoint = 'jobs/335';
const findCollapsibleLine = () => wrapper.find('.collapsible-line');
const createComponent = (props = {}) => {
wrapper = mount(CollpasibleSection, {
sync: true,
propsData: {
...props,
},
});
};
afterEach(() => {
wrapper.destroy();
});
describe('with closed nested section', () => {
beforeEach(() => {
createComponent({
section: nestedSectionClosed,
traceEndpoint,
});
});
it('renders clickable header line', () => {
expect(findCollapsibleLine().attributes('role')).toBe('button');
});
});
describe('with opened nested section', () => {
beforeEach(() => {
createComponent({
section: nestedSectionOpened,
traceEndpoint,
});
});
it('renders all sections opened', () => {
expect(wrapper.findAll('.collapsible-line').length).toBe(2);
});
});
it('emits onClickCollapsibleLine on click', () => {
createComponent({
section: nestedSectionOpened,
traceEndpoint,
});
findCollapsibleLine().trigger('click');
expect(wrapper.emitted('onClickCollapsibleLine').length).toBe(1);
});
});
...@@ -150,3 +150,73 @@ export const collapsibleTraceIncremental = [ ...@@ -150,3 +150,73 @@ export const collapsibleTraceIncremental = [
sections: ['section'], sections: ['section'],
}, },
]; ];
export const nestedSectionClosed = {
offset: 5,
section_header: true,
isHeader: true,
isClosed: true,
line: {
content: [{ text: 'foo' }],
sections: ['prepare-script'],
lineNumber: 1,
},
section_duration: '00:03',
lines: [
{
section_header: true,
section_duration: '00:02',
isHeader: true,
isClosed: true,
line: {
offset: 52,
content: [{ text: 'bar' }],
sections: ['prepare-script', 'prepare-script-nested'],
lineNumber: 2,
},
lines: [
{
offset: 80,
content: [{ text: 'this is a collapsible nested section' }],
sections: ['prepare-script', 'prepare-script-nested'],
lineNumber: 3,
},
],
},
],
};
export const nestedSectionOpened = {
offset: 5,
section_header: true,
isHeader: true,
isClosed: false,
line: {
content: [{ text: 'foo' }],
sections: ['prepare-script'],
lineNumber: 1,
},
section_duration: '00:03',
lines: [
{
section_header: true,
section_duration: '00:02',
isHeader: true,
isClosed: false,
line: {
offset: 52,
content: [{ text: 'bar' }],
sections: ['prepare-script', 'prepare-script-nested'],
lineNumber: 2,
},
lines: [
{
offset: 80,
content: [{ text: 'this is a collapsible nested section' }],
sections: ['prepare-script', 'prepare-script-nested'],
lineNumber: 3,
},
],
},
],
};
...@@ -182,24 +182,24 @@ describe Gitlab::GitalyClient do ...@@ -182,24 +182,24 @@ describe Gitlab::GitalyClient do
end end
it 'sets the gitaly-session-id in the metadata' do it 'sets the gitaly-session-id in the metadata' do
results = described_class.request_kwargs('default', nil) results = described_class.request_kwargs('default', timeout: 1)
expect(results[:metadata]).to include('gitaly-session-id') expect(results[:metadata]).to include('gitaly-session-id')
end end
context 'when RequestStore is not enabled' do context 'when RequestStore is not enabled' do
it 'sets a different gitaly-session-id per request' do it 'sets a different gitaly-session-id per request' do
gitaly_session_id = described_class.request_kwargs('default', nil)[:metadata]['gitaly-session-id'] gitaly_session_id = described_class.request_kwargs('default', timeout: 1)[:metadata]['gitaly-session-id']
expect(described_class.request_kwargs('default', nil)[:metadata]['gitaly-session-id']).not_to eq(gitaly_session_id) expect(described_class.request_kwargs('default', timeout: 1)[:metadata]['gitaly-session-id']).not_to eq(gitaly_session_id)
end end
end end
context 'when RequestStore is enabled', :request_store do context 'when RequestStore is enabled', :request_store do
it 'sets the same gitaly-session-id on every outgoing request metadata' do it 'sets the same gitaly-session-id on every outgoing request metadata' do
gitaly_session_id = described_class.request_kwargs('default', nil)[:metadata]['gitaly-session-id'] gitaly_session_id = described_class.request_kwargs('default', timeout: 1)[:metadata]['gitaly-session-id']
3.times do 3.times do
expect(described_class.request_kwargs('default', nil)[:metadata]['gitaly-session-id']).to eq(gitaly_session_id) expect(described_class.request_kwargs('default', timeout: 1)[:metadata]['gitaly-session-id']).to eq(gitaly_session_id)
end end
end end
end end
......
...@@ -75,12 +75,6 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -75,12 +75,6 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
end end
end end
it 'invoke rss_within_range? twice' do
expect(memory_killer).to receive(:rss_within_range?).twice
subject
end
it 'not invoke restart_sidekiq when rss in range' do it 'not invoke restart_sidekiq when rss in range' do
expect(memory_killer).to receive(:rss_within_range?).twice.and_return(true) expect(memory_killer).to receive(:rss_within_range?).twice.and_return(true)
...@@ -128,7 +122,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -128,7 +122,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
expect(memory_killer).to receive(:soft_limit_rss).and_return(200) expect(memory_killer).to receive(:soft_limit_rss).and_return(200)
expect(memory_killer).to receive(:hard_limit_rss).and_return(300) expect(memory_killer).to receive(:hard_limit_rss).and_return(300)
expect(Time).to receive(:now).and_call_original expect(Gitlab::Metrics::System).to receive(:monotonic_time).and_call_original
expect(memory_killer).not_to receive(:log_rss_out_of_range) expect(memory_killer).not_to receive(:log_rss_out_of_range)
expect(subject).to be true expect(subject).to be true
...@@ -139,7 +133,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -139,7 +133,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
expect(memory_killer).to receive(:soft_limit_rss).at_least(:once).and_return(200) expect(memory_killer).to receive(:soft_limit_rss).at_least(:once).and_return(200)
expect(memory_killer).to receive(:hard_limit_rss).at_least(:once).and_return(300) expect(memory_killer).to receive(:hard_limit_rss).at_least(:once).and_return(300)
expect(Time).to receive(:now).and_call_original expect(Gitlab::Metrics::System).to receive(:monotonic_time).and_call_original
expect(memory_killer).to receive(:log_rss_out_of_range).with(400, 300, 200) expect(memory_killer).to receive(:log_rss_out_of_range).with(400, 300, 200)
...@@ -151,7 +145,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -151,7 +145,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
expect(memory_killer).to receive(:soft_limit_rss).at_least(:once).and_return(200) expect(memory_killer).to receive(:soft_limit_rss).at_least(:once).and_return(200)
expect(memory_killer).to receive(:hard_limit_rss).at_least(:once).and_return(300) expect(memory_killer).to receive(:hard_limit_rss).at_least(:once).and_return(300)
expect(Time).to receive(:now).twice.and_call_original expect(Gitlab::Metrics::System).to receive(:monotonic_time).twice.and_call_original
expect(memory_killer).to receive(:sleep).with(check_interval_seconds) expect(memory_killer).to receive(:sleep).with(check_interval_seconds)
expect(memory_killer).to receive(:log_rss_out_of_range).with(400, 300, 200) expect(memory_killer).to receive(:log_rss_out_of_range).with(400, 300, 200)
...@@ -164,7 +158,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -164,7 +158,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
expect(memory_killer).to receive(:soft_limit_rss).and_return(200, 200) expect(memory_killer).to receive(:soft_limit_rss).and_return(200, 200)
expect(memory_killer).to receive(:hard_limit_rss).and_return(300, 300) expect(memory_killer).to receive(:hard_limit_rss).and_return(300, 300)
expect(Time).to receive(:now).twice.and_call_original expect(Gitlab::Metrics::System).to receive(:monotonic_time).twice.and_call_original
expect(memory_killer).to receive(:sleep).with(check_interval_seconds) expect(memory_killer).to receive(:sleep).with(check_interval_seconds)
expect(memory_killer).not_to receive(:log_rss_out_of_range) expect(memory_killer).not_to receive(:log_rss_out_of_range)
...@@ -177,7 +171,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -177,7 +171,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
expect(memory_killer).to receive(:soft_limit_rss).exactly(5).times.and_return(200) expect(memory_killer).to receive(:soft_limit_rss).exactly(5).times.and_return(200)
expect(memory_killer).to receive(:hard_limit_rss).exactly(5).times.and_return(300) expect(memory_killer).to receive(:hard_limit_rss).exactly(5).times.and_return(300)
expect(Time).to receive(:now).exactly(5).times.and_call_original expect(Gitlab::Metrics::System).to receive(:monotonic_time).exactly(5).times.and_call_original
expect(memory_killer).to receive(:sleep).exactly(3).times.with(check_interval_seconds).and_call_original expect(memory_killer).to receive(:sleep).exactly(3).times.with(check_interval_seconds).and_call_original
expect(memory_killer).to receive(:log_rss_out_of_range).with(250, 300, 200) expect(memory_killer).to receive(:log_rss_out_of_range).with(250, 300, 200)
...@@ -219,7 +213,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -219,7 +213,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
it 'send signal and return when all jobs finished' do it 'send signal and return when all jobs finished' do
expect(Process).to receive(:kill).with(signal, pid).ordered expect(Process).to receive(:kill).with(signal, pid).ordered
expect(Time).to receive(:now).and_call_original expect(Gitlab::Metrics::System).to receive(:monotonic_time).and_call_original
expect(memory_killer).to receive(:enabled?).and_return(true) expect(memory_killer).to receive(:enabled?).and_return(true)
expect(memory_killer).to receive(:any_jobs?).and_return(false) expect(memory_killer).to receive(:any_jobs?).and_return(false)
...@@ -231,7 +225,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -231,7 +225,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
it 'send signal and wait till deadline if any job not finished' do it 'send signal and wait till deadline if any job not finished' do
expect(Process).to receive(:kill).with(signal, pid).ordered expect(Process).to receive(:kill).with(signal, pid).ordered
expect(Time).to receive(:now).and_call_original.at_least(:once) expect(Gitlab::Metrics::System).to receive(:monotonic_time).and_call_original.at_least(:once)
expect(memory_killer).to receive(:enabled?).and_return(true).at_least(:once) expect(memory_killer).to receive(:enabled?).and_return(true).at_least(:once)
expect(memory_killer).to receive(:any_jobs?).and_return(true).at_least(:once) expect(memory_killer).to receive(:any_jobs?).and_return(true).at_least(:once)
...@@ -351,7 +345,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -351,7 +345,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
subject { memory_killer.send(:rss_increase_by_job, job) } subject { memory_killer.send(:rss_increase_by_job, job) }
before do before do
stub_const("#{described_class}::MAX_MEMORY_KB", max_memory_kb) stub_const("#{described_class}::DEFAULT_MAX_MEMORY_GROWTH_KB", max_memory_kb)
end end
it 'return 0 if memory_growth_kb return 0' do it 'return 0 if memory_growth_kb return 0' do
...@@ -366,7 +360,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -366,7 +360,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
expect(memory_killer).to receive(:get_job_options).with(job, 'memory_killer_memory_growth_kb', 0).and_return(10) expect(memory_killer).to receive(:get_job_options).with(job, 'memory_killer_memory_growth_kb', 0).and_return(10)
expect(memory_killer).to receive(:get_job_options).with(job, 'memory_killer_max_memory_growth_kb', max_memory_kb).and_return(100) expect(memory_killer).to receive(:get_job_options).with(job, 'memory_killer_max_memory_growth_kb', max_memory_kb).and_return(100)
expect(Time).to receive(:now).and_return(323) expect(Gitlab::Metrics::System).to receive(:monotonic_time).and_return(323)
expect(subject).to eq(20) expect(subject).to eq(20)
end end
...@@ -374,7 +368,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do ...@@ -374,7 +368,7 @@ describe Gitlab::SidekiqDaemon::MemoryKiller do
expect(memory_killer).to receive(:get_job_options).with(job, 'memory_killer_memory_growth_kb', 0).and_return(10) expect(memory_killer).to receive(:get_job_options).with(job, 'memory_killer_memory_growth_kb', 0).and_return(10)
expect(memory_killer).to receive(:get_job_options).with(job, 'memory_killer_max_memory_growth_kb', max_memory_kb).and_return(100) expect(memory_killer).to receive(:get_job_options).with(job, 'memory_killer_max_memory_growth_kb', max_memory_kb).and_return(100)
expect(Time).to receive(:now).and_return(332) expect(Gitlab::Metrics::System).to receive(:monotonic_time).and_return(332)
expect(subject).to eq(100) expect(subject).to eq(100)
end end
end end
......
...@@ -16,7 +16,9 @@ describe ObjectPool::DestroyWorker do ...@@ -16,7 +16,9 @@ describe ObjectPool::DestroyWorker do
subject { described_class.new } subject { described_class.new }
it 'requests Gitaly to remove the object pool' do it 'requests Gitaly to remove the object pool' do
expect(Gitlab::GitalyClient).to receive(:call).with(pool.shard_name, :object_pool_service, :delete_object_pool, Object) expect(Gitlab::GitalyClient).to receive(:call)
.with(pool.shard_name, :object_pool_service, :delete_object_pool,
Object, timeout: Gitlab::GitalyClient.long_timeout)
subject.perform(pool.id) subject.perform(pool.id)
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment