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
5168d1fa
Commit
5168d1fa
authored
Jul 30, 2020
by
Francisco Javier López
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve user_creates_snippet spec
parent
75816023
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
20 additions
and
64 deletions
+20
-64
spec/features/snippets/user_creates_snippet_spec.rb
spec/features/snippets/user_creates_snippet_spec.rb
+20
-64
No files found.
spec/features/snippets/user_creates_snippet_spec.rb
View file @
5168d1fa
...
@@ -2,7 +2,17 @@
...
@@ -2,7 +2,17 @@
require
'spec_helper'
require
'spec_helper'
RSpec
.
shared_examples_for
'snippet editor'
do
RSpec
.
describe
'User creates snippet'
,
:js
do
include
DropzoneHelper
let_it_be
(
:user
)
{
create
(
:user
)
}
let
(
:title
)
{
'My Snippet Title'
}
let
(
:file_content
)
{
'Hello World!'
}
let
(
:md_description
)
{
'My Snippet **Description**'
}
let
(
:description
)
{
'My Snippet Description'
}
let
(
:created_snippet
)
{
Snippet
.
last
}
before
do
before
do
stub_feature_flags
(
snippets_vue:
false
)
stub_feature_flags
(
snippets_vue:
false
)
stub_feature_flags
(
snippets_edit_vue:
false
)
stub_feature_flags
(
snippets_edit_vue:
false
)
...
@@ -14,15 +24,15 @@ RSpec.shared_examples_for 'snippet editor' do
...
@@ -14,15 +24,15 @@ RSpec.shared_examples_for 'snippet editor' do
end
end
def
fill_form
def
fill_form
fill_in
'personal_snippet_title'
,
with:
'My Snippet Title'
fill_in
'personal_snippet_title'
,
with:
title
# Click placeholder first to expand full description field
# Click placeholder first to expand full description field
description_field
.
click
description_field
.
click
fill_in
'personal_snippet_description'
,
with:
'My Snippet **Description**'
fill_in
'personal_snippet_description'
,
with:
md_description
page
.
within
(
'.file-editor'
)
do
page
.
within
(
'.file-editor'
)
do
el
=
find
(
'.inputarea'
)
el
=
find
(
'.inputarea'
)
el
.
send_keys
'Hello World!'
el
.
send_keys
file_content
end
end
end
end
...
@@ -34,12 +44,12 @@ RSpec.shared_examples_for 'snippet editor' do
...
@@ -34,12 +44,12 @@ RSpec.shared_examples_for 'snippet editor' do
click_button
(
'Create snippet'
)
click_button
(
'Create snippet'
)
wait_for_requests
wait_for_requests
expect
(
page
).
to
have_content
(
'My Snippet Title'
)
expect
(
page
).
to
have_content
(
title
)
page
.
within
(
'.snippet-header .description'
)
do
page
.
within
(
'.snippet-header .description'
)
do
expect
(
page
).
to
have_content
(
'My Snippet Description'
)
expect
(
page
).
to
have_content
(
description
)
expect
(
page
).
to
have_selector
(
'strong'
)
expect
(
page
).
to
have_selector
(
'strong'
)
end
end
expect
(
page
).
to
have_content
(
'Hello World!'
)
expect
(
page
).
to
have_content
(
file_content
)
end
end
it
'previews a snippet with file'
do
it
'previews a snippet with file'
do
...
@@ -57,7 +67,7 @@ RSpec.shared_examples_for 'snippet editor' do
...
@@ -57,7 +67,7 @@ RSpec.shared_examples_for 'snippet editor' do
link
=
find
(
'a.no-attachment-icon img.js-lazy-loaded[alt="banana_sample"]'
)[
'src'
]
link
=
find
(
'a.no-attachment-icon img.js-lazy-loaded[alt="banana_sample"]'
)[
'src'
]
expect
(
link
).
to
match
(
%r{/uploads/-/system/user/
#{
user
.
id
}
/
\h
{32}/banana_sample
\.
gif
\z
}
)
expect
(
link
).
to
match
(
%r{/uploads/-/system/user/
#{
user
.
id
}
/
\h
{32}/banana_sample
\.
gif
\z
}
)
# Adds a cache buster for checking if the image exists as Selenium is now handling the cached re
g
quests
# Adds a cache buster for checking if the image exists as Selenium is now handling the cached requests
# not anymore as requests when they come straight from memory cache.
# not anymore as requests when they come straight from memory cache.
reqs
=
inspect_requests
{
visit
(
"
#{
link
}
?ran=
#{
SecureRandom
.
base64
(
20
)
}
"
)
}
reqs
=
inspect_requests
{
visit
(
"
#{
link
}
?ran=
#{
SecureRandom
.
base64
(
20
)
}
"
)
}
expect
(
reqs
.
first
.
status_code
).
to
eq
(
200
)
expect
(
reqs
.
first
.
status_code
).
to
eq
(
200
)
...
@@ -99,15 +109,10 @@ RSpec.shared_examples_for 'snippet editor' do
...
@@ -99,15 +109,10 @@ RSpec.shared_examples_for 'snippet editor' do
wait_for_requests
wait_for_requests
end
end
it
'displays the error'
do
it
'
renders the new page and
displays the error'
do
expect
(
page
).
to
have_content
(
error
)
expect
(
page
).
to
have_content
(
error
)
end
it
'renders new page'
do
expect
(
page
).
to
have_content
(
'New Snippet'
)
expect
(
page
).
to
have_content
(
'New Snippet'
)
end
it
'has the correct action path'
do
action
=
find
(
'form.snippet-form'
)[
'action'
]
action
=
find
(
'form.snippet-form'
)[
'action'
]
expect
(
action
).
to
match
(
%r{/snippets
\z
}
)
expect
(
action
).
to
match
(
%r{/snippets
\z
}
)
end
end
...
@@ -116,46 +121,10 @@ RSpec.shared_examples_for 'snippet editor' do
...
@@ -116,46 +121,10 @@ RSpec.shared_examples_for 'snippet editor' do
it
'validation fails for the first time'
do
it
'validation fails for the first time'
do
visit
new_snippet_path
visit
new_snippet_path
fill_in
'personal_snippet_title'
,
with:
'My Snippet Title'
fill_in
'personal_snippet_title'
,
with:
title
click_button
(
'Create snippet'
)
click_button
(
'Create snippet'
)
expect
(
page
).
to
have_selector
(
'#error_explanation'
)
expect
(
page
).
to
have_selector
(
'#error_explanation'
)
fill_form
dropzone_file
Rails
.
root
.
join
(
'spec'
,
'fixtures'
,
'banana_sample.gif'
)
click_button
(
'Create snippet'
)
wait_for_requests
expect
(
page
).
to
have_content
(
'My Snippet Title'
)
page
.
within
(
'.snippet-header .description'
)
do
expect
(
page
).
to
have_content
(
'My Snippet Description'
)
expect
(
page
).
to
have_selector
(
'strong'
)
end
expect
(
page
).
to
have_content
(
'Hello World!'
)
link
=
find
(
'a.no-attachment-icon img.js-lazy-loaded[alt="banana_sample"]'
)[
'src'
]
expect
(
link
).
to
match
(
%r{/uploads/-/system/personal_snippet/
#{
Snippet
.
last
.
id
}
/
\h
{32}/banana_sample
\.
gif
\z
}
)
reqs
=
inspect_requests
{
visit
(
"
#{
link
}
?ran=
#{
SecureRandom
.
base64
(
20
)
}
"
)
}
expect
(
reqs
.
first
.
status_code
).
to
eq
(
200
)
end
it
'Authenticated user creates a snippet with + in filename'
do
visit
new_snippet_path
fill_in
'personal_snippet_title'
,
with:
'My Snippet Title'
page
.
within
(
'.file-editor'
)
do
find
(
:xpath
,
"//input[@id='personal_snippet_file_name']"
).
set
'snippet+file+name'
el
=
find
(
'.inputarea'
)
el
.
send_keys
'Hello World!'
end
click_button
'Create snippet'
wait_for_requests
expect
(
page
).
to
have_content
(
'My Snippet Title'
)
expect
(
page
).
to
have_content
(
'snippet+file+name'
)
expect
(
page
).
to
have_content
(
'Hello World!'
)
end
end
context
'when snippets default visibility level is restricted'
do
context
'when snippets default visibility level is restricted'
do
...
@@ -172,20 +141,7 @@ RSpec.shared_examples_for 'snippet editor' do
...
@@ -172,20 +141,7 @@ RSpec.shared_examples_for 'snippet editor' do
click_button
(
'Create snippet'
)
click_button
(
'Create snippet'
)
wait_for_requests
wait_for_requests
visit
snippets_path
click_link
(
'Internal'
)
expect
(
page
).
to
have_content
(
'My Snippet Title'
)
created_snippet
=
Snippet
.
last
expect
(
created_snippet
.
visibility_level
).
to
eq
(
Gitlab
::
VisibilityLevel
::
INTERNAL
)
expect
(
created_snippet
.
visibility_level
).
to
eq
(
Gitlab
::
VisibilityLevel
::
INTERNAL
)
end
end
end
end
end
end
RSpec
.
describe
'User creates snippet'
,
:js
do
include
DropzoneHelper
let_it_be
(
:user
)
{
create
(
:user
)
}
it_behaves_like
"snippet editor"
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