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
f793b231
Commit
f793b231
authored
Dec 24, 2021
by
Andrejs Cunskis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
E2E: Validate merge request comments are migrated
parent
01049093
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
91 additions
and
26 deletions
+91
-26
qa/qa/resource/merge_request.rb
qa/qa/resource/merge_request.rb
+9
-1
qa/qa/specs/features/api/1_manage/bulk_import_project_spec.rb
...a/specs/features/api/1_manage/bulk_import_project_spec.rb
+36
-11
qa/qa/support/matchers/eventually_matcher.rb
qa/qa/support/matchers/eventually_matcher.rb
+46
-14
No files found.
qa/qa/resource/merge_request.rb
View file @
f793b231
...
@@ -168,7 +168,13 @@ module QA
...
@@ -168,7 +168,13 @@ module QA
)
)
end
end
protected
# Add mr comment
#
# @param [String] body
# @return [Hash]
def
add_comment
(
body
)
api_post_to
(
api_comments_path
,
body:
body
)
end
# Return subset of fields for comparing merge requests
# Return subset of fields for comparing merge requests
#
#
...
@@ -182,7 +188,9 @@ module QA
...
@@ -182,7 +188,9 @@ module QA
:project_id
,
:project_id
,
:source_project_id
,
:source_project_id
,
:target_project_id
,
:target_project_id
,
:merge_status
,
# these can differ depending on user fetching mr
# these can differ depending on user fetching mr
:user
,
:subscribed
,
:subscribed
,
:first_contribution
:first_contribution
).
merge
({
references:
api_resource
[
:references
].
except
(
:full
)
})
).
merge
({
references:
api_resource
[
:references
].
except
(
:full
)
})
...
...
qa/qa/specs/features/
ee/
api/1_manage/bulk_import_project_spec.rb
→
qa/qa/specs/features/api/1_manage/bulk_import_project_spec.rb
View file @
f793b231
...
@@ -5,6 +5,7 @@ module QA
...
@@ -5,6 +5,7 @@ module QA
# on staging environment
# on staging environment
RSpec
.
describe
'Manage'
,
:requires_admin
,
except:
{
subdomain: :staging
}
do
RSpec
.
describe
'Manage'
,
:requires_admin
,
except:
{
subdomain: :staging
}
do
describe
'Gitlab migration'
do
describe
'Gitlab migration'
do
let
(
:source_project_with_readme
)
{
false
}
let
(
:import_wait_duration
)
{
{
max_duration:
300
,
sleep_interval:
2
}
}
let
(
:import_wait_duration
)
{
{
max_duration:
300
,
sleep_interval:
2
}
}
let
(
:admin_api_client
)
{
Runtime
::
API
::
Client
.
as_admin
}
let
(
:admin_api_client
)
{
Runtime
::
API
::
Client
.
as_admin
}
let
(
:user
)
do
let
(
:user
)
do
...
@@ -33,7 +34,7 @@ module QA
...
@@ -33,7 +34,7 @@ module QA
Resource
::
Project
.
fabricate_via_api!
do
|
project
|
Resource
::
Project
.
fabricate_via_api!
do
|
project
|
project
.
api_client
=
api_client
project
.
api_client
=
api_client
project
.
group
=
source_group
project
.
group
=
source_group
project
.
initialize_with_readme
=
tru
e
project
.
initialize_with_readme
=
source_project_with_readm
e
end
end
end
end
...
@@ -63,8 +64,7 @@ module QA
...
@@ -63,8 +64,7 @@ module QA
Runtime
::
Feature
.
enable
(
:bulk_import_projects
)
Runtime
::
Feature
.
enable
(
:bulk_import_projects
)
sandbox
.
add_member
(
user
,
Resource
::
Members
::
AccessLevel
::
MAINTAINER
)
sandbox
.
add_member
(
user
,
Resource
::
Members
::
AccessLevel
::
MAINTAINER
)
source_project
# fabricate source group and project
source_project
.
tap
{
|
project
|
project
.
add_push_rules
(
member_check:
true
)
}
# fabricate source group and project
end
end
after
do
|
example
|
after
do
|
example
|
...
@@ -126,6 +126,7 @@ module QA
...
@@ -126,6 +126,7 @@ module QA
end
end
context
'with repository'
do
context
'with repository'
do
let
(
:source_project_with_readme
)
{
true
}
let
(
:source_commits
)
{
source_project
.
commits
.
map
{
|
c
|
c
.
except
(
:web_url
)
}
}
let
(
:source_commits
)
{
source_project
.
commits
.
map
{
|
c
|
c
.
except
(
:web_url
)
}
}
let
(
:source_tags
)
do
let
(
:source_tags
)
do
source_project
.
repository_tags
.
tap
do
|
tags
|
source_project
.
repository_tags
.
tap
do
|
tags
|
...
@@ -193,27 +194,42 @@ module QA
...
@@ -193,27 +194,42 @@ module QA
end
end
context
'with merge request'
do
context
'with merge request'
do
let
(
:other_user
)
do
Resource
::
User
.
fabricate_via_api!
do
|
usr
|
usr
.
api_client
=
admin_api_client
end
end
let
(
:source_mr
)
do
let
(
:source_mr
)
do
Resource
::
MergeRequest
.
fabricate_via_api!
do
|
mr
|
Resource
::
MergeRequest
.
fabricate_via_api!
do
|
mr
|
mr
.
no_preparation
=
true
mr
.
project
=
source_project
mr
.
project
=
source_project
mr
.
api_client
=
api_client
mr
.
api_client
=
Runtime
::
API
::
Client
.
new
(
user:
other_user
)
end
end
end
end
let
(
:imported_mrs
)
do
let
(
:source_comment
)
{
source_mr
.
add_comment
(
"This is a test comment!"
)
}
imported_project
.
merge_requests
end
let
(
:imported_mrs
)
{
imported_project
.
merge_requests
}
let
(
:imported_mr_comments
)
{
imported_mr
.
comments
}
let
(
:imported_mr
)
do
let
(
:imported_mr
)
do
Resource
::
MergeRequest
.
init
do
|
mr
|
Resource
::
MergeRequest
.
init
do
|
mr
|
mr
.
project
=
imported_project
mr
.
project
=
imported_project
mr
.
iid
=
imported_mrs
.
first
[
:iid
]
mr
.
iid
=
imported_mrs
.
first
[
:iid
]
mr
.
api_client
=
api_client
end
end
end
end
before
do
before
do
source_mr
# fabricate mr for import
other_user
.
set_public_email
source_project
.
add_member
(
other_user
,
Resource
::
Members
::
AccessLevel
::
MAINTAINER
)
source_comment
# fabricate mr and comment
source_mr
.
reload!
# update notes count attribute on object
end
after
do
other_user
.
remove_via_api!
end
end
it
(
it
(
...
@@ -222,8 +238,17 @@ module QA
...
@@ -222,8 +238,17 @@ module QA
)
do
)
do
expect_import_finished
expect_import_finished
aggregate_failures
do
expect
(
imported_mrs
.
count
).
to
eq
(
1
)
expect
(
imported_mrs
.
count
).
to
eq
(
1
)
expect
(
imported_mr
).
to
eq
(
source_mr
)
# TODO: remove custom comparison after member migration is implemented
# https://gitlab.com/gitlab-org/gitlab/-/issues/341886
expect
(
imported_mr
.
comparable
.
except
(
:author
)).
to
eq
(
source_mr
.
comparable
.
except
(
:author
))
expect
(
imported_mr_comments
.
count
).
to
eq
(
1
)
expect
(
imported_mr_comments
.
first
[
:body
]).
to
include
(
source_comment
[
:body
])
# Comment will have mention of original user since members are not migrated yet
expect
(
imported_mr_comments
.
first
[
:body
]).
to
include
(
other_user
.
name
)
end
end
end
end
end
end
end
...
...
qa/qa/support/matchers/eventually_matcher.rb
View file @
f793b231
...
@@ -28,27 +28,21 @@ module QA
...
@@ -28,27 +28,21 @@ module QA
RSpec
::
Matchers
.
define
(
:"eventually_
#{
op
}
"
)
do
|*
expected
|
RSpec
::
Matchers
.
define
(
:"eventually_
#{
op
}
"
)
do
|*
expected
|
chain
(
:within
)
do
|
kwargs
=
{}
|
chain
(
:within
)
do
|
kwargs
=
{}
|
@retry_args
=
kwargs
@retry_args
=
kwargs
@retry_args
[
:sleep_interval
]
=
0.5
unless
@retry_
args
[
:sleep_interval
]
@retry_args
[
:sleep_interval
]
=
0.5
unless
kw
args
[
:sleep_interval
]
end
end
def
supports_block_expectations?
description
{
"eventually
#{
operator_msg
}
:
#{
expected_formatted
}
"
}
true
end
match
{
|
actual
|
wait_and_check
(
actual
,
:default_expectation
)
}
match
{
|
actual
|
wait_and_check
(
actual
,
:default_expectation
)
}
match_when_negated
{
|
actual
|
wait_and_check
(
actual
,
:when_negated_expectation
)
}
match_when_negated
{
|
actual
|
wait_and_check
(
actual
,
:when_negated_expectation
)
}
description
do
failure_message
{
fail_message
}
"eventually
#{
operator_msg
}
#{
expected
.
inspect
}
"
end
failure_message
do
failure_message_when_negated
{
fail_message
(
negate:
true
)
}
"
#{
e
}
:
\n
expected to
#{
description
}
, last attempt was
#{
@result
.
nil?
?
'nil'
:
@result
}
"
end
failure_message_when_negated
do
def
supports_block_expectations?
"
#{
e
}
:
\n
expected not to
#{
description
}
, last attempt was
#{
@result
.
nil?
?
'nil'
:
@result
}
"
true
end
end
# Execute rspec expectation within retrier
# Execute rspec expectation within retrier
...
@@ -60,9 +54,9 @@ module QA
...
@@ -60,9 +54,9 @@ module QA
attempt
=
0
attempt
=
0
QA
::
Runtime
::
Logger
.
debug
(
QA
::
Runtime
::
Logger
.
debug
(
"Running eventually matcher with '
#{
operator_msg
}
' operator with:
#{
@retry_args
}
"
"Running eventually matcher with '
#{
operator_msg
}
' operator with:
'
#{
retry_args
}
' arguments
"
)
)
QA
::
Support
::
Retrier
.
retry_until
(
**
@
retry_args
,
log:
false
)
do
QA
::
Support
::
Retrier
.
retry_until
(
**
retry_args
,
log:
false
)
do
QA
::
Runtime
::
Logger
.
debug
(
"evaluating expectation, attempt:
#{
attempt
+=
1
}
"
)
QA
::
Runtime
::
Logger
.
debug
(
"evaluating expectation, attempt:
#{
attempt
+=
1
}
"
)
public_send
(
expectation_name
,
actual
)
public_send
(
expectation_name
,
actual
)
...
@@ -132,6 +126,44 @@ module QA
...
@@ -132,6 +126,44 @@ module QA
[
operator
,
expected
]
[
operator
,
expected
]
end
end
end
end
# Custom retry arguments
#
# @return [Hash]
def
retry_args
@retry_args
||=
{
sleep_interval:
0.5
}
end
# Custom failure message
#
# @param [Boolean] negate
# @return [String]
def
fail_message
(
negate:
false
)
"
#{
e
}
:
\n\n
expected
#{
negate
?
'not '
:
''
}
to
#{
description
}
\n\n
"
\
"last attempt was:
#{
@result
.
nil?
?
'nil'
:
actual_formatted
}
\n\n
"
\
"Diff:
#{
diff
}
"
end
# Formatted expect
#
# @return [String]
def
expected_formatted
RSpec
::
Support
::
ObjectFormatter
.
format
(
expected
)
end
# Formatted actual result
#
# @return [String]
def
actual_formatted
RSpec
::
Support
::
ObjectFormatter
.
format
(
@result
)
end
# Object diff
#
# @return [String]
def
diff
RSpec
::
Support
::
Differ
.
new
(
color:
true
).
diff
(
@result
,
expected
)
end
end
end
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