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
eca73d2b
Commit
eca73d2b
authored
Sep 07, 2018
by
Matija Čupić
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Address MR comments
CE mirror of 1269dc47b7f8d1a9913de326c9bd356d3e603663
parent
95b296f8
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
67 additions
and
48 deletions
+67
-48
lib/gitlab/ci/config.rb
lib/gitlab/ci/config.rb
+10
-10
lib/gitlab/ci/external_files/external_file.rb
lib/gitlab/ci/external_files/external_file.rb
+5
-3
lib/gitlab/ci/external_files/mapper.rb
lib/gitlab/ci/external_files/mapper.rb
+2
-2
lib/gitlab/ci/external_files/processor.rb
lib/gitlab/ci/external_files/processor.rb
+3
-3
spec/lib/gitlab/ci/config_spec.rb
spec/lib/gitlab/ci/config_spec.rb
+8
-9
spec/lib/gitlab/ci/external_files/external_file_spec.rb
spec/lib/gitlab/ci/external_files/external_file_spec.rb
+13
-1
spec/lib/gitlab/ci/external_files/mapper_spec.rb
spec/lib/gitlab/ci/external_files/mapper_spec.rb
+5
-5
spec/lib/gitlab/ci/external_files/processor_spec.rb
spec/lib/gitlab/ci/external_files/processor_spec.rb
+21
-15
No files found.
lib/gitlab/ci/config.rb
View file @
eca73d2b
...
...
@@ -7,17 +7,10 @@ module Gitlab
ConfigError
=
Class
.
new
(
StandardError
)
def
initialize
(
config
,
project
=
nil
,
opts
=
{})
initial_
config
=
Config
::
Extendable
@
config
=
Config
::
Extendable
.
new
(
build_config
(
config
,
opts
))
.
to_hash
if
project
.
present?
processor
=
::
Gitlab
::
Ci
::
ExternalFiles
::
Processor
.
new
(
initial_config
,
project
)
@config
=
processor
.
perform
else
@config
=
initial_config
end
@global
=
Entry
::
Global
.
new
(
@config
)
@global
.
compose!
rescue
Loader
::
FormatError
,
Extendable
::
ExtensionError
=>
e
...
...
@@ -72,8 +65,15 @@ module Gitlab
end
# 'opts' argument is used in EE see /ee/lib/ee/gitlab/ci/config.rb
def
build_config
(
config
,
opts
=
{})
Loader
.
new
(
config
).
load!
def
build_config
(
config
,
project
,
opts
=
{})
initial_config
=
Loader
.
new
(
config
).
load!
if
project
.
present?
processor
=
::
Gitlab
::
Ci
::
ExternalFiles
::
Processor
.
new
(
initial_config
,
project
)
processor
.
perform
else
initial_config
end
end
end
end
...
...
lib/gitlab/ci/external_files/external_file.rb
View file @
eca73d2b
...
...
@@ -4,6 +4,8 @@ module Gitlab
module
Ci
module
ExternalFiles
class
ExternalFile
attr_reader
:value
,
:project
def
initialize
(
value
,
project
)
@value
=
value
@project
=
project
...
...
@@ -11,10 +13,12 @@ module Gitlab
def
content
if
remote_url?
open
(
value
).
read
HTTParty
.
get
(
value
)
else
local_file_content
end
rescue
HTTParty
::
Error
,
Timeout
::
Error
nil
end
def
valid?
...
...
@@ -23,8 +27,6 @@ module Gitlab
private
attr_reader
:value
,
:project
def
remote_url?
::
Gitlab
::
UrlSanitizer
.
valid?
(
value
)
end
...
...
lib/gitlab/ci/external_files/mapper.rb
View file @
eca73d2b
...
...
@@ -3,7 +3,7 @@ module Gitlab
module
ExternalFiles
class
Mapper
def
initialize
(
values
,
project
)
@paths
=
values
.
fetch
(
:include
s
,
[])
@paths
=
values
.
fetch
(
:include
,
[])
@project
=
project
end
...
...
@@ -17,7 +17,7 @@ module Gitlab
private
attr_reaer
:paths
,
:project
attr_rea
d
er
:paths
,
:project
def
build_external_file
(
path
)
::
Gitlab
::
Ci
::
ExternalFiles
::
ExternalFile
.
new
(
path
,
project
)
...
...
lib/gitlab/ci/external_files/processor.rb
View file @
eca73d2b
...
...
@@ -6,7 +6,7 @@ module Gitlab
def
initialize
(
values
,
project
)
@values
=
values
@external_files
=
::
Gitlab
::
Ci
::
ExternalFiles
::
Mapper
.
fetch_paths
(
values
,
project
).
process
@external_files
=
::
Gitlab
::
Ci
::
ExternalFiles
::
Mapper
.
new
(
values
,
project
).
process
end
def
perform
...
...
@@ -26,7 +26,7 @@ module Gitlab
def
validate_external_file
(
external_file
)
unless
external_file
.
valid?
raise
ExternalFileError
,
'External files should be a valid local or remote file'
raise
ExternalFileError
,
"External file: '
#{
external_file
.
value
}
' should be a valid local or remote file"
end
end
...
...
@@ -36,7 +36,7 @@ module Gitlab
end
def
remove_include_keyword
values
.
delete
(
:include
s
)
values
.
delete
(
:include
)
values
end
end
...
...
spec/lib/gitlab/ci/config_spec.rb
View file @
eca73d2b
...
...
@@ -126,7 +126,7 @@ describe Gitlab::Ci::Config do
end
end
context
"when yml has valid 'include
s
' defined"
do
context
"when yml has valid 'include' defined"
do
let
(
:http_file_content
)
do
<<~
HEREDOC
variables:
...
...
@@ -140,9 +140,8 @@ describe Gitlab::Ci::Config do
let
(
:local_file_content
)
{
File
.
read
(
"
#{
Rails
.
root
}
/spec/ee/fixtures/gitlab/ci/external_files/.gitlab-ci-template-1.yml"
)
}
let
(
:yml
)
do
<<-
EOS
include
s
:
include:
- /spec/fixtures/gitlab/ci/external_files/.gitlab-ci-template-1.yml
- /spec/fixtures/gitlab/ci/external_files/.gitlab-ci-template-2.yml
- https://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml
image: ruby:2.2
...
...
@@ -151,7 +150,7 @@ describe Gitlab::Ci::Config do
before
do
allow_any_instance_of
(
::
Gitlab
::
Ci
::
ExternalFiles
::
ExternalFile
).
to
receive
(
:local_file_content
).
and_return
(
local_file_content
)
allow
_any_instance_of
(
Kernel
).
to
receive_message_chain
(
:open
,
:read
).
and_return
(
http_file_content
)
allow
(
HTTParty
).
to
receive
(
:get
).
and_return
(
http_file_content
)
end
it
'should return a composed hash'
do
...
...
@@ -179,17 +178,17 @@ describe Gitlab::Ci::Config do
end
end
context
"when yml has invalid 'include
s
' defined"
do
context
"when yml has invalid 'include' defined"
do
let
(
:yml
)
do
<<-
EOS
include
s
: invalid
include: invalid
EOS
end
it
'raises error'
do
it
'raises error
YamlProcessor ValidationError
'
do
expect
{
config
}.
to
raise_error
(
::
Gitlab
::
Ci
::
ExternalFiles
::
Processor
::
ExternalFile
Error
,
/External files should be a valid local or remote file/
::
Gitlab
::
Ci
::
YamlProcessor
::
Validation
Error
,
"External file: 'invalid' should be a valid local or remote file"
)
end
end
...
...
spec/lib/gitlab/ci/external_files/external_file_spec.rb
View file @
eca73d2b
...
...
@@ -71,12 +71,24 @@ describe Gitlab::Ci::ExternalFiles::ExternalFile do
let
(
:value
)
{
'https://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml'
}
before
do
allow
_any_instance_of
(
Kernel
).
to
receive_message_chain
(
:open
,
:read
).
and_return
(
external_file_content
)
allow
(
HTTParty
).
to
receive
(
:get
).
and_return
(
external_file_content
)
end
it
'should return the content of the file'
do
expect
(
external_file
.
content
).
to
eq
(
external_file_content
)
end
end
context
'with a timeout'
do
let
(
:value
)
{
'https://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml'
}
before
do
allow
(
HTTParty
).
to
receive
(
:get
).
and_raise
(
Timeout
::
Error
)
end
it
'should return nil'
do
expect
(
external_file
.
content
).
to
be_nil
end
end
end
end
spec/lib/gitlab/ci/external_files/mapper_spec.rb
View file @
eca73d2b
...
...
@@ -6,10 +6,10 @@ describe Gitlab::Ci::ExternalFiles::Mapper do
describe
'#process'
do
subject
{
described_class
.
new
(
values
,
project
).
process
}
context
'when includes keyword is defined as string'
do
context
"when 'include' keyword is defined as string"
do
let
(
:values
)
do
{
include
s
:
'/vendor/gitlab-ci-yml/non-existent-file.yml'
,
include:
'/vendor/gitlab-ci-yml/non-existent-file.yml'
,
image:
'ruby:2.2'
}
end
...
...
@@ -23,10 +23,10 @@ describe Gitlab::Ci::ExternalFiles::Mapper do
end
end
context
'when includes is defined as an array'
do
context
"when 'include' is defined as an array"
do
let
(
:values
)
do
{
include
s
:
include:
[
'https://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml'
,
'/vendor/gitlab-ci-yml/template.yml'
...
...
@@ -44,7 +44,7 @@ describe Gitlab::Ci::ExternalFiles::Mapper do
end
end
context
'when includes is not defined'
do
context
"when 'include' is not defined"
do
let
(
:values
)
do
{
image:
'ruby:2.2'
}
end
...
...
spec/lib/gitlab/ci/external_files/processor_spec.rb
View file @
eca73d2b
...
...
@@ -14,23 +14,29 @@ describe Gitlab::Ci::ExternalFiles::Processor do
end
context
'when an invalid local file is defined'
do
let
(
:values
)
{
{
include
s
:
'/vendor/gitlab-ci-yml/non-existent-file.yml'
,
image:
'ruby:2.2'
}
}
let
(
:values
)
{
{
include:
'/vendor/gitlab-ci-yml/non-existent-file.yml'
,
image:
'ruby:2.2'
}
}
it
'should raise an error'
do
expect
{
processor
.
perform
}.
to
raise_error
(
described_class
::
ExternalFileError
)
expect
{
processor
.
perform
}.
to
raise_error
(
described_class
::
ExternalFileError
,
"External file: '/vendor/gitlab-ci-yml/non-existent-file.yml' should be a valid local or remote file"
)
end
end
context
'when an invalid remote file is defined'
do
let
(
:values
)
{
{
include
s
:
'not-valid://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml'
,
image:
'ruby:2.2'
}
}
let
(
:values
)
{
{
include:
'not-valid://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml'
,
image:
'ruby:2.2'
}
}
it
'should raise an error'
do
expect
{
processor
.
perform
}.
to
raise_error
(
described_class
::
ExternalFileError
)
expect
{
processor
.
perform
}.
to
raise_error
(
described_class
::
ExternalFileError
,
"External file: 'not-valid://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml' should be a valid local or remote file"
)
end
end
context
'with a valid remote external file is defined'
do
let
(
:values
)
{
{
include
s
:
'https://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml'
,
image:
'ruby:2.2'
}
}
let
(
:values
)
{
{
include:
'https://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml'
,
image:
'ruby:2.2'
}
}
let
(
:external_file_content
)
do
<<-
HEREDOC
before_script:
...
...
@@ -51,7 +57,7 @@ describe Gitlab::Ci::ExternalFiles::Processor do
end
before
do
allow
_any_instance_of
(
Kernel
).
to
receive_message_chain
(
:open
,
:read
).
and_return
(
external_file_content
)
allow
(
HTTParty
).
to
receive
(
:get
).
and_return
(
external_file_content
)
end
it
'should append the file to the values'
do
...
...
@@ -59,13 +65,13 @@ describe Gitlab::Ci::ExternalFiles::Processor do
expect
(
output
.
keys
).
to
match_array
([
:image
,
:before_script
,
:rspec
,
:rubocop
])
end
it
"should remove the 'include
s
' keyword"
do
expect
(
processor
.
perform
[
:include
s
]).
to
be_nil
it
"should remove the 'include' keyword"
do
expect
(
processor
.
perform
[
:include
]).
to
be_nil
end
end
context
'with a valid local external file is defined'
do
let
(
:values
)
{
{
include
s
:
'/vendor/gitlab-ci-yml/template.yml'
,
image:
'ruby:2.2'
}
}
let
(
:values
)
{
{
include:
'/vendor/gitlab-ci-yml/template.yml'
,
image:
'ruby:2.2'
}
}
let
(
:external_file_content
)
do
<<-
HEREDOC
before_script:
...
...
@@ -86,7 +92,7 @@ describe Gitlab::Ci::ExternalFiles::Processor do
expect
(
output
.
keys
).
to
match_array
([
:image
,
:before_script
])
end
it
"should remove the 'include
s
' keyword"
do
it
"should remove the 'include' keyword"
do
expect
(
processor
.
perform
[
:includes
]).
to
be_nil
end
end
...
...
@@ -98,7 +104,7 @@ describe Gitlab::Ci::ExternalFiles::Processor do
'https://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml'
]
end
let
(
:values
)
{
{
include
s
:
external_files
,
image:
'ruby:2.2'
}
}
let
(
:values
)
{
{
include:
external_files
,
image:
'ruby:2.2'
}
}
let
(
:remote_file_content
)
do
<<-
HEREDOC
...
...
@@ -112,20 +118,20 @@ describe Gitlab::Ci::ExternalFiles::Processor do
before
do
file_content
=
File
.
read
(
"
#{
Rails
.
root
}
/spec/ee/fixtures/gitlab/ci/external_files/.gitlab-ci-template-1.yml"
)
allow_any_instance_of
(
::
Gitlab
::
Ci
::
ExternalFiles
::
ExternalFile
).
to
receive
(
:local_file_content
).
and_return
(
file_content
)
allow
_any_instance_of
(
Kernel
).
to
receive_message_chain
(
:open
,
:read
).
and_return
(
remote_file_content
)
allow
(
HTTParty
).
to
receive
(
:get
).
and_return
(
remote_file_content
)
end
it
'should append the files to the values'
do
expect
(
processor
.
perform
.
keys
).
to
match_array
([
:image
,
:stages
,
:before_script
,
:rspec
])
end
it
"should remove the 'include
s
' keyword"
do
expect
(
processor
.
perform
[
:include
s
]).
to
be_nil
it
"should remove the 'include' keyword"
do
expect
(
processor
.
perform
[
:include
]).
to
be_nil
end
end
context
'when external files are defined but not valid'
do
let
(
:values
)
{
{
include
s
:
'/vendor/gitlab-ci-yml/template.yml'
,
image:
'ruby:2.2'
}
}
let
(
:values
)
{
{
include:
'/vendor/gitlab-ci-yml/template.yml'
,
image:
'ruby:2.2'
}
}
let
(
:external_file_content
)
{
'invalid content file ////'
}
...
...
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