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
857d0391
Commit
857d0391
authored
May 31, 2017
by
Rémy Coutable
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Lint our factories creation in addition to their build
Signed-off-by:
Rémy Coutable
<
remy@rymai.me
>
parent
19ee16a0
Changes
15
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
93 additions
and
47 deletions
+93
-47
app/models/commit.rb
app/models/commit.rb
+1
-1
spec/controllers/profiles/keys_controller_spec.rb
spec/controllers/profiles/keys_controller_spec.rb
+1
-1
spec/factories/ci/pipelines.rb
spec/factories/ci/pipelines.rb
+9
-12
spec/factories/ci/stages.rb
spec/factories/ci/stages.rb
+2
-0
spec/factories/ci/trigger_requests.rb
spec/factories/ci/trigger_requests.rb
+2
-2
spec/factories/commits.rb
spec/factories/commits.rb
+2
-7
spec/factories/file_uploaders.rb
spec/factories/file_uploaders.rb
+2
-0
spec/factories/keys.rb
spec/factories/keys.rb
+5
-14
spec/factories/project_statistics.rb
spec/factories/project_statistics.rb
+6
-2
spec/factories/project_wikis.rb
spec/factories/project_wikis.rb
+2
-0
spec/factories/projects.rb
spec/factories/projects.rb
+2
-0
spec/factories/wiki_directories.rb
spec/factories/wiki_directories.rb
+2
-0
spec/factories_spec.rb
spec/factories_spec.rb
+10
-4
spec/models/key_spec.rb
spec/models/key_spec.rb
+6
-4
spec/support/helpers/key_generator_helper.rb
spec/support/helpers/key_generator_helper.rb
+41
-0
No files found.
app/models/commit.rb
View file @
857d0391
...
...
@@ -14,7 +14,7 @@ class Commit
participant
:committer
participant
:notes_with_associations
attr_accessor
:project
attr_accessor
:project
,
:author
DIFF_SAFE_LINES
=
Gitlab
::
Git
::
DiffCollection
::
DEFAULT_LIMITS
[
:max_lines
]
...
...
spec/controllers/profiles/keys_controller_spec.rb
View file @
857d0391
...
...
@@ -49,7 +49,7 @@ describe Profiles::KeysController do
expect
(
response
.
body
).
to
eq
(
user
.
all_ssh_keys
.
join
(
"
\n
"
))
expect
(
response
.
body
).
to
include
(
key
.
key
.
sub
(
' dummy@gitlab.com'
,
''
))
expect
(
response
.
body
).
to
include
(
another_key
.
key
)
expect
(
response
.
body
).
to
include
(
another_key
.
key
.
sub
(
' dummy@gitlab.com'
,
''
)
)
expect
(
response
.
body
).
not_to
include
(
deploy_key
.
key
)
end
...
...
spec/factories/ci/pipelines.rb
View file @
857d0391
...
...
@@ -8,14 +8,14 @@ FactoryGirl.define do
factory
:ci_pipeline_without_jobs
do
after
(
:build
)
do
|
pipeline
|
allow
(
pipeline
).
to
receive
(
:ci_yaml_file
)
{
YAML
.
dump
({})
}
pipeline
.
instance_variable_set
(
:@ci_yaml_file
,
YAML
.
dump
({}))
end
end
factory
:ci_pipeline_with_one_job
do
after
(
:build
)
do
|
pipeline
|
allow
(
pipeline
).
to
receive
(
:ci_yaml_file
)
do
YAML
.
dump
({
rspec:
{
script:
"ls"
}
}
)
pipeline
.
instance_variable_set
(
:@ci_yaml_file
,
YAML
.
dump
({
rspec:
{
script:
"ls"
}
})
)
end
end
end
...
...
@@ -33,17 +33,14 @@ FactoryGirl.define do
transient
{
config
nil
}
after
(
:build
)
do
|
pipeline
,
evaluator
|
allow
(
pipeline
).
to
receive
(
:ci_yaml_file
)
do
if
evaluator
.
config
YAML
.
dump
(
evaluator
.
config
)
else
File
.
read
(
Rails
.
root
.
join
(
'spec/support/gitlab_stubs/gitlab_ci.yml'
))
end
end
pipeline
.
instance_variable_set
(
:@ci_yaml_file
,
YAML
.
dump
(
evaluator
.
config
))
# Populates pipeline with errors
#
pipeline
.
config_processor
if
evaluator
.
config
else
pipeline
.
instance_variable_set
(
:@ci_yaml_file
,
File
.
read
(
Rails
.
root
.
join
(
'spec/support/gitlab_stubs/gitlab_ci.yml'
)))
end
end
trait
:invalid
do
...
...
spec/factories/ci/stages.rb
View file @
857d0391
FactoryGirl
.
define
do
factory
:ci_stage
,
class:
Ci
::
Stage
do
skip_create
transient
do
name
'test'
status
nil
...
...
spec/factories/ci/trigger_requests.rb
View file @
857d0391
FactoryGirl
.
define
do
factory
:ci_trigger_request
,
class:
Ci
::
TriggerRequest
do
factory
:ci_trigger_request_with_variables
do
trigger
factory: :ci_trigger
factory
:ci_trigger_request_with_variables
do
variables
do
{
TRIGGER_KEY_1
:
'TRIGGER_VALUE_1'
,
...
...
spec/factories/commits.rb
View file @
857d0391
...
...
@@ -4,19 +4,14 @@ FactoryGirl.define do
factory
:commit
do
git_commit
RepoHelpers
.
sample_commit
project
factory: :empty_project
author
{
build
(
:author
)
}
initialize_with
do
new
(
git_commit
,
project
)
end
after
(
:build
)
do
|
commit
|
allow
(
commit
).
to
receive
(
:author
).
and_return
build
(
:author
)
end
trait
:without_author
do
after
(
:build
)
do
|
commit
|
allow
(
commit
).
to
receive
(
:author
).
and_return
nil
end
author
nil
end
end
end
spec/factories/file_uploader.rb
→
spec/factories/file_uploader
s
.rb
View file @
857d0391
FactoryGirl
.
define
do
factory
:file_uploader
do
skip_create
project
factory: :empty_project
secret
nil
...
...
spec/factories/keys.rb
View file @
857d0391
require_relative
'../support/helpers/key_generator_helper'
FactoryGirl
.
define
do
factory
:key
do
title
key
do
'ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAIEAiPWx6WM4lhHNedGfBpPJNPpZ7yKu+dnn1SJejgt4596k6YjzGGphH2TUxwKzxcKDKKezwkpfnxPkSMkuEspGRt/aZZ9wa++Oi7Qkr8prgHc4soW6NUlfDzpvZK2H5E7eQaSeP3SAwGmQKUFHCddNaP0L+hM7zhFNzjFvpaMgJw0= dummy@gitlab.com'
end
key
{
Spec
::
Support
::
Helpers
::
KeyGeneratorHelper
.
new
(
1024
).
generate
+
' dummy@gitlab.com'
}
factory
:deploy_key
,
class:
'DeployKey'
do
key
do
'ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDFf6RYK3qu/RKF/3ndJmL5xgMLp3O96x8lTay+QGZ0+9FnnAXMdUqBq/ZU6d/gyMB4IaW3nHzM1w049++yAB6UPCzMB8Uo27K5/jyZCtj7Vm9PFNjF/8am1kp46c/SeYicQgQaSBdzIW3UDEa1Ef68qroOlvpi9PYZ/tA7M0YP0K5PXX+E36zaIRnJVMPT3f2k+GnrxtjafZrwFdpOP/Fol5BQLBgcsyiU+LM1SuaCrzd8c9vyaTA1CxrkxaZh+buAi0PmdDtaDrHd42gqZkXCKavyvgM5o2CkQ5LJHCgzpXy05qNFzmThBSkb+XtoxbyagBiGbVZtSVow6Xa7qewz'
end
end
factory
:deploy_key
,
class:
'DeployKey'
factory
:personal_key
do
user
end
factory
:another_key
do
key
do
'ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDmTillFzNTrrGgwaCKaSj+QCz81E6jBc/s9av0+3b1Hwfxgkqjl4nAK/OD2NjgyrONDTDfR8cRN4eAAy6nY8GLkOyYBDyuc5nTMqs5z3yVuTwf3koGm/YQQCmo91psZ2BgDFTor8SVEE5Mm1D1k3JDMhDFxzzrOtRYFPci9lskTJaBjpqWZ4E9rDTD2q/QZntCqbC3wE9uSemRQB5f8kik7vD/AD8VQXuzKladrZKkzkONCPWsXDspUitjM8HkQdOf0PsYn1CMUC1xKYbCxkg5TkEosIwGv6CoEArUrdu/4+10LVslq494mAvEItywzrluCLCnwELfW+h/m8UHoVhZ'
end
factory
:another_deploy_key
,
class:
'DeployKey'
do
end
factory
:another_deploy_key
,
class:
'DeployKey'
end
factory
:write_access_key
,
class:
'DeployKey'
do
...
...
spec/factories/project_statistics.rb
View file @
857d0391
FactoryGirl
.
define
do
factory
:project_statistics
do
project
{
create
:project
}
namespace
{
project
.
namespace
}
project
initialize_with
do
# statistics are automatically created when a project is created
project
&
.
statistics
||
new
end
end
end
spec/factories/project_wikis.rb
View file @
857d0391
FactoryGirl
.
define
do
factory
:project_wiki
do
skip_create
project
factory: :empty_project
user
factory: :user
initialize_with
{
new
(
project
,
user
)
}
...
...
spec/factories/projects.rb
View file @
857d0391
require_relative
'../support/test_env'
FactoryGirl
.
define
do
# Project without repository
#
...
...
spec/factories/wiki_directories.rb
View file @
857d0391
FactoryGirl
.
define
do
factory
:wiki_directory
do
skip_create
slug
'/path_up_to/dir'
initialize_with
{
new
(
slug
)
}
end
...
...
spec/factories_spec.rb
View file @
857d0391
...
...
@@ -3,14 +3,20 @@ require 'spec_helper'
describe
'factories'
do
FactoryGirl
.
factories
.
each
do
|
factory
|
describe
"
#{
factory
.
name
}
factory"
do
let
(
:entity
)
{
build
(
factory
.
name
)
}
it
'does not raise error when built'
do
expect
{
build
(
factory
.
name
)
}.
not_to
raise_error
end
it
'does not raise error when created'
do
expect
{
entity
}.
not_to
raise_error
expect
{
create
(
factory
.
name
)
}.
not_to
raise_error
end
it
'is valid'
,
if:
factory
.
build_class
<
ActiveRecord
::
Base
do
expect
(
entity
).
to
be_valid
factory
.
definition
.
defined_traits
.
map
(
&
:name
).
each
do
|
trait_name
|
describe
"linting
#{
trait_name
}
trait"
do
skip
'does not raise error when created'
do
expect
{
create
(
factory
.
name
,
trait_name
)
}.
not_to
raise_error
end
end
end
end
end
...
...
spec/models/key_spec.rb
View file @
857d0391
...
...
@@ -66,14 +66,16 @@ describe Key, models: true do
end
it
"does not accept the exact same key twice"
do
create
(
:key
,
user:
user
)
expect
(
build
(
:key
,
user:
user
)).
not_to
be_valid
first_key
=
create
(
:key
,
user:
user
)
expect
(
build
(
:key
,
user:
user
,
key:
first_key
.
key
)).
not_to
be_valid
end
it
"does not accept a duplicate key with a different comment"
do
create
(
:key
,
user:
user
)
duplicate
=
build
(
:key
,
user:
user
)
first_key
=
create
(
:key
,
user:
user
)
duplicate
=
build
(
:key
,
user:
user
,
key:
first_key
.
key
)
duplicate
.
key
<<
' extra comment'
expect
(
duplicate
).
not_to
be_valid
end
end
...
...
spec/support/helpers/key_generator_helper.rb
0 → 100644
View file @
857d0391
module
Spec
module
Support
module
Helpers
class
KeyGeneratorHelper
# The components in a openssh .pub / known_host RSA public key.
RSA_COMPONENTS
=
[
'ssh-rsa'
,
:e
,
:n
].
freeze
attr_reader
:size
def
initialize
(
size
=
2048
)
@size
=
size
end
def
generate
key
=
OpenSSL
::
PKey
::
RSA
.
generate
(
size
)
components
=
RSA_COMPONENTS
.
map
do
|
component
|
key
.
respond_to?
(
component
)
?
encode_mpi
(
key
.
public_send
(
component
))
:
component
end
# Ruby tries to be helpful and adds new lines every 60 bytes :(
'ssh-rsa '
+
[
pack_pubkey_components
(
components
)].
pack
(
'm'
).
delete
(
"
\n
"
)
end
private
# Encodes an openssh-mpi-encoded integer.
def
encode_mpi
(
n
)
chars
,
n
=
[],
n
.
to_i
chars
<<
(
n
&
0xff
)
&&
n
>>=
8
while
n
!=
0
chars
<<
0
if
chars
.
empty?
||
chars
.
last
>=
0x80
chars
.
reverse
.
pack
(
'C*'
)
end
# Packs string components into an openssh-encoded pubkey.
def
pack_pubkey_components
(
strings
)
(
strings
.
map
{
|
s
|
[
s
.
length
].
pack
(
'N'
)
}).
zip
(
strings
).
flatten
.
join
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