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
0
Merge Requests
0
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
Boxiang Sun
gitlab-ce
Commits
934342de
Commit
934342de
authored
Aug 18, 2017
by
Douwe Maan
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'mk-setup-settings-properly' into 'master'
Setup settings properly See merge request !13645
parents
cc543b6c
a037a791
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
34 additions
and
1 deletion
+34
-1
config/initializers/1_settings.rb
config/initializers/1_settings.rb
+9
-1
spec/initializers/settings_spec.rb
spec/initializers/settings_spec.rb
+25
-0
No files found.
config/initializers/1_settings.rb
View file @
934342de
...
@@ -139,6 +139,8 @@ if Settings.ldap['enabled'] || Rails.env.test?
...
@@ -139,6 +139,8 @@ if Settings.ldap['enabled'] || Rails.env.test?
end
end
Settings
.
ldap
[
'servers'
].
each
do
|
key
,
server
|
Settings
.
ldap
[
'servers'
].
each
do
|
key
,
server
|
server
=
Settingslogic
.
new
(
server
)
server
[
'label'
]
||=
'LDAP'
server
[
'label'
]
||=
'LDAP'
server
[
'timeout'
]
||=
10
.
seconds
server
[
'timeout'
]
||=
10
.
seconds
server
[
'block_auto_created_users'
]
=
false
if
server
[
'block_auto_created_users'
].
nil?
server
[
'block_auto_created_users'
]
=
false
if
server
[
'block_auto_created_users'
].
nil?
...
@@ -165,6 +167,8 @@ if Settings.ldap['enabled'] || Rails.env.test?
...
@@ -165,6 +167,8 @@ if Settings.ldap['enabled'] || Rails.env.test?
MSG
MSG
Rails
.
logger
.
warn
(
message
)
Rails
.
logger
.
warn
(
message
)
end
end
Settings
.
ldap
[
'servers'
][
key
]
=
server
end
end
end
end
...
@@ -436,7 +440,9 @@ unless Settings.repositories.storages['default']
...
@@ -436,7 +440,9 @@ unless Settings.repositories.storages['default']
Settings
.
repositories
.
storages
[
'default'
][
'path'
]
||=
Settings
.
gitlab
[
'user_home'
]
+
'/repositories/'
Settings
.
repositories
.
storages
[
'default'
][
'path'
]
||=
Settings
.
gitlab
[
'user_home'
]
+
'/repositories/'
end
end
Settings
.
repositories
.
storages
.
values
.
each
do
|
storage
|
Settings
.
repositories
.
storages
.
each
do
|
key
,
storage
|
storage
=
Settingslogic
.
new
(
storage
)
# Expand relative paths
# Expand relative paths
storage
[
'path'
]
=
Settings
.
absolute
(
storage
[
'path'
])
storage
[
'path'
]
=
Settings
.
absolute
(
storage
[
'path'
])
# Set failure defaults
# Set failure defaults
...
@@ -450,6 +456,8 @@ Settings.repositories.storages.values.each do |storage|
...
@@ -450,6 +456,8 @@ Settings.repositories.storages.values.each do |storage|
storage
[
'failure_reset_time'
]
=
storage
[
'failure_reset_time'
].
to_i
storage
[
'failure_reset_time'
]
=
storage
[
'failure_reset_time'
].
to_i
# We might want to have a timeout shorter than 1 second.
# We might want to have a timeout shorter than 1 second.
storage
[
'storage_timeout'
]
=
storage
[
'storage_timeout'
].
to_f
storage
[
'storage_timeout'
]
=
storage
[
'storage_timeout'
].
to_f
Settings
.
repositories
.
storages
[
key
]
=
storage
end
end
#
#
...
...
spec/initializers/settings_spec.rb
View file @
934342de
...
@@ -2,6 +2,22 @@ require 'spec_helper'
...
@@ -2,6 +2,22 @@ require 'spec_helper'
require_relative
'../../config/initializers/1_settings'
require_relative
'../../config/initializers/1_settings'
describe
Settings
do
describe
Settings
do
describe
'#ldap'
do
it
'can be accessed with dot syntax all the way down'
do
expect
(
Gitlab
.
config
.
ldap
.
servers
.
main
.
label
).
to
eq
(
'ldap'
)
end
# Specifically trying to cause this error discovered in EE when removing the
# reassignment of each server element with Settingslogic.
#
# `undefined method `label' for #<Hash:0x007fbd18b59c08>`
#
it
'can be accessed in a very specific way that breaks without reassigning each element with Settingslogic'
do
server_settings
=
Gitlab
.
config
.
ldap
.
servers
[
'main'
]
expect
(
server_settings
.
label
).
to
eq
(
'ldap'
)
end
end
describe
'#repositories'
do
describe
'#repositories'
do
it
'assigns the default failure attributes'
do
it
'assigns the default failure attributes'
do
repository_settings
=
Gitlab
.
config
.
repositories
.
storages
[
'broken'
]
repository_settings
=
Gitlab
.
config
.
repositories
.
storages
[
'broken'
]
...
@@ -11,6 +27,15 @@ describe Settings do
...
@@ -11,6 +27,15 @@ describe Settings do
expect
(
repository_settings
[
'failure_reset_time'
]).
to
eq
(
1800
)
expect
(
repository_settings
[
'failure_reset_time'
]).
to
eq
(
1800
)
expect
(
repository_settings
[
'storage_timeout'
]).
to
eq
(
5
)
expect
(
repository_settings
[
'storage_timeout'
]).
to
eq
(
5
)
end
end
it
'can be accessed with dot syntax all the way down'
do
expect
(
Gitlab
.
config
.
repositories
.
storages
.
broken
.
failure_count_threshold
).
to
eq
(
10
)
end
it
'can be accessed in a very specific way that breaks without reassigning each element with Settingslogic'
do
storage_settings
=
Gitlab
.
config
.
repositories
.
storages
[
'broken'
]
expect
(
storage_settings
.
failure_count_threshold
).
to
eq
(
10
)
end
end
end
describe
'#host_without_www'
do
describe
'#host_without_www'
do
...
...
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