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
6a3fc833
Commit
6a3fc833
authored
Sep 06, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
27da119c
af0eb56e
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
158 additions
and
16 deletions
+158
-16
app/serializers/merge_request_noteable_entity.rb
app/serializers/merge_request_noteable_entity.rb
+1
-1
changelogs/unreleased/ac-accelerate-wiki-attachments.yml
changelogs/unreleased/ac-accelerate-wiki-attachments.yml
+5
-0
changelogs/unreleased/id-autosave-for-new-mr.yml
changelogs/unreleased/id-autosave-for-new-mr.yml
+5
-0
lib/api/validations/types/workhorse_file.rb
lib/api/validations/types/workhorse_file.rb
+20
-0
lib/api/wikis.rb
lib/api/wikis.rb
+16
-6
lib/gitlab/middleware/multipart.rb
lib/gitlab/middleware/multipart.rb
+16
-2
spec/features/merge_request/user_posts_notes_spec.rb
spec/features/merge_request/user_posts_notes_spec.rb
+8
-3
spec/fixtures/api/schemas/entities/merge_request_noteable.json
...fixtures/api/schemas/entities/merge_request_noteable.json
+4
-0
spec/requests/api/wikis_spec.rb
spec/requests/api/wikis_spec.rb
+12
-1
spec/requests/projects/uploads_spec.rb
spec/requests/projects/uploads_spec.rb
+38
-0
spec/serializers/merge_request_serializer_spec.rb
spec/serializers/merge_request_serializer_spec.rb
+3
-2
spec/support/helpers/workhorse_helpers.rb
spec/support/helpers/workhorse_helpers.rb
+30
-1
No files found.
app/serializers/merge_request_noteable_entity.rb
View file @
6a3fc833
# frozen_string_literal: true
# frozen_string_literal: true
class
MergeRequestNoteableEntity
<
Grape
::
Entity
class
MergeRequestNoteableEntity
<
Issuable
Entity
include
RequestAwareEntity
include
RequestAwareEntity
# Currently this attr is exposed to be used in app/assets/javascripts/notes/stores/getters.js
# Currently this attr is exposed to be used in app/assets/javascripts/notes/stores/getters.js
...
...
changelogs/unreleased/ac-accelerate-wiki-attachments.yml
0 → 100644
View file @
6a3fc833
---
title
:
Preprocess wiki attachments with GitLab-Workhorse
merge_request
:
32663
author
:
type
:
performance
changelogs/unreleased/id-autosave-for-new-mr.yml
0 → 100644
View file @
6a3fc833
---
title
:
Fix sharing localStorage with all MRs
merge_request
:
32699
author
:
type
:
fixed
lib/api/validations/types/workhorse_file.rb
0 → 100644
View file @
6a3fc833
# frozen_string_literal: true
module
API
module
Validations
module
Types
class
WorkhorseFile
<
Virtus
::
Attribute
def
coerce
(
input
)
# Processing of multipart file objects
# is already taken care of by Gitlab::Middleware::Multipart.
# Nothing to do here.
input
end
def
value_coerced?
(
value
)
value
.
is_a?
(
::
UploadedFile
)
end
end
end
end
end
lib/api/wikis.rb
View file @
6a3fc833
...
@@ -4,11 +4,21 @@ module API
...
@@ -4,11 +4,21 @@ module API
class
Wikis
<
Grape
::
API
class
Wikis
<
Grape
::
API
helpers
do
helpers
do
def
commit_params
(
attrs
)
def
commit_params
(
attrs
)
{
# In order to avoid service disruption this can work with an old workhorse without the acceleration
file_name:
attrs
[
:file
][
:filename
],
# the first branch of this if must be removed when we drop support for non accelerated uploads
file_content:
attrs
[
:file
][
:tempfile
].
read
,
if
attrs
[
:file
].
is_a?
(
Hash
)
branch_name:
attrs
[
:branch
]
{
}
file_name:
attrs
[
:file
][
:filename
],
file_content:
attrs
[
:file
][
:tempfile
].
read
,
branch_name:
attrs
[
:branch
]
}
else
{
file_name:
attrs
[
:file
].
original_filename
,
file_content:
attrs
[
:file
].
read
,
branch_name:
attrs
[
:branch
]
}
end
end
end
params
:common_wiki_page_params
do
params
:common_wiki_page_params
do
...
@@ -106,7 +116,7 @@ module API
...
@@ -106,7 +116,7 @@ module API
success
Entities
::
WikiAttachment
success
Entities
::
WikiAttachment
end
end
params
do
params
do
requires
:file
,
type
:
::
API
::
Validations
::
Types
::
SafeFile
,
desc:
'The attachment file to be uploaded'
requires
:file
,
type
s:
[
::
API
::
Validations
::
Types
::
SafeFile
,
::
API
::
Validations
::
Types
::
WorkhorseFile
]
,
desc:
'The attachment file to be uploaded'
optional
:branch
,
type:
String
,
desc:
'The name of the branch'
optional
:branch
,
type:
String
,
desc:
'The name of the branch'
end
end
post
":id/wikis/attachments"
do
post
":id/wikis/attachments"
do
...
...
lib/gitlab/middleware/multipart.rb
View file @
6a3fc833
...
@@ -32,7 +32,7 @@ module Gitlab
...
@@ -32,7 +32,7 @@ module Gitlab
class
Handler
class
Handler
def
initialize
(
env
,
message
)
def
initialize
(
env
,
message
)
@request
=
ActionDispatch
::
Request
.
new
(
env
)
@request
=
Rack
::
Request
.
new
(
env
)
@rewritten_fields
=
message
[
'rewritten_fields'
]
@rewritten_fields
=
message
[
'rewritten_fields'
]
@open_files
=
[]
@open_files
=
[]
end
end
...
@@ -50,7 +50,7 @@ module Gitlab
...
@@ -50,7 +50,7 @@ module Gitlab
value
=
decorate_params_value
(
value
,
@request
.
params
[
key
])
value
=
decorate_params_value
(
value
,
@request
.
params
[
key
])
end
end
@request
.
update_param
(
key
,
value
)
update_param
(
key
,
value
)
end
end
yield
yield
...
@@ -92,6 +92,20 @@ module Gitlab
...
@@ -92,6 +92,20 @@ module Gitlab
::
UploadedFile
.
from_params
(
params
,
key
,
allowed_paths
)
::
UploadedFile
.
from_params
(
params
,
key
,
allowed_paths
)
end
end
# update_params ensures that both rails controllers and rack middleware can find
# workhorse accelerate files in the request
def
update_param
(
key
,
value
)
# we make sure we have key in POST otherwise update_params will add it in GET
@request
.
POST
[
key
]
||=
value
# this will force Rack::Request to properly update env keys
@request
.
update_param
(
key
,
value
)
# ActionDispatch::Request is based on Rack::Request but it caches params
# inside other env keys, here we ensure everything is updated correctly
ActionDispatch
::
Request
.
new
(
@request
.
env
).
update_param
(
key
,
value
)
end
end
end
def
initialize
(
app
)
def
initialize
(
app
)
...
...
spec/features/merge_request/user_posts_notes_spec.rb
View file @
6a3fc833
...
@@ -5,7 +5,8 @@ require 'spec_helper'
...
@@ -5,7 +5,8 @@ require 'spec_helper'
describe
'Merge request > User posts notes'
,
:js
do
describe
'Merge request > User posts notes'
,
:js
do
include
NoteInteractionHelpers
include
NoteInteractionHelpers
let
(
:project
)
{
create
(
:project
,
:repository
)
}
set
(
:project
)
{
create
(
:project
,
:repository
)
}
let
(
:user
)
{
project
.
creator
}
let
(
:user
)
{
project
.
creator
}
let
(
:merge_request
)
do
let
(
:merge_request
)
do
create
(
:merge_request
,
source_project:
project
,
target_project:
project
)
create
(
:merge_request
,
source_project:
project
,
target_project:
project
)
...
@@ -33,17 +34,21 @@ describe 'Merge request > User posts notes', :js do
...
@@ -33,17 +34,21 @@ describe 'Merge request > User posts notes', :js do
end
end
describe
'with text'
do
describe
'with text'
do
let
(
:text
)
{
'This is awesome'
}
before
do
before
do
page
.
within
(
'.js-main-target-form'
)
do
page
.
within
(
'.js-main-target-form'
)
do
fill_in
'note[note]'
,
with:
'This is awesome'
fill_in
'note[note]'
,
with:
text
end
end
end
end
it
'has enable submit button
and preview button
'
do
it
'has enable submit button
, preview button and saves content to local storage
'
do
page
.
within
(
'.js-main-target-form'
)
do
page
.
within
(
'.js-main-target-form'
)
do
expect
(
page
).
not_to
have_css
(
'.js-comment-button[disabled]'
)
expect
(
page
).
not_to
have_css
(
'.js-comment-button[disabled]'
)
expect
(
page
).
to
have_css
(
'.js-md-preview-button'
,
visible:
true
)
expect
(
page
).
to
have_css
(
'.js-md-preview-button'
,
visible:
true
)
end
end
expect
(
page
.
evaluate_script
(
"localStorage['autosave/Note/MergeRequest/
#{
merge_request
.
id
}
']"
)).
to
eq
(
text
)
end
end
end
end
end
end
...
...
spec/fixtures/api/schemas/entities/merge_request_noteable.json
View file @
6a3fc833
{
{
"type"
:
"object"
,
"type"
:
"object"
,
"properties"
:
{
"properties"
:
{
"id"
:
{
"type"
:
"integer"
},
"iid"
:
{
"type"
:
"integer"
},
"title"
:
{
"type"
:
"string"
},
"description"
:
{
"type"
:
"string"
},
"merge_params"
:
{
"type"
:
[
"object"
,
"null"
]
},
"merge_params"
:
{
"type"
:
[
"object"
,
"null"
]
},
"state"
:
{
"type"
:
"string"
},
"state"
:
{
"type"
:
"string"
},
"source_branch"
:
{
"type"
:
"string"
},
"source_branch"
:
{
"type"
:
"string"
},
...
...
spec/requests/api/wikis_spec.rb
View file @
6a3fc833
...
@@ -11,6 +11,8 @@ require 'spec_helper'
...
@@ -11,6 +11,8 @@ require 'spec_helper'
# because they are 3 edge cases of using wiki pages.
# because they are 3 edge cases of using wiki pages.
describe
API
::
Wikis
do
describe
API
::
Wikis
do
include
WorkhorseHelpers
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:group
)
{
create
(
:group
).
tap
{
|
g
|
g
.
add_owner
(
user
)
}
}
let
(
:group
)
{
create
(
:group
).
tap
{
|
g
|
g
.
add_owner
(
user
)
}
}
let
(
:project_wiki
)
{
create
(
:project_wiki
,
project:
project
,
user:
user
)
}
let
(
:project_wiki
)
{
create
(
:project_wiki
,
project:
project
,
user:
user
)
}
...
@@ -155,7 +157,7 @@ describe API::Wikis do
...
@@ -155,7 +157,7 @@ describe API::Wikis do
it
'pushes attachment to the wiki repository'
do
it
'pushes attachment to the wiki repository'
do
allow
(
SecureRandom
).
to
receive
(
:hex
).
and_return
(
'fixed_hex'
)
allow
(
SecureRandom
).
to
receive
(
:hex
).
and_return
(
'fixed_hex'
)
post
(
api
(
url
,
user
)
,
params:
payload
)
workhorse_post_with_file
(
api
(
url
,
user
),
file_key: :file
,
params:
payload
)
expect
(
response
).
to
have_gitlab_http_status
(
201
)
expect
(
response
).
to
have_gitlab_http_status
(
201
)
expect
(
json_response
).
to
eq
result_hash
.
deep_stringify_keys
expect
(
json_response
).
to
eq
result_hash
.
deep_stringify_keys
...
@@ -180,6 +182,15 @@ describe API::Wikis do
...
@@ -180,6 +182,15 @@ describe API::Wikis do
expect
(
json_response
.
size
).
to
eq
(
1
)
expect
(
json_response
.
size
).
to
eq
(
1
)
expect
(
json_response
[
'error'
]).
to
eq
(
'file is invalid'
)
expect
(
json_response
[
'error'
]).
to
eq
(
'file is invalid'
)
end
end
it
'is backward compatible with regular multipart uploads'
do
allow
(
SecureRandom
).
to
receive
(
:hex
).
and_return
(
'fixed_hex'
)
post
(
api
(
url
,
user
),
params:
payload
)
expect
(
response
).
to
have_gitlab_http_status
(
201
)
expect
(
json_response
).
to
eq
result_hash
.
deep_stringify_keys
end
end
end
describe
'GET /projects/:id/wikis'
do
describe
'GET /projects/:id/wikis'
do
...
...
spec/requests/projects/uploads_spec.rb
0 → 100644
View file @
6a3fc833
# frozen_string_literal: true
require
'spec_helper'
describe
'File uploads'
do
include
WorkhorseHelpers
let
(
:project
)
{
create
(
:project
,
:public
,
:repository
)
}
let
(
:user
)
{
create
(
:user
)
}
describe
'POST /:namespace/:project/create/:branch'
do
let
(
:branch
)
{
'master'
}
let
(
:create_url
)
{
project_blob_path
(
project
,
branch
)
}
let
(
:blob_url
)
{
project_blob_path
(
project
,
"
#{
branch
}
/dk.png"
)
}
let
(
:params
)
do
{
namespace_id:
project
.
namespace
,
project_id:
project
,
id:
branch
,
branch_name:
branch
,
file:
fixture_file_upload
(
'spec/fixtures/dk.png'
),
commit_message:
'Add an image'
}
end
before
do
project
.
add_maintainer
(
user
)
login_as
(
user
)
end
it
'redirects to blob'
do
workhorse_post_with_file
(
create_url
,
file_key: :file
,
params:
params
)
expect
(
response
).
to
redirect_to
(
blob_url
)
end
end
end
spec/serializers/merge_request_serializer_spec.rb
View file @
6a3fc833
require
'spec_helper'
require
'spec_helper'
describe
MergeRequestSerializer
do
describe
MergeRequestSerializer
do
let
(
:user
)
{
create
(
:user
)
}
set
(
:user
)
{
create
(
:user
)
}
let
(
:resource
)
{
create
(
:merge_request
)
}
set
(
:resource
)
{
create
(
:merge_request
,
description:
"Description"
)
}
let
(
:json_entity
)
do
let
(
:json_entity
)
do
described_class
.
new
(
current_user:
user
)
described_class
.
new
(
current_user:
user
)
.
represent
(
resource
,
serializer:
serializer
)
.
represent
(
resource
,
serializer:
serializer
)
...
...
spec/support/helpers/workhorse_helpers.rb
View file @
6a3fc833
...
@@ -17,7 +17,36 @@ module WorkhorseHelpers
...
@@ -17,7 +17,36 @@ module WorkhorseHelpers
end
end
def
workhorse_internal_api_request_header
def
workhorse_internal_api_request_header
jwt_token
=
JWT
.
encode
({
'iss'
=>
'gitlab-workhorse'
},
Gitlab
::
Workhorse
.
secret
,
'HS256'
)
{
'HTTP_'
+
Gitlab
::
Workhorse
::
INTERNAL_API_REQUEST_HEADER
.
upcase
.
tr
(
'-'
,
'_'
)
=>
jwt_token
}
{
'HTTP_'
+
Gitlab
::
Workhorse
::
INTERNAL_API_REQUEST_HEADER
.
upcase
.
tr
(
'-'
,
'_'
)
=>
jwt_token
}
end
end
# workhorse_post_with_file will transform file_key inside params as if it was disk accelerated by workhorse
def
workhorse_post_with_file
(
url
,
file_key
:,
params
:)
workhorse_params
=
params
.
dup
file
=
workhorse_params
.
delete
(
file_key
)
workhorse_params
.
merge!
(
workhorse_disk_accelerated_file_params
(
file_key
,
file
))
post
(
url
,
params:
workhorse_params
,
headers:
workhorse_rewritten_fields_header
(
'file'
=>
file
.
path
)
)
end
private
def
jwt_token
(
data
=
{})
JWT
.
encode
({
'iss'
=>
'gitlab-workhorse'
}.
merge
(
data
),
Gitlab
::
Workhorse
.
secret
,
'HS256'
)
end
def
workhorse_rewritten_fields_header
(
fields
)
{
Gitlab
::
Middleware
::
Multipart
::
RACK_ENV_KEY
=>
jwt_token
(
'rewritten_fields'
=>
fields
)
}
end
def
workhorse_disk_accelerated_file_params
(
key
,
file
)
{
"
#{
key
}
.name"
=>
file
.
original_filename
,
"
#{
key
}
.path"
=>
file
.
path
}
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