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
08861da4
Commit
08861da4
authored
Jun 07, 2017
by
Adam Niedzielski
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
EE port of: "Fix incorrect ETag cache key when relative instance URL is used"
parent
63305cfe
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
48 additions
and
24 deletions
+48
-24
changelogs/unreleased/32995-issue-contents-dynamically-replaced-with-stale-version-after-saving-or-refreshing-relative-external_url-only.yml
...after-saving-or-refreshing-relative-external_url-only.yml
+4
-0
lib/gitlab/etag_caching/middleware.rb
lib/gitlab/etag_caching/middleware.rb
+5
-4
lib/gitlab/etag_caching/router.rb
lib/gitlab/etag_caching/router.rb
+2
-2
spec/lib/gitlab/etag_caching/middleware_spec.rb
spec/lib/gitlab/etag_caching/middleware_spec.rb
+19
-0
spec/lib/gitlab/etag_caching/router_spec.rb
spec/lib/gitlab/etag_caching/router_spec.rb
+18
-18
No files found.
changelogs/unreleased/32995-issue-contents-dynamically-replaced-with-stale-version-after-saving-or-refreshing-relative-external_url-only.yml
0 → 100644
View file @
08861da4
---
title
:
Fix incorrect ETag cache key when relative instance URL is used
merge_request
:
11964
author
:
lib/gitlab/etag_caching/middleware.rb
View file @
08861da4
...
@@ -6,12 +6,13 @@ module Gitlab
...
@@ -6,12 +6,13 @@ module Gitlab
end
end
def
call
(
env
)
def
call
(
env
)
route
=
Gitlab
::
EtagCaching
::
Router
.
match
(
env
)
request
=
Rack
::
Request
.
new
(
env
)
route
=
Gitlab
::
EtagCaching
::
Router
.
match
(
request
)
return
@app
.
call
(
env
)
unless
route
return
@app
.
call
(
env
)
unless
route
track_event
(
:etag_caching_middleware_used
,
route
)
track_event
(
:etag_caching_middleware_used
,
route
)
etag
,
cached_value_present
=
get_etag
(
env
)
etag
,
cached_value_present
=
get_etag
(
request
)
if_none_match
=
env
[
'HTTP_IF_NONE_MATCH'
]
if_none_match
=
env
[
'HTTP_IF_NONE_MATCH'
]
if
if_none_match
==
etag
if
if_none_match
==
etag
...
@@ -27,8 +28,8 @@ module Gitlab
...
@@ -27,8 +28,8 @@ module Gitlab
private
private
def
get_etag
(
env
)
def
get_etag
(
request
)
cache_key
=
env
[
'PATH_INFO'
]
cache_key
=
request
.
path
store
=
Gitlab
::
EtagCaching
::
Store
.
new
store
=
Gitlab
::
EtagCaching
::
Store
.
new
current_value
=
store
.
get
(
cache_key
)
current_value
=
store
.
get
(
cache_key
)
cached_value_present
=
current_value
.
present?
cached_value_present
=
current_value
.
present?
...
...
lib/gitlab/etag_caching/router.rb
View file @
08861da4
...
@@ -43,8 +43,8 @@ module Gitlab
...
@@ -43,8 +43,8 @@ module Gitlab
)
)
].
freeze
].
freeze
def
self
.
match
(
env
)
def
self
.
match
(
request
)
ROUTES
.
find
{
|
route
|
route
.
regexp
.
match
(
env
[
'PATH_INFO'
]
)
}
ROUTES
.
find
{
|
route
|
route
.
regexp
.
match
(
request
.
path_info
)
}
end
end
end
end
end
end
...
...
spec/lib/gitlab/etag_caching/middleware_spec.rb
View file @
08861da4
...
@@ -164,6 +164,25 @@ describe Gitlab::EtagCaching::Middleware do
...
@@ -164,6 +164,25 @@ describe Gitlab::EtagCaching::Middleware do
end
end
end
end
context
'when GitLab instance is using a relative URL'
do
before
do
mock_app_response
end
it
'uses full path as cache key'
do
env
=
{
'PATH_INFO'
=>
enabled_path
,
'SCRIPT_NAME'
=>
'/relative-gitlab'
}
expect_any_instance_of
(
Gitlab
::
EtagCaching
::
Store
)
.
to
receive
(
:get
).
with
(
"/relative-gitlab
#{
enabled_path
}
"
)
.
and_return
(
nil
)
middleware
.
call
(
env
)
end
end
def
mock_app_response
def
mock_app_response
allow
(
app
).
to
receive
(
:call
).
and_return
([
app_status_code
,
{},
[
'body'
]])
allow
(
app
).
to
receive
(
:call
).
and_return
([
app_status_code
,
{},
[
'body'
]])
end
end
...
...
spec/lib/gitlab/etag_caching/router_spec.rb
View file @
08861da4
...
@@ -2,93 +2,93 @@ require 'spec_helper'
...
@@ -2,93 +2,93 @@ require 'spec_helper'
describe
Gitlab
::
EtagCaching
::
Router
do
describe
Gitlab
::
EtagCaching
::
Router
do
it
'matches issue notes endpoint'
do
it
'matches issue notes endpoint'
do
env
=
build_env
(
request
=
build_request
(
'/my-group/and-subgroup/here-comes-the-project/noteable/issue/1/notes'
'/my-group/and-subgroup/here-comes-the-project/noteable/issue/1/notes'
)
)
result
=
described_class
.
match
(
env
)
result
=
described_class
.
match
(
request
)
expect
(
result
).
to
be_present
expect
(
result
).
to
be_present
expect
(
result
.
name
).
to
eq
'issue_notes'
expect
(
result
.
name
).
to
eq
'issue_notes'
end
end
it
'matches issue title endpoint'
do
it
'matches issue title endpoint'
do
env
=
build_env
(
request
=
build_request
(
'/my-group/my-project/issues/123/realtime_changes'
'/my-group/my-project/issues/123/realtime_changes'
)
)
result
=
described_class
.
match
(
env
)
result
=
described_class
.
match
(
request
)
expect
(
result
).
to
be_present
expect
(
result
).
to
be_present
expect
(
result
.
name
).
to
eq
'issue_title'
expect
(
result
.
name
).
to
eq
'issue_title'
end
end
it
'matches project pipelines endpoint'
do
it
'matches project pipelines endpoint'
do
env
=
build_env
(
request
=
build_request
(
'/my-group/my-project/pipelines.json'
'/my-group/my-project/pipelines.json'
)
)
result
=
described_class
.
match
(
env
)
result
=
described_class
.
match
(
request
)
expect
(
result
).
to
be_present
expect
(
result
).
to
be_present
expect
(
result
.
name
).
to
eq
'project_pipelines'
expect
(
result
.
name
).
to
eq
'project_pipelines'
end
end
it
'matches commit pipelines endpoint'
do
it
'matches commit pipelines endpoint'
do
env
=
build_env
(
request
=
build_request
(
'/my-group/my-project/commit/aa8260d253a53f73f6c26c734c72fdd600f6e6d4/pipelines.json'
'/my-group/my-project/commit/aa8260d253a53f73f6c26c734c72fdd600f6e6d4/pipelines.json'
)
)
result
=
described_class
.
match
(
env
)
result
=
described_class
.
match
(
request
)
expect
(
result
).
to
be_present
expect
(
result
).
to
be_present
expect
(
result
.
name
).
to
eq
'commit_pipelines'
expect
(
result
.
name
).
to
eq
'commit_pipelines'
end
end
it
'matches new merge request pipelines endpoint'
do
it
'matches new merge request pipelines endpoint'
do
env
=
build_env
(
request
=
build_request
(
'/my-group/my-project/merge_requests/new.json'
'/my-group/my-project/merge_requests/new.json'
)
)
result
=
described_class
.
match
(
env
)
result
=
described_class
.
match
(
request
)
expect
(
result
).
to
be_present
expect
(
result
).
to
be_present
expect
(
result
.
name
).
to
eq
'new_merge_request_pipelines'
expect
(
result
.
name
).
to
eq
'new_merge_request_pipelines'
end
end
it
'matches merge request pipelines endpoint'
do
it
'matches merge request pipelines endpoint'
do
env
=
build_env
(
request
=
build_request
(
'/my-group/my-project/merge_requests/234/pipelines.json'
'/my-group/my-project/merge_requests/234/pipelines.json'
)
)
result
=
described_class
.
match
(
env
)
result
=
described_class
.
match
(
request
)
expect
(
result
).
to
be_present
expect
(
result
).
to
be_present
expect
(
result
.
name
).
to
eq
'merge_request_pipelines'
expect
(
result
.
name
).
to
eq
'merge_request_pipelines'
end
end
it
'does not match blob with confusing name'
do
it
'does not match blob with confusing name'
do
env
=
build_env
(
request
=
build_request
(
'/my-group/my-project/blob/master/pipelines.json'
'/my-group/my-project/blob/master/pipelines.json'
)
)
result
=
described_class
.
match
(
env
)
result
=
described_class
.
match
(
request
)
expect
(
result
).
to
be_blank
expect
(
result
).
to
be_blank
end
end
it
'matches pipeline#show endpoint'
do
it
'matches pipeline#show endpoint'
do
env
=
build_env
(
request
=
build_request
(
'/my-group/my-project/pipelines/2.json'
'/my-group/my-project/pipelines/2.json'
)
)
result
=
described_class
.
match
(
env
)
result
=
described_class
.
match
(
request
)
expect
(
result
).
to
be_present
expect
(
result
).
to
be_present
expect
(
result
.
name
).
to
eq
'project_pipeline'
expect
(
result
.
name
).
to
eq
'project_pipeline'
end
end
def
build_
env
(
path
)
def
build_
request
(
path
)
{
'PATH_INFO'
=>
path
}
double
(
path_info:
path
)
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