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
8c9dc985
Commit
8c9dc985
authored
Feb 12, 2020
by
GitLab Bot
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add latest changes from gitlab-org/gitlab@master
parent
500626a5
Changes
45
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
45 changed files
with
774 additions
and
139 deletions
+774
-139
app/assets/javascripts/diffs/components/diff_line_gutter_content.vue
...javascripts/diffs/components/diff_line_gutter_content.vue
+4
-1
app/assets/javascripts/lib/utils/common_utils.js
app/assets/javascripts/lib/utils/common_utils.js
+4
-1
app/models/ci/bridge.rb
app/models/ci/bridge.rb
+0
-1
app/models/ci/build.rb
app/models/ci/build.rb
+0
-1
app/models/ci/processable.rb
app/models/ci/processable.rb
+19
-0
app/models/clusters/applications/elastic_stack.rb
app/models/clusters/applications/elastic_stack.rb
+13
-2
app/services/ci/retry_build_service.rb
app/services/ci/retry_build_service.rb
+5
-4
app/views/shared/boards/components/_board.html.haml
app/views/shared/boards/components/_board.html.haml
+1
-1
changelogs/unreleased/24020-copy-markdown-from-comments.yml
changelogs/unreleased/24020-copy-markdown-from-comments.yml
+5
-0
changelogs/unreleased/30235-support-allow-failure-for-ci-rules.yml
...s/unreleased/30235-support-allow-failure-for-ci-rules.yml
+5
-0
changelogs/unreleased/ak-wait-for-green-es.yml
changelogs/unreleased/ak-wait-for-green-es.yml
+5
-0
changelogs/unreleased/jdb-minimal-merge-ref-diff.yml
changelogs/unreleased/jdb-minimal-merge-ref-diff.yml
+5
-0
changelogs/unreleased/ss-fix-text-truncated-on-board-list.yml
...gelogs/unreleased/ss-fix-text-truncated-on-board-list.yml
+5
-0
db/fixtures/development/14_pipelines.rb
db/fixtures/development/14_pipelines.rb
+3
-2
db/migrate/20191223124940_add_scheduling_type_to_ci_builds.rb
...igrate/20191223124940_add_scheduling_type_to_ci_builds.rb
+11
-0
db/schema.rb
db/schema.rb
+1
-0
doc/ci/yaml/README.md
doc/ci/yaml/README.md
+21
-1
doc/user/clusters/applications.md
doc/user/clusters/applications.md
+2
-2
doc/user/group/index.md
doc/user/group/index.md
+2
-1
lib/gitlab/ci/build/rules.rb
lib/gitlab/ci/build/rules.rb
+5
-3
lib/gitlab/ci/config/entry/bridge.rb
lib/gitlab/ci/config/entry/bridge.rb
+2
-1
lib/gitlab/ci/config/entry/job.rb
lib/gitlab/ci/config/entry/job.rb
+2
-1
lib/gitlab/ci/config/entry/rules/rule.rb
lib/gitlab/ci/config/entry/rules/rule.rb
+3
-2
lib/gitlab/ci/yaml_processor.rb
lib/gitlab/ci/yaml_processor.rb
+1
-0
spec/factories/ci/bridge.rb
spec/factories/ci/bridge.rb
+1
-0
spec/factories/ci/builds.rb
spec/factories/ci/builds.rb
+1
-0
spec/frontend/diffs/components/diff_line_gutter_content_spec.js
...rontend/diffs/components/diff_line_gutter_content_spec.js
+160
-70
spec/javascripts/behaviors/shortcuts/shortcuts_issuable_spec.js
...avascripts/behaviors/shortcuts/shortcuts_issuable_spec.js
+14
-0
spec/lib/gitlab/ci/build/rules_spec.rb
spec/lib/gitlab/ci/build/rules_spec.rb
+48
-2
spec/lib/gitlab/ci/config/entry/bridge_spec.rb
spec/lib/gitlab/ci/config/entry/bridge_spec.rb
+4
-2
spec/lib/gitlab/ci/config/entry/job_spec.rb
spec/lib/gitlab/ci/config/entry/job_spec.rb
+6
-1
spec/lib/gitlab/ci/config/entry/jobs_spec.rb
spec/lib/gitlab/ci/config/entry/jobs_spec.rb
+4
-2
spec/lib/gitlab/ci/config/entry/root_spec.rb
spec/lib/gitlab/ci/config/entry/root_spec.rb
+10
-5
spec/lib/gitlab/ci/config/entry/rules/rule_spec.rb
spec/lib/gitlab/ci/config/entry/rules/rule_spec.rb
+42
-3
spec/lib/gitlab/ci/pipeline/seed/build_spec.rb
spec/lib/gitlab/ci/pipeline/seed/build_spec.rb
+4
-2
spec/lib/gitlab/ci/pipeline/seed/stage_spec.rb
spec/lib/gitlab/ci/pipeline/seed/stage_spec.rb
+3
-3
spec/lib/gitlab/ci/yaml_processor_spec.rb
spec/lib/gitlab/ci/yaml_processor_spec.rb
+36
-17
spec/lib/gitlab/import_export/safe_model_attributes.yml
spec/lib/gitlab/import_export/safe_model_attributes.yml
+1
-0
spec/models/ci/build_spec.rb
spec/models/ci/build_spec.rb
+2
-1
spec/models/ci/processable_spec.rb
spec/models/ci/processable_spec.rb
+68
-0
spec/services/ci/create_pipeline_service/needs_spec.rb
spec/services/ci/create_pipeline_service/needs_spec.rb
+4
-0
spec/services/ci/create_pipeline_service_spec.rb
spec/services/ci/create_pipeline_service_spec.rb
+196
-6
spec/services/ci/retry_build_service_spec.rb
spec/services/ci/retry_build_service_spec.rb
+22
-0
vendor/elastic_stack/values.yaml
vendor/elastic_stack/values.yaml
+1
-1
vendor/elastic_stack/wait-for-elasticsearch.sh
vendor/elastic_stack/wait-for-elasticsearch.sh
+23
-0
No files found.
app/assets/javascripts/diffs/components/diff_line_gutter_content.vue
View file @
8c9dc985
<
script
>
import
{
mapState
,
mapGetters
,
mapActions
}
from
'
vuex
'
;
import
{
getParameterByName
,
parseBoolean
}
from
'
~/lib/utils/common_utils
'
;
import
Icon
from
'
~/vue_shared/components/icon.vue
'
;
import
DiffGutterAvatars
from
'
./diff_gutter_avatars.vue
'
;
import
{
LINE_POSITION_RIGHT
}
from
'
../constants
'
;
...
...
@@ -98,7 +99,8 @@ export default {
return
this
.
showCommentButton
&&
this
.
hasDiscussions
;
},
shouldRenderCommentButton
()
{
return
this
.
isLoggedIn
&&
this
.
showCommentButton
;
const
isDiffHead
=
parseBoolean
(
getParameterByName
(
'
diff_head
'
));
return
!
isDiffHead
&&
this
.
isLoggedIn
&&
this
.
showCommentButton
;
},
},
methods
:
{
...
...
@@ -130,6 +132,7 @@ export default {
</button>
<a
v-if=
"lineNumber"
ref=
"lineNumberRef"
:data-linenumber=
"lineNumber"
:href=
"lineHref"
@
click=
"setHighlightedRow(lineCode)"
...
...
app/assets/javascripts/lib/utils/common_utils.js
View file @
8c9dc985
...
...
@@ -327,7 +327,10 @@ export const getSelectedFragment = restrictToNode => {
documentFragment
.
originalNodes
.
push
(
range
.
commonAncestorContainer
);
}
}
if
(
documentFragment
.
textContent
.
length
===
0
)
return
null
;
if
(
documentFragment
.
textContent
.
length
===
0
&&
documentFragment
.
children
.
length
===
0
)
{
return
null
;
}
return
documentFragment
;
};
...
...
app/models/ci/bridge.rb
View file @
8c9dc985
...
...
@@ -8,7 +8,6 @@ module Ci
include
Importable
include
AfterCommitQueue
include
HasRef
include
Gitlab
::
Utils
::
StrongMemoize
InvalidBridgeTypeError
=
Class
.
new
(
StandardError
)
...
...
app/models/ci/build.rb
View file @
8c9dc985
...
...
@@ -10,7 +10,6 @@ module Ci
include
ObjectStorage
::
BackgroundMove
include
Presentable
include
Importable
include
Gitlab
::
Utils
::
StrongMemoize
include
HasRef
include
IgnorableColumns
...
...
app/models/ci/processable.rb
View file @
8c9dc985
...
...
@@ -2,10 +2,14 @@
module
Ci
class
Processable
<
::
CommitStatus
include
Gitlab
::
Utils
::
StrongMemoize
has_many
:needs
,
class_name:
'Ci::BuildNeed'
,
foreign_key: :build_id
,
inverse_of: :build
accepts_nested_attributes_for
:needs
enum
scheduling_type:
{
stage:
0
,
dag:
1
},
_prefix:
true
scope
:preload_needs
,
->
{
preload
(
:needs
)
}
def
self
.
select_with_aggregated_needs
(
project
)
...
...
@@ -23,6 +27,7 @@ module Ci
end
validates
:type
,
presence:
true
validates
:scheduling_type
,
presence:
true
,
on: :create
,
if: :validate_scheduling_type?
def
aggregated_needs_names
read_attribute
(
:aggregated_needs_names
)
...
...
@@ -47,5 +52,19 @@ module Ci
def
scoped_variables_hash
raise
NotImplementedError
end
# scheduling_type column of previous builds/bridges have not been populated,
# so we calculate this value on runtime when we need it.
def
find_legacy_scheduling_type
strong_memoize
(
:find_legacy_scheduling_type
)
do
needs
.
exists?
?
:dag
:
:stage
end
end
private
def
validate_scheduling_type?
!
importing?
&&
Feature
.
enabled?
(
:validate_scheduling_type_of_processables
,
project
)
end
end
end
app/models/clusters/applications/elastic_stack.rb
View file @
8c9dc985
...
...
@@ -30,7 +30,8 @@ module Clusters
version:
VERSION
,
rbac:
cluster
.
platform_kubernetes_rbac?
,
chart:
chart
,
files:
files
files:
files
,
postinstall:
post_install_script
)
end
...
...
@@ -43,6 +44,10 @@ module Clusters
)
end
def
files
super
.
merge
(
'wait-for-elasticsearch.sh'
:
File
.
read
(
"
#{
Rails
.
root
}
/vendor/elastic_stack/wait-for-elasticsearch.sh"
))
end
def
elasticsearch_client
strong_memoize
(
:elasticsearch_client
)
do
next
unless
kube_client
...
...
@@ -69,10 +74,16 @@ module Clusters
private
def
post_install_script
[
"timeout -t60 sh /data/helm/elastic-stack/config/wait-for-elasticsearch.sh http://elastic-stack-elasticsearch-client:9200"
]
end
def
post_delete_script
[
Gitlab
::
Kubernetes
::
KubectlCmd
.
delete
(
"pvc"
,
"--selector"
,
"release=elastic-stack"
)
]
.
compact
]
end
def
kube_client
...
...
app/services/ci/retry_build_service.rb
View file @
8c9dc985
...
...
@@ -5,7 +5,7 @@ module Ci
CLONE_ACCESSORS
=
%i[pipeline project ref tag options name
allow_failure stage stage_id stage_idx trigger_request
yaml_variables when environment coverage_regex
description tag_list protected needs resource_group]
.
freeze
description tag_list protected needs resource_group
scheduling_type
]
.
freeze
def
execute
(
build
)
reprocess!
(
build
).
tap
do
|
new_build
|
...
...
@@ -27,9 +27,10 @@ module Ci
attributes
=
CLONE_ACCESSORS
.
map
do
|
attribute
|
[
attribute
,
build
.
public_send
(
attribute
)]
# rubocop:disable GitlabSecurity/PublicSend
end
end
.
to_h
attributes
.
push
([
:user
,
current_user
])
attributes
[
:user
]
=
current_user
attributes
[
:scheduling_type
]
||=
build
.
find_legacy_scheduling_type
Ci
::
Build
.
transaction
do
# mark all other builds of that name as retried
...
...
@@ -49,7 +50,7 @@ module Ci
private
def
create_build!
(
attributes
)
build
=
project
.
builds
.
new
(
Hash
[
attributes
]
)
build
=
project
.
builds
.
new
(
attributes
)
build
.
deployment
=
::
Gitlab
::
Ci
::
Pipeline
::
Seed
::
Deployment
.
new
(
build
).
to_resource
build
.
retried
=
false
build
.
save!
...
...
app/views/shared/boards/components/_board.html.haml
View file @
8c9dc985
...
...
@@ -29,7 +29,7 @@
":title"
=>
'(list.assignee && list.assignee.username || "")'
}
@{{ list.assignee.username }}
%span
.has-tooltip.badge.color-label.title
{
"v-if"
:
"list.type ===
\"
label
\"
"
,
%span
.has-tooltip.badge.color-label.title
.d-inline-block.mw-100.text-truncate.align-middle
{
"v-if"
:
"list.type ===
\"
label
\"
"
,
":title"
=>
'(list.label ? list.label.description : "")'
,
data:
{
container:
"body"
,
placement:
"bottom"
},
":style"
=>
"{ backgroundColor: (list.label && list.label.color ? list.label.color : null), color: (list.label && list.label.textColor ? list.label.textColor :
\"
#2e2e2e
\"
) }"
}
...
...
changelogs/unreleased/24020-copy-markdown-from-comments.yml
0 → 100644
View file @
8c9dc985
---
title
:
Fix copy markdown with elements with no text content
merge_request
:
24020
author
:
type
:
fixed
changelogs/unreleased/30235-support-allow-failure-for-ci-rules.yml
0 → 100644
View file @
8c9dc985
---
title
:
Implement support of allow_failure keyword for CI rules
merge_request
:
24605
author
:
type
:
added
changelogs/unreleased/ak-wait-for-green-es.yml
0 → 100644
View file @
8c9dc985
---
title
:
Wait for elasticsearch to be green on install
merge_request
:
24489
author
:
type
:
added
changelogs/unreleased/jdb-minimal-merge-ref-diff.yml
0 → 100644
View file @
8c9dc985
---
title
:
Hide comment button if on diff HEAD
merge_request
:
24207
author
:
type
:
changed
changelogs/unreleased/ss-fix-text-truncated-on-board-list.yml
0 → 100644
View file @
8c9dc985
---
title
:
Add styles for board list labels when text is too long
merge_request
:
24627
author
:
type
:
fixed
db/fixtures/development/14_pipelines.rb
View file @
8c9dc985
...
...
@@ -165,9 +165,10 @@ class Gitlab::Seeder::Pipelines
end
def
job_attributes
(
pipeline
,
opts
)
{
name:
'test build'
,
stage:
'test'
,
stage_idx:
stage_index
(
opts
[
:stage
]),
{
name:
'test build'
,
stage:
'test'
,
stage_idx:
stage_index
(
opts
[
:stage
]),
ref:
pipeline
.
ref
,
tag:
false
,
user:
build_user
,
project:
@project
,
pipeline:
pipeline
,
created_at:
Time
.
now
,
updated_at:
Time
.
now
scheduling_type: :stage
,
created_at:
Time
.
now
,
updated_at:
Time
.
now
}.
merge
(
opts
)
end
...
...
db/migrate/20191223124940_add_scheduling_type_to_ci_builds.rb
0 → 100644
View file @
8c9dc985
# frozen_string_literal: true
class
AddSchedulingTypeToCiBuilds
<
ActiveRecord
::
Migration
[
5.2
]
include
Gitlab
::
Database
::
MigrationHelpers
DOWNTIME
=
false
def
change
add_column
:ci_builds
,
:scheduling_type
,
:integer
,
limit:
2
end
end
db/schema.rb
View file @
8c9dc985
...
...
@@ -677,6 +677,7 @@ ActiveRecord::Schema.define(version: 2020_02_11_152410) do
t
.
bigint
"resource_group_id"
t
.
datetime_with_timezone
"waiting_for_resource_at"
t
.
boolean
"processed"
t
.
integer
"scheduling_type"
,
limit:
2
t
.
index
[
"artifacts_expire_at"
],
name:
"index_ci_builds_on_artifacts_expire_at"
,
where:
"(artifacts_file <> ''::text)"
t
.
index
[
"auto_canceled_by_id"
],
name:
"index_ci_builds_on_auto_canceled_by_id"
t
.
index
[
"commit_id"
,
"artifacts_expire_at"
,
"id"
],
name:
"index_ci_builds_on_commit_id_and_artifacts_expireatandidpartial"
,
where:
"(((type)::text = 'Ci::Build'::text) AND ((retried = false) OR (retried IS NULL)) AND ((name)::text = ANY (ARRAY[('sast'::character varying)::text, ('dependency_scanning'::character varying)::text, ('sast:container'::character varying)::text, ('container_scanning'::character varying)::text, ('dast'::character varying)::text])))"
...
...
doc/ci/yaml/README.md
View file @
8c9dc985
...
...
@@ -851,7 +851,7 @@ In this example, if the first rule:
-
Matches, the job will be given the
`when:always`
attribute.
-
Does not match, the second and third rules will be evaluated sequentially
until a match is found. That is, the job will be given either the:
-
`when: manual`
attribute if the second rule matches.
-
`when: manual`
attribute if the second rule matches.
**The stage will not complete until this manual job is triggered and completes successfully.**
-
`when: on_success`
attribute if the second rule does not match. The third
rule will always match when reached because it has no conditional clauses.
...
...
@@ -937,6 +937,25 @@ NOTE: **Note:**
For performance reasons, using
`exists`
with patterns is limited to 10000
checks. After the 10000th check, rules with patterned globs will always match.
#### `rules:allow_failure`
> [Introduced](https://gitlab.com/gitlab-org/gitlab/issues/30235) in GitLab 12.8.
You can use
[
`allow_failure: true`
](
#allow_failure
)
within
`rules:`
to allow a job to fail, or a manual job to
wait for action, without stopping the pipeline itself. All jobs using
`rules:`
default to
`allow_failure: false`
if
`allow_failure:`
is not defined.
```
yaml
job
:
script
:
"
echo
Hello,
Rules!"
rules
:
-
if
:
'
$CI_MERGE_REQUEST_TARGET_BRANCH_NAME
==
"master"'
when
:
manual
allow_failure
:
true
```
In this example, if the first rule matches, then the job will have
`when: manual`
and
`allow_failure: true`
.
#### Complex rule clauses
To conjoin
`if`
,
`changes`
, and
`exists`
clauses with an AND, use them in the
...
...
@@ -976,6 +995,7 @@ The only job attributes currently set by `rules` are:
-
`when`
.
-
`start_in`
, if
`when`
is set to
`delayed`
.
-
`allow_failure`
.
A job will be included in a pipeline if
`when`
is evaluated to any value
except
`never`
.
...
...
doc/user/clusters/applications.md
View file @
8c9dc985
...
...
@@ -464,8 +464,8 @@ chart is used to install this application with a
file.
NOTE:
**Note:**
The chart will deploy
4 Elasticsearch nodes: 2 masters, 1
data and 1 client node,
with resource requests totalling 0.1
CPU and 3
GB RAM. Each data node requests 1.5GB of memory,
The chart will deploy
5 Elasticsearch nodes: 2 masters, 2
data and 1 client node,
with resource requests totalling 0.1
25 CPU and 4.5
GB RAM. Each data node requests 1.5GB of memory,
which makes it incompatible with clusters of
`f1-micro`
and
`g1-small`
instance types.
## Install using GitLab CI (alpha)
...
...
doc/user/group/index.md
View file @
8c9dc985
...
...
@@ -241,9 +241,10 @@ and give all group members access to the project at once.
Alternatively, you can
[
lock the sharing with group feature
](
#share-with-group-lock
)
.
## Sharing a group with another group
## Sharing a group with another group
**(CORE ONLY)**
> [Introduced](https://gitlab.com/gitlab-org/gitlab/issues/18328) in GitLab 12.7.
> This feature has been [disabled on GitLab.com](https://gitlab.com/gitlab-com/gl-infra/production/issues/1635).
Similarly to
[
sharing a project with a group
](
#sharing-a-project-with-a-group
)
,
you can share a group with another group to give direct group members access
...
...
lib/gitlab/ci/build/rules.rb
View file @
8c9dc985
...
...
@@ -6,11 +6,12 @@ module Gitlab
class
Rules
include
::
Gitlab
::
Utils
::
StrongMemoize
Result
=
Struct
.
new
(
:when
,
:start_in
)
do
Result
=
Struct
.
new
(
:when
,
:start_in
,
:allow_failure
)
do
def
build_attributes
{
when:
self
.
when
,
options:
{
start_in:
start_in
}.
compact
options:
{
start_in:
start_in
}.
compact
,
allow_failure:
allow_failure
}.
compact
end
...
...
@@ -30,7 +31,8 @@ module Gitlab
elsif
matched_rule
=
match_rule
(
pipeline
,
context
)
Result
.
new
(
matched_rule
.
attributes
[
:when
]
||
@default_when
,
matched_rule
.
attributes
[
:start_in
]
matched_rule
.
attributes
[
:start_in
],
matched_rule
.
attributes
[
:allow_failure
]
)
else
Result
.
new
(
'never'
)
...
...
lib/gitlab/ci/config/entry/bridge.rb
View file @
8c9dc985
...
...
@@ -132,7 +132,8 @@ module Gitlab
variables:
(
variables_value
if
variables_defined?
),
rules:
(
rules_value
if
has_rules?
),
only:
only_value
,
except:
except_value
}.
compact
except:
except_value
,
scheduling_type:
needs_defined?
&&
!
bridge_needs
?
:dag
:
:stage
}.
compact
end
def
bridge_needs
...
...
lib/gitlab/ci/config/entry/job.rb
View file @
8c9dc985
...
...
@@ -258,7 +258,8 @@ module Gitlab
after_script:
after_script_value
,
ignore:
ignored?
,
needs:
needs_defined?
?
needs_value
:
nil
,
resource_group:
resource_group
}
resource_group:
resource_group
,
scheduling_type:
needs_defined?
?
:dag
:
:stage
}
end
end
end
...
...
lib/gitlab/ci/config/entry/rules/rule.rb
View file @
8c9dc985
...
...
@@ -9,10 +9,10 @@ module Gitlab
include
::
Gitlab
::
Config
::
Entry
::
Attributable
CLAUSES
=
%i[if changes exists]
.
freeze
ALLOWED_KEYS
=
%i[if changes exists when start_in]
.
freeze
ALLOWED_KEYS
=
%i[if changes exists when start_in
allow_failure
]
.
freeze
ALLOWABLE_WHEN
=
%w[on_success on_failure always never manual delayed]
.
freeze
attributes
:if
,
:changes
,
:exists
,
:when
,
:start_in
attributes
:if
,
:changes
,
:exists
,
:when
,
:start_in
,
:allow_failure
validations
do
validates
:config
,
presence:
true
...
...
@@ -26,6 +26,7 @@ module Gitlab
validates
:if
,
expression:
true
validates
:changes
,
:exists
,
array_of_strings:
true
,
length:
{
maximum:
50
}
validates
:when
,
allowed_values:
{
in:
ALLOWABLE_WHEN
}
validates
:allow_failure
,
boolean:
true
end
validate
do
...
...
lib/gitlab/ci/yaml_processor.rb
View file @
8c9dc985
...
...
@@ -65,6 +65,7 @@ module Gitlab
rules:
job
[
:rules
],
cache:
job
[
:cache
],
resource_group_key:
job
[
:resource_group
],
scheduling_type:
job
[
:scheduling_type
],
options:
{
image:
job
[
:image
],
services:
job
[
:services
],
...
...
spec/factories/ci/bridge.rb
View file @
8c9dc985
...
...
@@ -9,6 +9,7 @@ FactoryBot.define do
tag
{
false
}
created_at
{
'Di 29. Okt 09:50:00 CET 2013'
}
status
{
:created
}
scheduling_type
{
'stage'
}
pipeline
factory: :ci_pipeline
...
...
spec/factories/ci/builds.rb
View file @
8c9dc985
...
...
@@ -11,6 +11,7 @@ FactoryBot.define do
tag
{
false
}
add_attribute
(
:protected
)
{
false
}
created_at
{
'Di 29. Okt 09:50:00 CET 2013'
}
scheduling_type
{
'stage'
}
pending
options
do
...
...
spec/frontend/diffs/components/diff_line_gutter_content_spec.js
View file @
8c9dc985
This diff is collapsed.
Click to expand it.
spec/javascripts/behaviors/shortcuts/shortcuts_issuable_spec.js
View file @
8c9dc985
...
...
@@ -52,6 +52,7 @@ describe('ShortcutsIssuable', function() {
return
documentFragment
;
});
};
describe
(
'
with empty selection
'
,
()
=>
{
it
(
'
does not return an error
'
,
()
=>
{
ShortcutsIssuable
.
replyWithSelectedText
(
true
);
...
...
@@ -297,5 +298,18 @@ describe('ShortcutsIssuable', function() {
});
});
});
describe
(
'
with a valid selection with no text content
'
,
()
=>
{
it
(
'
returns the proper markdown
'
,
done
=>
{
stubSelection
(
'
<img src="foo" alt="image" />
'
);
ShortcutsIssuable
.
replyWithSelectedText
(
true
);
setTimeout
(()
=>
{
expect
(
$
(
FORM_SELECTOR
).
val
()).
toBe
(
'
> ![image](http://localhost:9876/foo)
\n\n
'
);
done
();
});
});
});
});
});
spec/lib/gitlab/ci/build/rules_spec.rb
View file @
8c9dc985
...
...
@@ -102,9 +102,9 @@ describe Gitlab::Ci::Build::Rules do
end
context
'with one rule without any clauses'
do
let
(
:rule_list
)
{
[{
when:
'manual'
}]
}
let
(
:rule_list
)
{
[{
when:
'manual'
,
allow_failure:
true
}]
}
it
{
is_expected
.
to
eq
(
described_class
::
Result
.
new
(
'manual'
))
}
it
{
is_expected
.
to
eq
(
described_class
::
Result
.
new
(
'manual'
,
nil
,
true
))
}
end
context
'with one matching rule'
do
...
...
@@ -166,5 +166,51 @@ describe Gitlab::Ci::Build::Rules do
end
end
end
context
'with only allow_failure'
do
context
'with matching rule'
do
let
(
:rule_list
)
{
[{
if:
'$VAR == null'
,
allow_failure:
true
}]
}
it
{
is_expected
.
to
eq
(
described_class
::
Result
.
new
(
'on_success'
,
nil
,
true
))
}
end
context
'with non-matching rule'
do
let
(
:rule_list
)
{
[{
if:
'$VAR != null'
,
allow_failure:
true
}]
}
it
{
is_expected
.
to
eq
(
described_class
::
Result
.
new
(
'never'
))
}
end
end
end
describe
'Gitlab::Ci::Build::Rules::Result'
do
let
(
:when_value
)
{
'on_success'
}
let
(
:start_in
)
{
nil
}
let
(
:allow_failure
)
{
nil
}
subject
{
Gitlab
::
Ci
::
Build
::
Rules
::
Result
.
new
(
when_value
,
start_in
,
allow_failure
)
}
describe
'#build_attributes'
do
it
'compacts nil values'
do
expect
(
subject
.
build_attributes
).
to
eq
(
options:
{},
when:
'on_success'
)
end
end
describe
'#pass?'
do
context
"'when' is 'never'"
do
let!
(
:when_value
)
{
'never'
}
it
'returns false'
do
expect
(
subject
.
pass?
).
to
eq
(
false
)
end
end
context
"'when' is 'on_success'"
do
let!
(
:when_value
)
{
'on_success'
}
it
'returns true'
do
expect
(
subject
.
pass?
).
to
eq
(
true
)
end
end
end
end
end
spec/lib/gitlab/ci/config/entry/bridge_spec.rb
View file @
8c9dc985
...
...
@@ -105,7 +105,8 @@ describe Gitlab::Ci::Config::Entry::Bridge do
trigger:
{
project:
'some/project'
},
ignore:
false
,
stage:
'test'
,
only:
{
refs:
%w[branches tags]
})
only:
{
refs:
%w[branches tags]
},
scheduling_type: :stage
)
end
end
end
...
...
@@ -126,7 +127,8 @@ describe Gitlab::Ci::Config::Entry::Bridge do
branch:
'feature'
},
ignore:
false
,
stage:
'test'
,
only:
{
refs:
%w[branches tags]
})
only:
{
refs:
%w[branches tags]
},
scheduling_type: :stage
)
end
end
end
...
...
spec/lib/gitlab/ci/config/entry/job_spec.rb
View file @
8c9dc985
...
...
@@ -110,6 +110,10 @@ describe Gitlab::Ci::Config::Entry::Job do
it
{
expect
(
entry
).
to
be_valid
}
it
"returns scheduling_type as :dag"
do
expect
(
entry
.
value
[
:scheduling_type
]).
to
eq
(
:dag
)
end
context
'when has dependencies'
do
let
(
:config
)
do
{
...
...
@@ -598,7 +602,8 @@ describe Gitlab::Ci::Config::Entry::Job do
ignore:
false
,
after_script:
%w[cleanup]
,
only:
{
refs:
%w[branches tags]
},
variables:
{})
variables:
{},
scheduling_type: :stage
)
end
end
end
...
...
spec/lib/gitlab/ci/config/entry/jobs_spec.rb
View file @
8c9dc985
...
...
@@ -98,7 +98,8 @@ describe Gitlab::Ci::Config::Entry::Jobs do
name: :my_trigger
,
only:
{
refs:
%w[branches tags]
},
stage:
'test'
,
trigger:
{
project:
'my/project'
}
trigger:
{
project:
'my/project'
},
scheduling_type: :stage
},
regular_job:
{
ignore:
false
,
...
...
@@ -106,7 +107,8 @@ describe Gitlab::Ci::Config::Entry::Jobs do
only:
{
refs:
%w[branches tags]
},
script:
[
'something'
],
stage:
'test'
,
variables:
{}
variables:
{},
scheduling_type: :stage
})
end
end
...
...
spec/lib/gitlab/ci/config/entry/root_spec.rb
View file @
8c9dc985
...
...
@@ -130,7 +130,8 @@ describe Gitlab::Ci::Config::Entry::Root do
variables:
{},
ignore:
false
,
after_script:
[
'make clean'
],
only:
{
refs:
%w[branches tags]
}
}
only:
{
refs:
%w[branches tags]
},
scheduling_type: :stage
}
)
expect
(
root
.
jobs_value
[
:spinach
]).
to
eq
(
{
name: :spinach
,
...
...
@@ -143,7 +144,8 @@ describe Gitlab::Ci::Config::Entry::Root do
variables:
{},
ignore:
false
,
after_script:
[
'make clean'
],
only:
{
refs:
%w[branches tags]
}
}
only:
{
refs:
%w[branches tags]
},
scheduling_type: :stage
}
)
expect
(
root
.
jobs_value
[
:release
]).
to
eq
(
{
name: :release
,
...
...
@@ -157,7 +159,8 @@ describe Gitlab::Ci::Config::Entry::Root do
only:
{
refs:
%w(branches tags)
},
variables:
{},
after_script:
[],
ignore:
false
}
ignore:
false
,
scheduling_type: :stage
}
)
end
end
...
...
@@ -203,7 +206,8 @@ describe Gitlab::Ci::Config::Entry::Root do
variables:
{},
ignore:
false
,
after_script:
[
'make clean'
],
only:
{
refs:
%w[branches tags]
}
},
only:
{
refs:
%w[branches tags]
},
scheduling_type: :stage
},
spinach:
{
name: :spinach
,
before_script:
[],
script:
%w[spinach]
,
...
...
@@ -214,7 +218,8 @@ describe Gitlab::Ci::Config::Entry::Root do
variables:
{
'VAR'
=>
'AA'
},
ignore:
false
,
after_script:
[
'make clean'
],
only:
{
refs:
%w[branches tags]
}
}
only:
{
refs:
%w[branches tags]
},
scheduling_type: :stage
}
)
end
end
...
...
spec/lib/gitlab/ci/config/entry/rules/rule_spec.rb
View file @
8c9dc985
...
...
@@ -27,8 +27,14 @@ describe Gitlab::Ci::Config::Entry::Rules::Rule do
it
{
is_expected
.
to
be_valid
}
end
context
'with an allow_failure: value but no clauses'
do
let
(
:config
)
{
{
allow_failure:
true
}
}
it
{
is_expected
.
to
be_valid
}
end
context
'when specifying an if: clause'
do
let
(
:config
)
{
{
if:
'$THIS || $THAT'
,
when:
'manual'
}
}
let
(
:config
)
{
{
if:
'$THIS || $THAT'
,
when:
'manual'
,
allow_failure:
true
}
}
it
{
is_expected
.
to
be_valid
}
...
...
@@ -37,6 +43,12 @@ describe Gitlab::Ci::Config::Entry::Rules::Rule do
it
{
is_expected
.
to
eq
(
'manual'
)
}
end
describe
'#allow_failure'
do
subject
{
entry
.
allow_failure
}
it
{
is_expected
.
to
eq
(
true
)
}
end
end
context
'using a list of multiple expressions'
do
...
...
@@ -328,16 +340,43 @@ describe Gitlab::Ci::Config::Entry::Rules::Rule do
end
end
end
context
'allow_failure: validation'
do
context
'with an invalid string allow_failure:'
do
let
(
:config
)
do
{
if:
'$THIS == "that"'
,
allow_failure:
'always'
}
end
it
{
is_expected
.
to
be_a
(
described_class
)
}
it
{
is_expected
.
not_to
be_valid
}
it
'returns an error about invalid allow_failure:'
do
expect
(
subject
.
errors
).
to
include
(
/rule allow failure should be a boolean value/
)
end
context
'when composed'
do
before
do
subject
.
compose!
end
it
{
is_expected
.
not_to
be_valid
}
it
'returns an error about invalid allow_failure:'
do
expect
(
subject
.
errors
).
to
include
(
/rule allow failure should be a boolean value/
)
end
end
end
end
end
describe
'#value'
do
subject
{
entry
.
value
}
context
'when specifying an if: clause'
do
let
(
:config
)
{
{
if:
'$THIS || $THAT'
,
when:
'manual'
}
}
let
(
:config
)
{
{
if:
'$THIS || $THAT'
,
when:
'manual'
,
allow_failure:
true
}
}
it
'stores the expression as "if"'
do
expect
(
subject
).
to
eq
(
if:
'$THIS || $THAT'
,
when:
'manual'
)
expect
(
subject
).
to
eq
(
if:
'$THIS || $THAT'
,
when:
'manual'
,
allow_failure:
true
)
end
end
...
...
spec/lib/gitlab/ci/pipeline/seed/build_spec.rb
View file @
8c9dc985
...
...
@@ -6,7 +6,7 @@ describe Gitlab::Ci::Pipeline::Seed::Build do
let
(
:project
)
{
create
(
:project
,
:repository
)
}
let
(
:head_sha
)
{
project
.
repository
.
head_commit
.
id
}
let
(
:pipeline
)
{
create
(
:ci_empty_pipeline
,
project:
project
,
sha:
head_sha
)
}
let
(
:attributes
)
{
{
name:
'rspec'
,
ref:
'master'
}
}
let
(
:attributes
)
{
{
name:
'rspec'
,
ref:
'master'
,
scheduling_type: :stage
}
}
let
(
:previous_stages
)
{
[]
}
let
(
:seed_build
)
{
described_class
.
new
(
pipeline
,
attributes
,
previous_stages
)
}
...
...
@@ -244,7 +244,9 @@ describe Gitlab::Ci::Pipeline::Seed::Build do
context
'when job is a bridge'
do
let
(
:attributes
)
do
{
name:
'rspec'
,
ref:
'master'
,
options:
{
trigger:
'my/project'
}
}
{
name:
'rspec'
,
ref:
'master'
,
options:
{
trigger:
'my/project'
},
scheduling_type: :stage
}
end
it
{
is_expected
.
to
be_a
(
::
Ci
::
Bridge
)
}
...
...
spec/lib/gitlab/ci/pipeline/seed/stage_spec.rb
View file @
8c9dc985
...
...
@@ -10,9 +10,9 @@ describe Gitlab::Ci::Pipeline::Seed::Stage do
let
(
:attributes
)
do
{
name:
'test'
,
index:
0
,
builds:
[{
name:
'rspec'
},
{
name:
'spinach'
},
{
name:
'deploy'
,
only:
{
refs:
[
'feature'
]
}
}]
}
builds:
[{
name:
'rspec'
,
scheduling_type: :stage
},
{
name:
'spinach'
,
scheduling_type: :stage
},
{
name:
'deploy'
,
only:
{
refs:
[
'feature'
]
}
}]
,
scheduling_type: :stage
}
end
subject
do
...
...
spec/lib/gitlab/ci/yaml_processor_spec.rb
View file @
8c9dc985
...
...
@@ -36,7 +36,8 @@ module Gitlab
interruptible:
true
,
allow_failure:
false
,
when:
"on_success"
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
end
...
...
@@ -66,7 +67,8 @@ module Gitlab
],
allow_failure:
false
,
when:
'on_success'
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
end
...
...
@@ -126,7 +128,8 @@ module Gitlab
interruptible:
true
,
allow_failure:
false
,
when:
"on_success"
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
end
...
...
@@ -282,6 +285,7 @@ module Gitlab
allow_failure:
false
,
when:
"on_success"
,
yaml_variables:
[],
scheduling_type: :stage
,
options:
{
script:
[
"rspec"
]
},
only:
{
refs:
[
"branches"
]
}
}]
},
{
name:
"deploy"
,
...
...
@@ -293,6 +297,7 @@ module Gitlab
allow_failure:
false
,
when:
"on_success"
,
yaml_variables:
[],
scheduling_type: :stage
,
options:
{
script:
[
"cap prod"
]
},
only:
{
refs:
[
"tags"
]
}
}]
},
{
name:
".post"
,
...
...
@@ -642,7 +647,8 @@ module Gitlab
},
allow_failure:
false
,
when:
"on_success"
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
...
...
@@ -674,7 +680,8 @@ module Gitlab
},
allow_failure:
false
,
when:
"on_success"
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
end
...
...
@@ -702,7 +709,8 @@ module Gitlab
},
allow_failure:
false
,
when:
"on_success"
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
...
...
@@ -728,7 +736,8 @@ module Gitlab
},
allow_failure:
false
,
when:
"on_success"
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
end
...
...
@@ -1250,7 +1259,8 @@ module Gitlab
},
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
...
...
@@ -1604,7 +1614,8 @@ module Gitlab
},
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
)
expect
(
subject
.
builds
[
4
]).
to
eq
(
stage:
"test"
,
...
...
@@ -1618,7 +1629,8 @@ module Gitlab
],
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :dag
)
end
end
...
...
@@ -1644,7 +1656,8 @@ module Gitlab
},
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
)
expect
(
subject
.
builds
[
4
]).
to
eq
(
stage:
"test"
,
...
...
@@ -1660,7 +1673,8 @@ module Gitlab
],
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :dag
)
end
end
...
...
@@ -1682,7 +1696,8 @@ module Gitlab
],
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :dag
)
end
end
...
...
@@ -1712,7 +1727,8 @@ module Gitlab
],
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :dag
)
end
end
...
...
@@ -1849,7 +1865,8 @@ module Gitlab
},
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
end
...
...
@@ -1895,7 +1912,8 @@ module Gitlab
},
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
expect
(
subject
.
second
).
to
eq
({
stage:
"build"
,
...
...
@@ -1907,7 +1925,8 @@ module Gitlab
},
when:
"on_success"
,
allow_failure:
false
,
yaml_variables:
[]
yaml_variables:
[],
scheduling_type: :stage
})
end
end
...
...
spec/lib/gitlab/import_export/safe_model_attributes.yml
View file @
8c9dc985
...
...
@@ -360,6 +360,7 @@ CommitStatus:
-
upstream_pipeline_id
-
interruptible
-
processed
-
scheduling_type
Ci::Variable:
-
id
-
project_id
...
...
spec/models/ci/build_spec.rb
View file @
8c9dc985
...
...
@@ -3007,7 +3007,8 @@ describe Ci::Build do
stage:
'test'
,
ref:
'feature'
,
project:
project
,
pipeline:
pipeline
pipeline:
pipeline
,
scheduling_type: :stage
)
end
...
...
spec/models/ci/processable_spec.rb
View file @
8c9dc985
...
...
@@ -52,4 +52,72 @@ describe Ci::Processable do
end
end
end
describe
'validate presence of scheduling_type'
do
context
'on create'
do
let
(
:processable
)
do
build
(
:ci_build
,
:created
,
project:
project
,
pipeline:
pipeline
,
importing:
importing
,
scheduling_type:
nil
)
end
context
'when importing'
do
let
(
:importing
)
{
true
}
context
'when validate_scheduling_type_of_processables is true'
do
before
do
stub_feature_flags
(
validate_scheduling_type_of_processables:
true
)
end
it
'does not validate'
do
expect
(
processable
).
to
be_valid
end
end
context
'when validate_scheduling_type_of_processables is false'
do
before
do
stub_feature_flags
(
validate_scheduling_type_of_processables:
false
)
end
it
'does not validate'
do
expect
(
processable
).
to
be_valid
end
end
end
context
'when not importing'
do
let
(
:importing
)
{
false
}
context
'when validate_scheduling_type_of_processables is true'
do
before
do
stub_feature_flags
(
validate_scheduling_type_of_processables:
true
)
end
it
'validates'
do
expect
(
processable
).
not_to
be_valid
end
end
context
'when validate_scheduling_type_of_processables is false'
do
before
do
stub_feature_flags
(
validate_scheduling_type_of_processables:
false
)
end
it
'does not validate'
do
expect
(
processable
).
to
be_valid
end
end
end
end
context
'on update'
do
let
(
:processable
)
{
create
(
:ci_build
,
:created
,
project:
project
,
pipeline:
pipeline
)
}
it
'does not validate'
do
processable
.
scheduling_type
=
nil
expect
(
processable
).
to
be_valid
end
end
end
end
spec/services/ci/create_pipeline_service/needs_spec.rb
View file @
8c9dc985
...
...
@@ -131,6 +131,10 @@ describe Ci::CreatePipelineService do
)
end
end
it
"sets scheduling_type as 'dag'"
do
expect
(
test_a_build
.
scheduling_type
).
to
eq
(
'dag'
)
end
end
context
'with an invalid config'
do
...
...
spec/services/ci/create_pipeline_service_spec.rb
View file @
8c9dc985
This diff is collapsed.
Click to expand it.
spec/services/ci/retry_build_service_spec.rb
View file @
8c9dc985
...
...
@@ -222,6 +222,28 @@ describe Ci::RetryBuildService do
expect
{
new_build
}.
to
change
{
Deployment
.
count
}.
by
(
1
)
end
end
context
'when scheduling_type of build is nil'
do
before
do
build
.
update_columns
(
scheduling_type:
nil
)
end
context
'when build has not needs'
do
it
'sets scheduling_type as :stage'
do
expect
(
new_build
.
scheduling_type
).
to
eq
(
'stage'
)
end
end
context
'when build has needs'
do
before
do
create
(
:ci_build_need
,
build:
build
)
end
it
'sets scheduling_type as :dag'
do
expect
(
new_build
.
scheduling_type
).
to
eq
(
'dag'
)
end
end
end
end
context
'when user does not have ability to execute build'
do
...
...
vendor/elastic_stack/values.yaml
View file @
8c9dc985
...
...
@@ -8,7 +8,7 @@ elasticsearch:
client
:
replicas
:
1
data
:
replicas
:
1
replicas
:
2
kibana
:
enabled
:
false
...
...
vendor/elastic_stack/wait-for-elasticsearch.sh
0 → 100755
View file @
8c9dc985
#!/bin/bash
# http://redsymbol.net/articles/unofficial-bash-strict-mode/
IFS
=
$'
\n\t
'
set
-euo
pipefail
HOST
=
"
$1
"
printf
'Waiting for ES to be reachable ...'
until
$(
wget
-O-
-q
"
$HOST
"
&>/dev/null
)
;
do
printf
'.'
sleep
1
done
echo
" OK!"
printf
'Waiting for ES to be healthy ...'
while
:
;
do
HEALTH
=
"
$(
wget
-O-
-q
"
$HOST
/_cat/health?h=status"
2> /dev/null
)
"
HEALTH
=
"
$(
echo
"
$HEALTH
"
|
sed
-r
's/^[[:space:]]+|[[:space:]]+$//g'
)
"
# trim whitespace (otherwise we'll have "green ")
([
"
$HEALTH
"
!=
"green"
]
&&
printf
'.'
&&
sleep
1
)
||
break
done
echo
" OK!"
echo
"Elastic Search is up!"
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