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
4372795d
Commit
4372795d
authored
Sep 17, 2019
by
Kamil Trzciński
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix Composite
parent
4e1281a1
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
58 additions
and
37 deletions
+58
-37
app/models/commit_status.rb
app/models/commit_status.rb
+1
-1
lib/gitlab/ci/status/composite.rb
lib/gitlab/ci/status/composite.rb
+41
-28
spec/lib/gitlab/ci/status/composite_spec.rb
spec/lib/gitlab/ci/status/composite_spec.rb
+16
-8
No files found.
app/models/commit_status.rb
View file @
4372795d
...
@@ -49,7 +49,7 @@ class CommitStatus < ApplicationRecord
...
@@ -49,7 +49,7 @@ class CommitStatus < ApplicationRecord
scope
:for_ids
,
->
(
ids
)
{
where
(
id:
ids
)
}
scope
:for_ids
,
->
(
ids
)
{
where
(
id:
ids
)
}
scope
:with_preloads
,
->
do
scope
:with_preloads
,
->
do
preload
(
:project
,
:
taggings
,
:deployment
,
:
user
)
preload
(
:project
,
:user
)
end
end
scope
:with_needs
,
->
(
names
=
nil
)
do
scope
:with_needs
,
->
(
names
=
nil
)
do
...
...
lib/gitlab/ci/status/composite.rb
View file @
4372795d
...
@@ -4,12 +4,16 @@ module Gitlab
...
@@ -4,12 +4,16 @@ module Gitlab
module
Ci
module
Ci
module
Status
module
Status
class
Composite
class
Composite
include
Gitlab
::
Utils
::
StrongMemoize
attr_reader
:warnings
attr_reader
:warnings
# This class accepts an array of arrays
or array of hashes
# This class accepts an array of arrays
# The `status_key` and `allow_failure_key` define an index
# The `status_key` and `allow_failure_key` define an index
# or key in each entry
# or key in each entry
def
initialize
(
all_statuses
,
status_key
:,
allow_failure_key
:)
def
initialize
(
all_statuses
,
status_key
:,
allow_failure_key
:)
raise
ArgumentError
,
"all_statuses needs to be an Array"
unless
all_statuses
.
is_a?
(
Array
)
@count
=
0
@count
=
0
@warnings
=
0
@warnings
=
0
@status_set
=
Set
.
new
@status_set
=
Set
.
new
...
@@ -19,34 +23,41 @@ module Gitlab
...
@@ -19,34 +23,41 @@ module Gitlab
build_status_set
(
all_statuses
)
build_status_set
(
all_statuses
)
end
end
# The status calculation is order dependent,
# 1. In some cases we assume that that status is exact
# if the we only have given statues,
# 2. In other cases we assume that status is of that type
# based on what statuses are no longer valid based on the
# data set that we have
def
status
def
status
case
strong_memoize
(
:status
)
do
when
@count
.
zero?
next
if
@count
.
zero?
nil
when
none?
||
only_of?
(
:skipped
)
if
none?
||
only_of?
(
:skipped
)
warnings?
?
'success'
:
'skipped'
warnings?
?
'success'
:
'skipped'
when
only_of?
(
:success
,
:skipped
)
elsif
only_of?
(
:success
,
:skipped
)
'success'
'success'
when
only_of?
(
:created
)
elsif
only_of?
(
:created
)
'created'
'created'
when
only_of?
(
:preparing
)
elsif
only_of?
(
:preparing
)
'preparing'
'preparing'
when
only_of?
(
:success
,
:skipped
,
:canceled
)
elsif
only_of?
(
:canceled
,
:success
,
:skipped
)
'canceled'
'canceled'
when
only_of?
(
:created
,
:skipped
,
:pending
)
elsif
only_of?
(
:pending
,
:created
,
:skipped
)
'pending'
'pending'
when
any_of?
(
:running
,
:pending
)
elsif
any_of?
(
:running
,
:pending
)
'running'
'running'
when
any_of?
(
:manual
)
elsif
any_of?
(
:manual
)
'manual'
'manual'
when
any_of?
(
:scheduled
)
elsif
any_of?
(
:scheduled
)
'scheduled'
'scheduled'
when
any_of?
(
:preparing
)
elsif
any_of?
(
:preparing
)
'preparing'
'preparing'
when
any_of?
(
:created
)
elsif
any_of?
(
:created
)
'running'
'running'
else
else
'failed'
'failed'
end
end
end
end
end
...
@@ -71,6 +82,8 @@ module Gitlab
...
@@ -71,6 +82,8 @@ module Gitlab
def
build_status_set
(
all_statuses
)
def
build_status_set
(
all_statuses
)
all_statuses
.
each
do
|
status
|
all_statuses
.
each
do
|
status
|
status
=
Array
(
status
)
@count
+=
1
@count
+=
1
@warnings
+=
1
if
count_as_warning?
(
status
)
@warnings
+=
1
if
count_as_warning?
(
status
)
next
if
exclude_from_calculation?
(
status
)
next
if
exclude_from_calculation?
(
status
)
...
...
spec/lib/gitlab/ci/status/composite_spec.rb
View file @
4372795d
...
@@ -3,14 +3,6 @@ require 'spec_helper'
...
@@ -3,14 +3,6 @@ require 'spec_helper'
describe
Gitlab
::
Ci
::
Status
::
Composite
do
describe
Gitlab
::
Ci
::
Status
::
Composite
do
set
(
:pipeline
)
{
create
(
:ci_pipeline
)
}
set
(
:pipeline
)
{
create
(
:ci_pipeline
)
}
let
(
:composite_status
)
do
described_class
.
new
(
all_statuses
.
pluck
(
:status
,
:allow_failure
),
status_key:
0
,
allow_failure_key:
0
)
end
before
(
:all
)
do
before
(
:all
)
do
@statuses
=
HasStatus
::
STATUSES_ENUM
.
map
do
|
status
,
idx
|
@statuses
=
HasStatus
::
STATUSES_ENUM
.
map
do
|
status
,
idx
|
[
status
,
create
(
:ci_build
,
pipeline:
pipeline
,
status:
status
,
importing:
true
)]
[
status
,
create
(
:ci_build
,
pipeline:
pipeline
,
status:
status
,
importing:
true
)]
...
@@ -37,6 +29,14 @@ describe Gitlab::Ci::Status::Composite do
...
@@ -37,6 +29,14 @@ describe Gitlab::Ci::Status::Composite do
let
(
:all_statuses
)
do
let
(
:all_statuses
)
do
statuses
.
map
{
|
status
|
@statuses
[
status
]
}
statuses
.
map
{
|
status
|
@statuses
[
status
]
}
end
end
let
(
:composite_status
)
do
described_class
.
new
(
all_statuses
.
pluck
(
:status
),
status_key:
0
,
allow_failure_key:
nil
)
end
end
end
HasStatus
::
STATUSES_ENUM
.
each
do
|
allow_failure_status
,
_
|
HasStatus
::
STATUSES_ENUM
.
each
do
|
allow_failure_status
,
_
|
...
@@ -46,6 +46,14 @@ describe Gitlab::Ci::Status::Composite do
...
@@ -46,6 +46,14 @@ describe Gitlab::Ci::Status::Composite do
statuses
.
map
{
|
status
|
@statuses
[
status
]
}
+
statuses
.
map
{
|
status
|
@statuses
[
status
]
}
+
[
@statuses_with_allow_failure
[
allow_failure_status
]]
[
@statuses_with_allow_failure
[
allow_failure_status
]]
end
end
let
(
:composite_status
)
do
described_class
.
new
(
all_statuses
.
pluck
(
:status
,
:allow_failure
),
status_key:
0
,
allow_failure_key:
1
)
end
end
end
end
end
end
end
...
...
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