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
6b5fb14f
Commit
6b5fb14f
authored
Oct 15, 2015
by
Valery Sizov
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/master' into ce_upstream_15_10
parents
8766c54b
62bf2eb8
Changes
13
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
290 additions
and
56 deletions
+290
-56
CHANGELOG
CHANGELOG
+1
-0
app/controllers/admin/services_controller.rb
app/controllers/admin/services_controller.rb
+7
-1
app/controllers/projects/services_controller.rb
app/controllers/projects/services_controller.rb
+7
-1
app/models/project_services/bamboo_service.rb
app/models/project_services/bamboo_service.rb
+1
-1
app/models/project_services/teamcity_service.rb
app/models/project_services/teamcity_service.rb
+1
-1
app/models/service.rb
app/models/service.rb
+28
-7
app/models/user.rb
app/models/user.rb
+8
-2
db/migrate/20151008110232_add_users_lower_username_email_indexes.rb
.../20151008110232_add_users_lower_username_email_indexes.rb
+17
-0
lib/tasks/migrate/setup_postgresql.rake
lib/tasks/migrate/setup_postgresql.rake
+2
-0
spec/benchmarks/models/user_spec.rb
spec/benchmarks/models/user_spec.rb
+3
-1
spec/models/project_services/bamboo_service_spec.rb
spec/models/project_services/bamboo_service_spec.rb
+56
-18
spec/models/project_services/teamcity_service_spec.rb
spec/models/project_services/teamcity_service_spec.rb
+55
-18
spec/models/service_spec.rb
spec/models/service_spec.rb
+104
-6
No files found.
CHANGELOG
View file @
6b5fb14f
...
...
@@ -8,6 +8,7 @@ v 8.1.0 (unreleased)
- Fix error preventing displaying of commit data for a directory with a leading dot (Stan Hu)
- Speed up load times of issue detail pages by roughly 1.5x
- Make diff file view easier to use on mobile screens (Stan Hu)
- Improved performance of finding users by username or Email address
- Add support for creating directories from Files page (Stan Hu)
- Allow removing of project without confirmation when JavaScript is disabled (Stan Hu)
- Support filtering by "Any" milestone or issue and fix "No Milestone" and "No Label" filters (Stan Hu)
...
...
app/controllers/admin/services_controller.rb
View file @
6b5fb14f
...
...
@@ -39,7 +39,13 @@ class Admin::ServicesController < Admin::ApplicationController
end
def
application_services_params
params
.
permit
(
:id
,
application_services_params
=
params
.
permit
(
:id
,
service:
Projects
::
ServicesController
::
ALLOWED_PARAMS
)
if
application_services_params
[
:service
].
is_a?
(
Hash
)
Projects
::
ServicesController
::
FILTER_BLANK_PARAMS
.
each
do
|
param
|
application_services_params
[
:service
].
delete
(
param
)
if
application_services_params
[
:service
][
param
].
blank?
end
end
application_services_params
end
end
app/controllers/projects/services_controller.rb
View file @
6b5fb14f
...
...
@@ -10,6 +10,10 @@ class Projects::ServicesController < Projects::ApplicationController
:jira_issue_transition_id
,
:notify
,
:color
,
:server_host
,
:server_port
,
:default_irc_uri
,
:enable_ssl_verification
]
# Parameters to ignore if no value is specified
FILTER_BLANK_PARAMS
=
[
:password
]
# Authorize
before_action
:authorize_admin_project!
before_action
:service
,
only:
[
:edit
,
:update
,
:test
]
...
...
@@ -60,7 +64,9 @@ class Projects::ServicesController < Projects::ApplicationController
def
service_params
service_params
=
params
.
require
(
:service
).
permit
(
ALLOWED_PARAMS
)
service_params
.
delete
(
"password"
)
if
service_params
[
"password"
].
blank?
FILTER_BLANK_PARAMS
.
each
do
|
param
|
service_params
.
delete
(
param
)
if
service_params
[
param
].
blank?
end
service_params
end
end
app/models/project_services/bamboo_service.rb
View file @
6b5fb14f
...
...
@@ -48,7 +48,7 @@ class BambooService < CiService
end
def
reset_password
if
prop_updated?
(
:bamboo_url
)
if
bamboo_url_changed?
&&
!
password_touched?
self
.
password
=
nil
end
end
...
...
app/models/project_services/teamcity_service.rb
View file @
6b5fb14f
...
...
@@ -45,7 +45,7 @@ class TeamcityService < CiService
end
def
reset_password
if
prop_updated?
(
:teamcity_url
)
if
teamcity_url_changed?
&&
!
password_touched?
self
.
password
=
nil
end
end
...
...
app/models/service.rb
View file @
6b5fb14f
...
...
@@ -33,6 +33,8 @@ class Service < ActiveRecord::Base
after_initialize
:initialize_properties
after_commit
:reset_updated_properties
belongs_to
:project
has_one
:service_hook
...
...
@@ -103,6 +105,7 @@ class Service < ActiveRecord::Base
# Provide convenient accessor methods
# for each serialized property.
# Also keep track of updated properties in a similar way as ActiveModel::Dirty
def
self
.
prop_accessor
(
*
args
)
args
.
each
do
|
arg
|
class_eval
%{
...
...
@@ -111,21 +114,39 @@ class Service < ActiveRecord::Base
end
def #{arg}=(value)
updated_properties['#{arg}'] = #{arg} unless #{arg}_changed?
self.properties['#{arg}'] = value
end
def #{arg}_changed?
#{arg}_touched? && #{arg} != #{arg}_was
end
def #{arg}_touched?
updated_properties.include?('#{arg}')
end
def #{arg}_was
updated_properties['#{arg}']
end
}
end
end
# ActiveRecord does not provide a mechanism to track changes in serialized keys.
# This is why we need to perform extra query to do it mannually.
def
prop_updated?
(
prop_name
)
relation_name
=
self
.
type
.
underscore
previous_value
=
project
.
send
(
relation_name
).
send
(
prop_name
)
return
false
if
previous_value
.
nil?
previous_value
!=
send
(
prop_name
)
# Returns a hash of the properties that have been assigned a new value since last save,
# indicating their original values (attr => original value).
# ActiveRecord does not provide a mechanism to track changes in serialized keys,
# so we need a specific implementation for service properties.
# This allows to track changes to properties set with the accessor methods,
# but not direct manipulation of properties hash.
def
updated_properties
@updated_properties
||=
ActiveSupport
::
HashWithIndifferentAccess
.
new
end
def
reset_updated_properties
@updated_properties
=
nil
end
def
async_execute
(
data
)
return
unless
supported_events
.
include?
(
data
[
:object_kind
])
...
...
app/models/user.rb
View file @
6b5fb14f
...
...
@@ -68,6 +68,7 @@ class User < ActiveRecord::Base
include
Referable
include
Sortable
include
TokenAuthenticatable
include
CaseSensitivity
default_value_for
:admin
,
false
default_value_for
:can_create_group
,
gitlab_config
.
default_can_create_group
...
...
@@ -280,8 +281,13 @@ class User < ActiveRecord::Base
end
def
by_login
(
login
)
where
(
'lower(username) = :value OR lower(email) = :value'
,
value:
login
.
to_s
.
downcase
).
first
return
nil
unless
login
if
login
.
include?
(
'@'
.
freeze
)
unscoped
.
iwhere
(
email:
login
).
take
else
unscoped
.
iwhere
(
username:
login
).
take
end
end
def
find_by_username!
(
username
)
...
...
db/migrate/20151008110232_add_users_lower_username_email_indexes.rb
0 → 100644
View file @
6b5fb14f
class
AddUsersLowerUsernameEmailIndexes
<
ActiveRecord
::
Migration
disable_ddl_transaction!
def
up
return
unless
Gitlab
::
Database
.
postgresql?
execute
'CREATE INDEX CONCURRENTLY index_on_users_lower_username ON users (LOWER(username));'
execute
'CREATE INDEX CONCURRENTLY index_on_users_lower_email ON users (LOWER(email));'
end
def
down
return
unless
Gitlab
::
Database
.
postgresql?
remove_index
:users
,
:index_on_users_lower_username
remove_index
:users
,
:index_on_users_lower_email
end
end
lib/tasks/migrate/setup_postgresql.rake
View file @
6b5fb14f
require
Rails
.
root
.
join
(
'db/migrate/20151007120511_namespaces_projects_path_lower_indexes'
)
require
Rails
.
root
.
join
(
'db/migrate/20151008110232_add_users_lower_username_email_indexes'
)
desc
'GitLab | Sets up PostgreSQL'
task
setup_postgresql: :environment
do
NamespacesProjectsPathLowerIndexes
.
new
.
up
AddUsersLowerUsernameEmailIndexes
.
new
.
up
end
spec/benchmarks/models/user_spec.rb
View file @
6b5fb14f
...
...
@@ -11,7 +11,9 @@ describe User, benchmark: true do
end
end
let
(
:iterations
)
{
1000
}
# The iteration count is based on the query taking little over 1 ms when
# using PostgreSQL.
let
(
:iterations
)
{
900
}
describe
'using a capitalized username'
do
benchmark_subject
{
User
.
by_login
(
'Alice'
)
}
...
...
spec/models/project_services/bamboo_service_spec.rb
View file @
6b5fb14f
...
...
@@ -30,27 +30,65 @@ describe BambooService, models: true do
let
(
:user
)
{
create
(
:user
)
}
let
(
:project
)
{
create
(
:project
)
}
before
do
@bamboo_service
=
BambooService
.
create
(
project:
create
(
:project
),
properties:
{
bamboo_url:
'http://gitlab.com'
,
username:
'mic'
,
password:
"password"
}
)
end
context
"when a password was previously set"
do
before
do
@bamboo_service
=
BambooService
.
create
(
project:
create
(
:project
),
properties:
{
bamboo_url:
'http://gitlab.com'
,
username:
'mic'
,
password:
"password"
}
)
end
it
"reset password if url changed"
do
@bamboo_service
.
bamboo_url
=
'http://gitlab1.com'
@bamboo_service
.
save
expect
(
@bamboo_service
.
password
).
to
be_nil
end
it
"does not reset password if username changed"
do
@bamboo_service
.
username
=
"some_name"
@bamboo_service
.
save
expect
(
@bamboo_service
.
password
).
to
eq
(
"password"
)
end
it
"does not reset password if new url is set together with password, even if it's the same password"
do
@bamboo_service
.
bamboo_url
=
'http://gitlab_edited.com'
@bamboo_service
.
password
=
'password'
@bamboo_service
.
save
expect
(
@bamboo_service
.
password
).
to
eq
(
"password"
)
expect
(
@bamboo_service
.
bamboo_url
).
to
eq
(
"http://gitlab_edited.com"
)
end
it
"reset password if url changed"
do
@bamboo_service
.
bamboo_url
=
'http://gitlab1.com'
@bamboo_service
.
save
expect
(
@bamboo_service
.
password
).
to
be_nil
it
"should reset password if url changed, even if setter called multiple times"
do
@bamboo_service
.
bamboo_url
=
'http://gitlab1.com'
@bamboo_service
.
bamboo_url
=
'http://gitlab1.com'
@bamboo_service
.
save
expect
(
@bamboo_service
.
password
).
to
be_nil
end
end
context
"when no password was previously set"
do
before
do
@bamboo_service
=
BambooService
.
create
(
project:
create
(
:project
),
properties:
{
bamboo_url:
'http://gitlab.com'
,
username:
'mic'
}
)
end
it
"saves password if new url is set together with password"
do
@bamboo_service
.
bamboo_url
=
'http://gitlab_edited.com'
@bamboo_service
.
password
=
'password'
@bamboo_service
.
save
expect
(
@bamboo_service
.
password
).
to
eq
(
"password"
)
expect
(
@bamboo_service
.
bamboo_url
).
to
eq
(
"http://gitlab_edited.com"
)
end
it
"does not reset password if username changed"
do
@bamboo_service
.
username
=
"some_name"
@bamboo_service
.
save
expect
(
@bamboo_service
.
password
).
to
eq
(
"password"
)
end
end
end
spec/models/project_services/teamcity_service_spec.rb
View file @
6b5fb14f
...
...
@@ -30,27 +30,64 @@ describe TeamcityService, models: true do
let
(
:user
)
{
create
(
:user
)
}
let
(
:project
)
{
create
(
:project
)
}
before
do
@teamcity_service
=
TeamcityService
.
create
(
project:
create
(
:project
),
properties:
{
teamcity_url:
'http://gitlab.com'
,
username:
'mic'
,
password:
"password"
}
)
end
context
"when a password was previously set"
do
before
do
@teamcity_service
=
TeamcityService
.
create
(
project:
create
(
:project
),
properties:
{
teamcity_url:
'http://gitlab.com'
,
username:
'mic'
,
password:
"password"
}
)
end
it
"reset password if url changed"
do
@teamcity_service
.
teamcity_url
=
'http://gitlab1.com'
@teamcity_service
.
save
expect
(
@teamcity_service
.
password
).
to
be_nil
end
it
"does not reset password if username changed"
do
@teamcity_service
.
username
=
"some_name"
@teamcity_service
.
save
expect
(
@teamcity_service
.
password
).
to
eq
(
"password"
)
end
it
"does not reset password if new url is set together with password, even if it's the same password"
do
@teamcity_service
.
teamcity_url
=
'http://gitlab_edited.com'
@teamcity_service
.
password
=
'password'
@teamcity_service
.
save
expect
(
@teamcity_service
.
password
).
to
eq
(
"password"
)
expect
(
@teamcity_service
.
teamcity_url
).
to
eq
(
"http://gitlab_edited.com"
)
end
it
"reset password if url changed"
do
@teamcity_service
.
teamcity_url
=
'http://gitlab1.com'
@teamcity_service
.
save
expect
(
@teamcity_service
.
password
).
to
be_nil
it
"should reset password if url changed, even if setter called multiple times"
do
@teamcity_service
.
teamcity_url
=
'http://gitlab1.com'
@teamcity_service
.
teamcity_url
=
'http://gitlab1.com'
@teamcity_service
.
save
expect
(
@teamcity_service
.
password
).
to
be_nil
end
end
context
"when no password was previously set"
do
before
do
@teamcity_service
=
TeamcityService
.
create
(
project:
create
(
:project
),
properties:
{
teamcity_url:
'http://gitlab.com'
,
username:
'mic'
}
)
end
it
"does not reset password if username changed"
do
@teamcity_service
.
username
=
"some_name"
@teamcity_service
.
save
expect
(
@teamcity_service
.
password
).
to
eq
(
"password"
)
it
"saves password if new url is set together with password"
do
@teamcity_service
.
teamcity_url
=
'http://gitlab_edited.com'
@teamcity_service
.
password
=
'password'
@teamcity_service
.
save
expect
(
@teamcity_service
.
password
).
to
eq
(
"password"
)
expect
(
@teamcity_service
.
teamcity_url
).
to
eq
(
"http://gitlab_edited.com"
)
end
end
end
end
spec/models/service_spec.rb
View file @
6b5fb14f
...
...
@@ -108,7 +108,7 @@ describe Service do
end
end
describe
"
#prop_updat
ed?"
do
describe
"
{property}_chang
ed?"
do
let
(
:service
)
do
BambooService
.
create
(
project:
create
(
:project
),
...
...
@@ -120,14 +120,112 @@ describe Service do
)
end
it
"returns false"
do
it
"returns false
when the property has not been assigned a new value
"
do
service
.
username
=
"key_changed"
expect
(
service
.
prop_updated?
(
:bamboo_url
)
).
to
be_falsy
expect
(
service
.
bamboo_url_changed?
).
to
be_falsy
end
it
"returns true"
do
service
.
bamboo_url
=
"http://other.com"
expect
(
service
.
prop_updated?
(
:bamboo_url
)).
to
be_truthy
it
"returns true when the property has been assigned a different value"
do
service
.
bamboo_url
=
"http://example.com"
expect
(
service
.
bamboo_url_changed?
).
to
be_truthy
end
it
"returns true when the property has been assigned a different value twice"
do
service
.
bamboo_url
=
"http://example.com"
service
.
bamboo_url
=
"http://example.com"
expect
(
service
.
bamboo_url_changed?
).
to
be_truthy
end
it
"returns false when the property has been re-assigned the same value"
do
service
.
bamboo_url
=
'http://gitlab.com'
expect
(
service
.
bamboo_url_changed?
).
to
be_falsy
end
it
"returns false when the property has been assigned a new value then saved"
do
service
.
bamboo_url
=
'http://example.com'
service
.
save
expect
(
service
.
bamboo_url_changed?
).
to
be_falsy
end
end
describe
"{property}_touched?"
do
let
(
:service
)
do
BambooService
.
create
(
project:
create
(
:project
),
properties:
{
bamboo_url:
'http://gitlab.com'
,
username:
'mic'
,
password:
"password"
}
)
end
it
"returns false when the property has not been assigned a new value"
do
service
.
username
=
"key_changed"
expect
(
service
.
bamboo_url_touched?
).
to
be_falsy
end
it
"returns true when the property has been assigned a different value"
do
service
.
bamboo_url
=
"http://example.com"
expect
(
service
.
bamboo_url_touched?
).
to
be_truthy
end
it
"returns true when the property has been assigned a different value twice"
do
service
.
bamboo_url
=
"http://example.com"
service
.
bamboo_url
=
"http://example.com"
expect
(
service
.
bamboo_url_touched?
).
to
be_truthy
end
it
"returns true when the property has been re-assigned the same value"
do
service
.
bamboo_url
=
'http://gitlab.com'
expect
(
service
.
bamboo_url_touched?
).
to
be_truthy
end
it
"returns false when the property has been assigned a new value then saved"
do
service
.
bamboo_url
=
'http://example.com'
service
.
save
expect
(
service
.
bamboo_url_changed?
).
to
be_falsy
end
end
describe
"{property}_was"
do
let
(
:service
)
do
BambooService
.
create
(
project:
create
(
:project
),
properties:
{
bamboo_url:
'http://gitlab.com'
,
username:
'mic'
,
password:
"password"
}
)
end
it
"returns nil when the property has not been assigned a new value"
do
service
.
username
=
"key_changed"
expect
(
service
.
bamboo_url_was
).
to
be_nil
end
it
"returns the previous value when the property has been assigned a different value"
do
service
.
bamboo_url
=
"http://example.com"
expect
(
service
.
bamboo_url_was
).
to
eq
(
'http://gitlab.com'
)
end
it
"returns initial value when the property has been re-assigned the same value"
do
service
.
bamboo_url
=
'http://gitlab.com'
expect
(
service
.
bamboo_url_was
).
to
eq
(
'http://gitlab.com'
)
end
it
"returns initial value when the property has been assigned multiple values"
do
service
.
bamboo_url
=
"http://example.com"
service
.
bamboo_url
=
"http://example2.com"
expect
(
service
.
bamboo_url_was
).
to
eq
(
'http://gitlab.com'
)
end
it
"returns nil when the property has been assigned a new value then saved"
do
service
.
bamboo_url
=
'http://example.com'
service
.
save
expect
(
service
.
bamboo_url_was
).
to
be_nil
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