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
Léo-Paul Géneau
gitlab-ce
Commits
7261bcaa
Commit
7261bcaa
authored
Aug 15, 2017
by
Douwe Maan
Committed by
Jose Ivan Vargas
Aug 16, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Merge branch 'forks-count-cache' into 'master'
Cache the number of forks of a project See merge request !13535
parent
b562e64f
Changes
14
Show whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
141 additions
and
1 deletion
+141
-1
app/models/project.rb
app/models/project.rb
+4
-1
app/services/projects/destroy_service.rb
app/services/projects/destroy_service.rb
+2
-0
app/services/projects/fork_service.rb
app/services/projects/fork_service.rb
+6
-0
app/services/projects/forks_count_service.rb
app/services/projects/forks_count_service.rb
+30
-0
app/services/projects/unlink_fork_service.rb
app/services/projects/unlink_fork_service.rb
+6
-0
changelogs/unreleased/forks-count-cache.yml
changelogs/unreleased/forks-count-cache.yml
+5
-0
lib/api/projects.rb
lib/api/projects.rb
+2
-0
lib/api/v3/projects.rb
lib/api/v3/projects.rb
+2
-0
spec/models/project_spec.rb
spec/models/project_spec.rb
+10
-0
spec/requests/api/projects_spec.rb
spec/requests/api/projects_spec.rb
+8
-0
spec/requests/api/v3/projects_spec.rb
spec/requests/api/v3/projects_spec.rb
+8
-0
spec/services/projects/fork_service_spec.rb
spec/services/projects/fork_service_spec.rb
+8
-0
spec/services/projects/forks_count_service_spec.rb
spec/services/projects/forks_count_service_spec.rb
+40
-0
spec/services/projects/unlink_fork_service_spec.rb
spec/services/projects/unlink_fork_service_spec.rb
+10
-0
No files found.
app/models/project.rb
View file @
7261bcaa
...
@@ -196,7 +196,6 @@ class Project < ActiveRecord::Base
...
@@ -196,7 +196,6 @@ class Project < ActiveRecord::Base
accepts_nested_attributes_for
:import_data
accepts_nested_attributes_for
:import_data
delegate
:name
,
to: :owner
,
allow_nil:
true
,
prefix:
true
delegate
:name
,
to: :owner
,
allow_nil:
true
,
prefix:
true
delegate
:count
,
to: :forks
,
prefix:
true
delegate
:members
,
to: :team
,
prefix:
true
delegate
:members
,
to: :team
,
prefix:
true
delegate
:add_user
,
:add_users
,
to: :team
delegate
:add_user
,
:add_users
,
to: :team
delegate
:add_guest
,
:add_reporter
,
:add_developer
,
:add_master
,
to: :team
delegate
:add_guest
,
:add_reporter
,
:add_developer
,
:add_master
,
to: :team
...
@@ -1393,6 +1392,10 @@ class Project < ActiveRecord::Base
...
@@ -1393,6 +1392,10 @@ class Project < ActiveRecord::Base
# @deprecated cannot remove yet because it has an index with its name in elasticsearch
# @deprecated cannot remove yet because it has an index with its name in elasticsearch
alias_method
:path_with_namespace
,
:full_path
alias_method
:path_with_namespace
,
:full_path
def
forks_count
Projects
::
ForksCountService
.
new
(
self
).
count
end
private
private
def
cross_namespace_reference?
(
from
)
def
cross_namespace_reference?
(
from
)
...
...
app/services/projects/destroy_service.rb
View file @
7261bcaa
...
@@ -128,6 +128,8 @@ module Projects
...
@@ -128,6 +128,8 @@ module Projects
project
.
repository
.
before_delete
project
.
repository
.
before_delete
Repository
.
new
(
wiki_path
,
project
,
disk_path:
repo_path
).
before_delete
Repository
.
new
(
wiki_path
,
project
,
disk_path:
repo_path
).
before_delete
Projects
::
ForksCountService
.
new
(
project
).
delete_cache
end
end
end
end
end
end
app/services/projects/fork_service.rb
View file @
7261bcaa
...
@@ -21,11 +21,17 @@ module Projects
...
@@ -21,11 +21,17 @@ module Projects
builds_access_level
=
@project
.
project_feature
.
builds_access_level
builds_access_level
=
@project
.
project_feature
.
builds_access_level
new_project
.
project_feature
.
update_attributes
(
builds_access_level:
builds_access_level
)
new_project
.
project_feature
.
update_attributes
(
builds_access_level:
builds_access_level
)
refresh_forks_count
new_project
new_project
end
end
private
private
def
refresh_forks_count
Projects
::
ForksCountService
.
new
(
@project
).
refresh_cache
end
def
allowed_visibility_level
def
allowed_visibility_level
project_level
=
@project
.
visibility_level
project_level
=
@project
.
visibility_level
...
...
app/services/projects/forks_count_service.rb
0 → 100644
View file @
7261bcaa
module
Projects
# Service class for getting and caching the number of forks of a project.
class
ForksCountService
def
initialize
(
project
)
@project
=
project
end
def
count
Rails
.
cache
.
fetch
(
cache_key
)
{
uncached_count
}
end
def
refresh_cache
Rails
.
cache
.
write
(
cache_key
,
uncached_count
)
end
def
delete_cache
Rails
.
cache
.
delete
(
cache_key
)
end
private
def
uncached_count
@project
.
forks
.
count
end
def
cache_key
[
'projects'
,
@project
.
id
,
'forks_count'
]
end
end
end
app/services/projects/unlink_fork_service.rb
View file @
7261bcaa
...
@@ -13,7 +13,13 @@ module Projects
...
@@ -13,7 +13,13 @@ module Projects
::
MergeRequests
::
CloseService
.
new
(
@project
,
@current_user
).
execute
(
mr
)
::
MergeRequests
::
CloseService
.
new
(
@project
,
@current_user
).
execute
(
mr
)
end
end
refresh_forks_count
(
@project
.
forked_from_project
)
@project
.
forked_project_link
.
destroy
@project
.
forked_project_link
.
destroy
end
end
def
refresh_forks_count
(
project
)
Projects
::
ForksCountService
.
new
(
project
).
refresh_cache
end
end
end
end
end
changelogs/unreleased/forks-count-cache.yml
0 → 100644
View file @
7261bcaa
---
title
:
Cache the number of forks of a project
merge_request
:
13535
author
:
type
:
other
lib/api/projects.rb
View file @
7261bcaa
...
@@ -351,6 +351,8 @@ module API
...
@@ -351,6 +351,8 @@ module API
if
user_project
.
forked_from_project
.
nil?
if
user_project
.
forked_from_project
.
nil?
user_project
.
create_forked_project_link
(
forked_to_project_id:
user_project
.
id
,
forked_from_project_id:
forked_from_project
.
id
)
user_project
.
create_forked_project_link
(
forked_to_project_id:
user_project
.
id
,
forked_from_project_id:
forked_from_project
.
id
)
::
Projects
::
ForksCountService
.
new
(
forked_from_project
).
refresh_cache
else
else
render_api_error!
(
"Project already forked"
,
409
)
render_api_error!
(
"Project already forked"
,
409
)
end
end
...
...
lib/api/v3/projects.rb
View file @
7261bcaa
...
@@ -388,6 +388,8 @@ module API
...
@@ -388,6 +388,8 @@ module API
if
user_project
.
forked_from_project
.
nil?
if
user_project
.
forked_from_project
.
nil?
user_project
.
create_forked_project_link
(
forked_to_project_id:
user_project
.
id
,
forked_from_project_id:
forked_from_project
.
id
)
user_project
.
create_forked_project_link
(
forked_to_project_id:
user_project
.
id
,
forked_from_project_id:
forked_from_project
.
id
)
::
Projects
::
ForksCountService
.
new
(
forked_from_project
).
refresh_cache
else
else
render_api_error!
(
"Project already forked"
,
409
)
render_api_error!
(
"Project already forked"
,
409
)
end
end
...
...
spec/models/project_spec.rb
View file @
7261bcaa
...
@@ -2305,4 +2305,14 @@ describe Project do
...
@@ -2305,4 +2305,14 @@ describe Project do
end
end
end
end
end
end
describe
'#forks_count'
do
it
'returns the number of forks'
do
project
=
build
(
:project
)
allow
(
project
.
forks
).
to
receive
(
:count
).
and_return
(
1
)
expect
(
project
.
forks_count
).
to
eq
(
1
)
end
end
end
end
spec/requests/api/projects_spec.rb
View file @
7261bcaa
...
@@ -1065,6 +1065,14 @@ describe API::Projects do
...
@@ -1065,6 +1065,14 @@ describe API::Projects do
expect
(
project_fork_target
.
forked?
).
to
be_truthy
expect
(
project_fork_target
.
forked?
).
to
be_truthy
end
end
it
'refreshes the forks count cachce'
do
expect
(
project_fork_source
.
forks_count
).
to
be_zero
post
api
(
"/projects/
#{
project_fork_target
.
id
}
/fork/
#{
project_fork_source
.
id
}
"
,
admin
)
expect
(
project_fork_source
.
forks_count
).
to
eq
(
1
)
end
it
'fails if forked_from project which does not exist'
do
it
'fails if forked_from project which does not exist'
do
post
api
(
"/projects/
#{
project_fork_target
.
id
}
/fork/9999"
,
admin
)
post
api
(
"/projects/
#{
project_fork_target
.
id
}
/fork/9999"
,
admin
)
expect
(
response
).
to
have_http_status
(
404
)
expect
(
response
).
to
have_http_status
(
404
)
...
...
spec/requests/api/v3/projects_spec.rb
View file @
7261bcaa
...
@@ -1004,6 +1004,14 @@ describe API::V3::Projects do
...
@@ -1004,6 +1004,14 @@ describe API::V3::Projects do
expect
(
project_fork_target
.
forked?
).
to
be_truthy
expect
(
project_fork_target
.
forked?
).
to
be_truthy
end
end
it
'refreshes the forks count cachce'
do
expect
(
project_fork_source
.
forks_count
).
to
be_zero
post
v3_api
(
"/projects/
#{
project_fork_target
.
id
}
/fork/
#{
project_fork_source
.
id
}
"
,
admin
)
expect
(
project_fork_source
.
forks_count
).
to
eq
(
1
)
end
it
'fails if forked_from project which does not exist'
do
it
'fails if forked_from project which does not exist'
do
post
v3_api
(
"/projects/
#{
project_fork_target
.
id
}
/fork/9999"
,
admin
)
post
v3_api
(
"/projects/
#{
project_fork_target
.
id
}
/fork/9999"
,
admin
)
expect
(
response
).
to
have_http_status
(
404
)
expect
(
response
).
to
have_http_status
(
404
)
...
...
spec/services/projects/fork_service_spec.rb
View file @
7261bcaa
...
@@ -50,6 +50,14 @@ describe Projects::ForkService do
...
@@ -50,6 +50,14 @@ describe Projects::ForkService do
expect
(
@from_project
.
avatar
.
file
).
to
be_exists
expect
(
@from_project
.
avatar
.
file
).
to
be_exists
end
end
it
'flushes the forks count cache of the source project'
do
expect
(
@from_project
.
forks_count
).
to
be_zero
fork_project
(
@from_project
,
@to_user
)
expect
(
@from_project
.
forks_count
).
to
eq
(
1
)
end
end
end
end
end
...
...
spec/services/projects/forks_count_service_spec.rb
0 → 100644
View file @
7261bcaa
require
'spec_helper'
describe
Projects
::
ForksCountService
do
let
(
:project
)
{
build
(
:project
,
id:
42
)
}
let
(
:service
)
{
described_class
.
new
(
project
)
}
describe
'#count'
do
it
'returns the number of forks'
do
allow
(
service
).
to
receive
(
:uncached_count
).
and_return
(
1
)
expect
(
service
.
count
).
to
eq
(
1
)
end
it
'caches the forks count'
,
:use_clean_rails_memory_store_caching
do
expect
(
service
).
to
receive
(
:uncached_count
).
once
.
and_return
(
1
)
2
.
times
{
service
.
count
}
end
end
describe
'#refresh_cache'
,
:use_clean_rails_memory_store_caching
do
it
'refreshes the cache'
do
expect
(
service
).
to
receive
(
:uncached_count
).
once
.
and_return
(
1
)
service
.
refresh_cache
expect
(
service
.
count
).
to
eq
(
1
)
end
end
describe
'#delete_cache'
,
:use_clean_rails_memory_store_caching
do
it
'removes the cache'
do
expect
(
service
).
to
receive
(
:uncached_count
).
twice
.
and_return
(
1
)
service
.
count
service
.
delete_cache
service
.
count
end
end
end
spec/services/projects/unlink_fork_service_spec.rb
View file @
7261bcaa
...
@@ -29,4 +29,14 @@ describe Projects::UnlinkForkService do
...
@@ -29,4 +29,14 @@ describe Projects::UnlinkForkService do
subject
.
execute
subject
.
execute
end
end
it
'refreshes the forks count cache of the source project'
do
source
=
fork_project
.
forked_from_project
expect
(
source
.
forks_count
).
to
eq
(
1
)
subject
.
execute
expect
(
source
.
forks_count
).
to
be_zero
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