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
a3b3cc22
Commit
a3b3cc22
authored
Jan 09, 2018
by
Tiago Botelho
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Moves remove_remote to a background job
parent
05d497e1
Changes
15
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
237 additions
and
46 deletions
+237
-46
app/models/repository.rb
app/models/repository.rb
+15
-1
app/workers/all_queues.yml
app/workers/all_queues.yml
+1
-0
app/workers/repository_remove_remote_worker.rb
app/workers/repository_remove_remote_worker.rb
+33
-0
changelogs/unreleased-ee/4099-remote-removal-port-to-background-job.yml
...eleased-ee/4099-remote-removal-port-to-background-job.yml
+5
-0
config/sidekiq_queues.yml
config/sidekiq_queues.yml
+1
-0
db/migrate/20180109150457_add_remote_name_to_remote_mirrors.rb
...grate/20180109150457_add_remote_name_to_remote_mirrors.rb
+9
-0
db/schema.rb
db/schema.rb
+1
-0
ee/app/models/ee/project.rb
ee/app/models/ee/project.rb
+1
-1
ee/app/models/remote_mirror.rb
ee/app/models/remote_mirror.rb
+25
-7
ee/app/services/projects/update_remote_mirror_service.rb
ee/app/services/projects/update_remote_mirror_service.rb
+1
-1
spec/factories/projects.rb
spec/factories/projects.rb
+1
-0
spec/models/remote_mirror_spec.rb
spec/models/remote_mirror_spec.rb
+30
-1
spec/models/repository_spec.rb
spec/models/repository_spec.rb
+32
-0
spec/services/projects/update_remote_mirror_service_spec.rb
spec/services/projects/update_remote_mirror_service_spec.rb
+35
-35
spec/workers/repository_remove_remote_worker_spec.rb
spec/workers/repository_remove_remote_worker_spec.rb
+47
-0
No files found.
app/models/repository.rb
View file @
a3b3cc22
...
@@ -1005,13 +1005,27 @@ class Repository
...
@@ -1005,13 +1005,27 @@ class Repository
add_remote
(
remote_name
,
url
,
mirror_refmap:
refmap
)
add_remote
(
remote_name
,
url
,
mirror_refmap:
refmap
)
fetch_remote
(
remote_name
,
forced:
forced
)
fetch_remote
(
remote_name
,
forced:
forced
)
ensure
ensure
remove_remote
(
remote_name
)
if
tmp_remote_name
schedule_
remove_remote
(
remote_name
)
if
tmp_remote_name
end
end
def
fetch_remote
(
remote
,
forced:
false
,
ssh_auth:
nil
,
no_tags:
false
)
def
fetch_remote
(
remote
,
forced:
false
,
ssh_auth:
nil
,
no_tags:
false
)
gitlab_shell
.
fetch_remote
(
raw_repository
,
remote
,
ssh_auth:
ssh_auth
,
forced:
forced
,
no_tags:
no_tags
)
gitlab_shell
.
fetch_remote
(
raw_repository
,
remote
,
ssh_auth:
ssh_auth
,
forced:
forced
,
no_tags:
no_tags
)
end
end
def
schedule_remove_remote
(
remote_name
)
return
unless
remote_name
job_id
=
RepositoryRemoveRemoteWorker
.
perform_async
(
project
.
id
,
remote_name
)
if
job_id
Rails
.
logger
.
info
(
"RepositoryRemoveRemoteWorker job scheduled for
#{
project
.
id
}
with remote name:
#{
remote_name
}
job ID
#{
job_id
}
."
)
else
Rails
.
logger
.
info
(
"RepositoryRemoveRemoteWorker job failed to create for
#{
project
.
id
}
with remote name
#{
remote_name
}
."
)
end
job_id
end
def
fetch_source_branch!
(
source_repository
,
source_branch
,
local_ref
)
def
fetch_source_branch!
(
source_repository
,
source_branch
,
local_ref
)
raw_repository
.
fetch_source_branch!
(
source_repository
.
raw_repository
,
source_branch
,
local_ref
)
raw_repository
.
fetch_source_branch!
(
source_repository
.
raw_repository
,
source_branch
,
local_ref
)
end
end
...
...
app/workers/all_queues.yml
View file @
a3b3cc22
...
@@ -93,6 +93,7 @@
...
@@ -93,6 +93,7 @@
-
rebase
-
rebase
-
repository_fork
-
repository_fork
-
repository_import
-
repository_import
-
repository_remove_remote
-
storage_migrator
-
storage_migrator
-
system_hook_push
-
system_hook_push
-
update_merge_requests
-
update_merge_requests
...
...
app/workers/repository_remove_remote_worker.rb
0 → 100644
View file @
a3b3cc22
class
RepositoryRemoveRemoteWorker
include
ApplicationWorker
LEASE_TIMEOUT
=
1
.
hour
def
perform
(
project_id
,
remote_name
)
lease_uuid
=
try_obtain_lease
(
project_id
)
return
unless
lease_uuid
project
=
Project
.
find
(
project_id
)
project
.
repository
.
remove_remote
(
remote_name
)
cancel_lease
(
project_id
,
lease_uuid
)
end
private
def
lease_key
(
project_id
)
"remove_remote_
#{
project_id
}
"
end
def
try_obtain_lease
(
id
)
key
=
lease_key
(
id
)
Gitlab
::
ExclusiveLease
.
new
(
key
,
timeout:
LEASE_TIMEOUT
).
try_obtain
end
def
cancel_lease
(
id
,
uuid
)
key
=
lease_key
(
id
)
Gitlab
::
ExclusiveLease
.
cancel
(
key
,
uuid
)
end
end
changelogs/unreleased-ee/4099-remote-removal-port-to-background-job.yml
0 → 100644
View file @
a3b3cc22
---
title
:
Ports remote removal to a background job
merge_request
:
author
:
type
:
changed
config/sidekiq_queues.yml
View file @
a3b3cc22
...
@@ -40,6 +40,7 @@
...
@@ -40,6 +40,7 @@
- [upload_checksum, 1]
- [upload_checksum, 1]
- [repository_fork, 1]
- [repository_fork, 1]
- [repository_import, 1]
- [repository_import, 1]
- [repository_remove_remote, 1]
- [github_importer, 1]
- [github_importer, 1]
- [github_import_advance_stage, 1]
- [github_import_advance_stage, 1]
- [project_service, 1]
- [project_service, 1]
...
...
db/migrate/20180109150457_add_remote_name_to_remote_mirrors.rb
0 → 100644
View file @
a3b3cc22
class
AddRemoteNameToRemoteMirrors
<
ActiveRecord
::
Migration
include
Gitlab
::
Database
::
MigrationHelpers
DOWNTIME
=
false
def
change
add_column
:remote_mirrors
,
:remote_name
,
:string
end
end
db/schema.rb
View file @
a3b3cc22
...
@@ -2029,6 +2029,7 @@ ActiveRecord::Schema.define(version: 20180113220114) do
...
@@ -2029,6 +2029,7 @@ ActiveRecord::Schema.define(version: 20180113220114) do
t
.
datetime
"updated_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
datetime
"last_update_started_at"
t
.
datetime
"last_update_started_at"
t
.
boolean
"only_protected_branches"
,
default:
false
,
null:
false
t
.
boolean
"only_protected_branches"
,
default:
false
,
null:
false
t
.
string
"remote_name"
end
end
add_index
"remote_mirrors"
,
[
"last_successful_update_at"
],
name:
"index_remote_mirrors_on_last_successful_update_at"
,
using: :btree
add_index
"remote_mirrors"
,
[
"last_successful_update_at"
],
name:
"index_remote_mirrors_on_last_successful_update_at"
,
using: :btree
...
...
ee/app/models/ee/project.rb
View file @
a3b3cc22
...
@@ -329,7 +329,7 @@ module EE
...
@@ -329,7 +329,7 @@ module EE
end
end
def
remove_mirror_repository_reference
def
remove_mirror_repository_reference
repository
.
remove_remote
(
::
Repository
::
MIRROR_REMOTE
)
repository
.
schedule_
remove_remote
(
::
Repository
::
MIRROR_REMOTE
)
end
end
def
import_url_availability
def
import_url_availability
...
...
ee/app/models/remote_mirror.rb
View file @
a3b3cc22
...
@@ -21,8 +21,9 @@ class RemoteMirror < ActiveRecord::Base
...
@@ -21,8 +21,9 @@ class RemoteMirror < ActiveRecord::Base
validate
:url_availability
,
if:
->
(
mirror
)
{
mirror
.
url_changed?
||
mirror
.
enabled?
}
validate
:url_availability
,
if:
->
(
mirror
)
{
mirror
.
url_changed?
||
mirror
.
enabled?
}
validates
:url
,
addressable_url:
true
,
if: :url_changed?
validates
:url
,
addressable_url:
true
,
if: :url_changed?
before_save
:refresh_remote
,
if: :mirror_url_changed?
after_save
:set_override_remote_mirror_available
,
unless:
->
{
Gitlab
::
CurrentSettings
.
current_application_settings
.
mirror_available
}
after_save
:set_override_remote_mirror_available
,
unless:
->
{
Gitlab
::
CurrentSettings
.
current_application_settings
.
mirror_available
}
after_save
:refresh_remote
,
if: :mirror_url_changed?
after_update
:reset_fields
,
if: :mirror_url_changed?
after_update
:reset_fields
,
if: :mirror_url_changed?
after_destroy
:remove_remote
after_destroy
:remove_remote
...
@@ -69,7 +70,12 @@ class RemoteMirror < ActiveRecord::Base
...
@@ -69,7 +70,12 @@ class RemoteMirror < ActiveRecord::Base
end
end
end
end
def
ref_name
def
remote_name
name
=
read_attribute
(
:remote_name
)
return
name
if
name
return
unless
id
"remote_mirror_
#{
id
}
"
"remote_mirror_
#{
id
}
"
end
end
...
@@ -149,7 +155,7 @@ class RemoteMirror < ActiveRecord::Base
...
@@ -149,7 +155,7 @@ class RemoteMirror < ActiveRecord::Base
private
private
def
raw
def
raw
@raw
||=
Gitlab
::
Git
::
RemoteMirror
.
new
(
project
.
repository
.
raw
,
re
f
_name
)
@raw
||=
Gitlab
::
Git
::
RemoteMirror
.
new
(
project
.
repository
.
raw
,
re
mote
_name
)
end
end
def
recently_scheduled?
def
recently_scheduled?
...
@@ -189,16 +195,28 @@ class RemoteMirror < ActiveRecord::Base
...
@@ -189,16 +195,28 @@ class RemoteMirror < ActiveRecord::Base
project
.
update
(
remote_mirror_available_overridden:
enabled
)
project
.
update
(
remote_mirror_available_overridden:
enabled
)
end
end
def
write_new_remote_name
self
.
remote_name
=
"remote_mirror_
#{
SecureRandom
.
hex
}
"
end
def
refresh_remote
def
refresh_remote
return
unless
project
return
unless
project
project
.
repository
.
add_remote
(
ref_name
,
url
)
# Before adding a new remote we have to delete the data from
# the previous remote name
prev_remote_name
=
remote_name
run_after_commit
do
project
.
repository
.
schedule_remove_remote
(
prev_remote_name
)
end
end
def
remove_remote
write_new_remote_name
if
project
# could be pending to delete so don't need to touch the git repository
project
.
repository
.
add_remote
(
remote_name
,
url
)
project
.
repository
.
remove_remote
(
ref_name
)
end
end
def
remove_remote
return
unless
project
# could be pending to delete so don't need to touch the git repository
project
.
repository
.
schedule_remove_remote
(
remote_name
)
end
end
def
mirror_url_changed?
def
mirror_url_changed?
...
...
ee/app/services/projects/update_remote_mirror_service.rb
View file @
a3b3cc22
...
@@ -8,7 +8,7 @@ module Projects
...
@@ -8,7 +8,7 @@ module Projects
return
success
unless
remote_mirror
.
enabled?
return
success
unless
remote_mirror
.
enabled?
begin
begin
repository
.
fetch_remote
(
remote_mirror
.
re
f
_name
,
no_tags:
true
)
repository
.
fetch_remote
(
remote_mirror
.
re
mote
_name
,
no_tags:
true
)
opts
=
{}
opts
=
{}
if
remote_mirror
.
only_protected_branches?
if
remote_mirror
.
only_protected_branches?
...
...
spec/factories/projects.rb
View file @
a3b3cc22
...
@@ -177,6 +177,7 @@ FactoryBot.define do
...
@@ -177,6 +177,7 @@ FactoryBot.define do
trait
:remote_mirror
do
trait
:remote_mirror
do
transient
do
transient
do
remote_name
"remote_mirror_
#{
SecureRandom
.
hex
}
"
url
"http://foo.com"
url
"http://foo.com"
enabled
true
enabled
true
end
end
...
...
spec/models/remote_mirror_spec.rb
View file @
a3b3cc22
...
@@ -68,7 +68,36 @@ describe RemoteMirror do
...
@@ -68,7 +68,36 @@ describe RemoteMirror do
mirror
.
update_attribute
(
:url
,
'http://foo:baz@test.com'
)
mirror
.
update_attribute
(
:url
,
'http://foo:baz@test.com'
)
config
=
repo
.
raw_repository
.
rugged
.
config
config
=
repo
.
raw_repository
.
rugged
.
config
expect
(
config
[
"remote.
#{
mirror
.
ref_name
}
.url"
]).
to
eq
(
'http://foo:baz@test.com'
)
expect
(
config
[
"remote.
#{
mirror
.
remote_name
}
.url"
]).
to
eq
(
'http://foo:baz@test.com'
)
end
end
end
describe
'#remote_name'
do
context
'when remote name is persisted in the database'
do
it
'returns remote name with random value'
do
allow
(
SecureRandom
).
to
receive
(
:hex
).
and_return
(
'secret'
)
remote_mirror
=
create
(
:remote_mirror
)
expect
(
remote_mirror
.
remote_name
).
to
eq
(
"remote_mirror_secret"
)
end
end
context
'when remote name is not persisted in the database'
do
it
'returns remote name with remote mirror id'
do
remote_mirror
=
create
(
:remote_mirror
)
remote_mirror
.
remote_name
=
nil
expect
(
remote_mirror
.
remote_name
).
to
eq
(
"remote_mirror_
#{
remote_mirror
.
id
}
"
)
end
end
context
'when remote is not persisted in the database'
do
it
'returns nil'
do
remote_mirror
=
build
(
:remote_mirror
,
remote_name:
nil
)
expect
(
remote_mirror
.
remote_name
).
to
be_nil
end
end
end
end
end
end
...
...
spec/models/repository_spec.rb
View file @
a3b3cc22
...
@@ -701,6 +701,38 @@ describe Repository do
...
@@ -701,6 +701,38 @@ describe Repository do
end
end
end
end
describe
'#schedule_remove_remote'
do
before
do
masterrev
=
repository
.
find_branch
(
'master'
).
dereferenced_target
create_remote_branch
(
'joe'
,
'remote_branch'
,
masterrev
)
end
context
'when worker is scheduled successfully'
do
before
do
masterrev
=
repository
.
find_branch
(
'master'
).
dereferenced_target
create_remote_branch
(
'remote_name'
,
'remote_branch'
,
masterrev
)
allow
(
RepositoryRemoveRemoteWorker
).
to
receive
(
:perform_async
).
and_return
(
'1234'
)
end
it
'returns job_id'
do
expect
(
repository
.
schedule_remove_remote
(
'joe'
)).
to
eq
(
'1234'
)
end
end
context
'when worker does not schedule successfully'
do
before
do
allow
(
RepositoryRemoveRemoteWorker
).
to
receive
(
:perform_async
).
and_return
(
nil
)
end
it
'returns nil'
do
expect
(
Rails
.
logger
).
to
receive
(
:info
).
with
(
"RepositoryRemoveRemoteWorker job failed to create for
#{
project
.
id
}
with remote name joe."
)
expect
(
repository
.
schedule_remove_remote
(
'joe'
)).
to
be_nil
end
end
end
describe
'#fetch_ref'
do
describe
'#fetch_ref'
do
let
(
:broken_repository
)
{
create
(
:project
,
:broken_storage
).
repository
}
let
(
:broken_repository
)
{
create
(
:project
,
:broken_storage
).
repository
}
...
...
spec/services/projects/update_remote_mirror_service_spec.rb
View file @
a3b3cc22
This diff is collapsed.
Click to expand it.
spec/workers/repository_remove_remote_worker_spec.rb
0 → 100644
View file @
a3b3cc22
require
'rails_helper'
describe
RepositoryRemoveRemoteWorker
do
describe
'#perform'
do
let
(
:remote_name
)
{
'joe'
}
let!
(
:project
)
{
create
(
:project
,
:repository
)
}
context
'when it does not get the lease'
do
it
'does not execute'
do
allow_any_instance_of
(
Gitlab
::
ExclusiveLease
).
to
receive
(
:try_obtain
).
and_return
(
false
)
expect_any_instance_of
(
Repository
).
not_to
receive
(
:remove_remote
)
subject
.
perform
(
project
.
id
,
remote_name
)
end
end
context
'when it gets the lease'
do
before
do
allow_any_instance_of
(
Gitlab
::
ExclusiveLease
).
to
receive
(
:try_obtain
).
and_return
(
true
)
end
context
'when project does not exist'
do
it
'returns nil'
do
expect
{
subject
.
perform
(
-
1
,
'remote_name'
)
}.
to
raise_error
(
ActiveRecord
::
RecordNotFound
)
end
end
context
'when project exists'
do
it
'removes remote from repository'
do
masterrev
=
project
.
repository
.
find_branch
(
'master'
).
dereferenced_target
create_remote_branch
(
remote_name
,
'remote_branch'
,
masterrev
)
expect_any_instance_of
(
Repository
).
to
receive
(
:remove_remote
).
with
(
remote_name
).
and_call_original
subject
.
perform
(
project
.
id
,
remote_name
)
end
end
end
end
def
create_remote_branch
(
remote_name
,
branch_name
,
target
)
rugged
=
project
.
repository
.
rugged
rugged
.
references
.
create
(
"refs/remotes/
#{
remote_name
}
/
#{
branch_name
}
"
,
target
.
id
)
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