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
85558bab
Commit
85558bab
authored
Jun 17, 2021
by
David Fernandez
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve gradle QA scenario
by adding the pull action Changelog: other
parent
095e2843
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
205 additions
and
85 deletions
+205
-85
app/views/shared/deploy_tokens/_form.html.haml
app/views/shared/deploy_tokens/_form.html.haml
+1
-1
qa/qa/page/project/settings/deploy_tokens.rb
qa/qa/page/project/settings/deploy_tokens.rb
+3
-1
qa/qa/resource/deploy_token.rb
qa/qa/resource/deploy_token.rb
+1
-1
qa/qa/resource/package.rb
qa/qa/resource/package.rb
+3
-4
qa/qa/specs/features/browser_ui/5_package/maven_gradle_repository_spec.rb
...ures/browser_ui/5_package/maven_gradle_repository_spec.rb
+197
-78
No files found.
app/views/shared/deploy_tokens/_form.html.haml
View file @
85558bab
...
@@ -38,7 +38,7 @@
...
@@ -38,7 +38,7 @@
-
if
packages_registry_enabled?
(
group_or_project
)
-
if
packages_registry_enabled?
(
group_or_project
)
%fieldset
.form-group.form-check
%fieldset
.form-group.form-check
=
f
.
check_box
:read_package_registry
,
class:
'form-check-input'
=
f
.
check_box
:read_package_registry
,
class:
'form-check-input'
,
data:
{
qa_selector:
'deploy_token_read_package_registry_checkbox'
}
=
f
.
label
:read_package_registry
,
'read_package_registry'
,
class:
'label-bold form-check-label'
=
f
.
label
:read_package_registry
,
'read_package_registry'
,
class:
'label-bold form-check-label'
.text-secondary
=
s_
(
'DeployTokens|Allows read access to the package registry.'
)
.text-secondary
=
s_
(
'DeployTokens|Allows read access to the package registry.'
)
...
...
qa/qa/page/project/settings/deploy_tokens.rb
View file @
85558bab
...
@@ -9,6 +9,7 @@ module QA
...
@@ -9,6 +9,7 @@ module QA
element
:deploy_token_name_field
element
:deploy_token_name_field
element
:deploy_token_expires_at_field
element
:deploy_token_expires_at_field
element
:deploy_token_read_repository_checkbox
element
:deploy_token_read_repository_checkbox
element
:deploy_token_read_package_registry_checkbox
element
:deploy_token_read_registry_checkbox
element
:deploy_token_read_registry_checkbox
element
:create_deploy_token_button
element
:create_deploy_token_button
end
end
...
@@ -27,8 +28,9 @@ module QA
...
@@ -27,8 +28,9 @@ module QA
fill_element
(
:deploy_token_expires_at_field
,
expires_at
.
to_s
+
"
\n
"
)
fill_element
(
:deploy_token_expires_at_field
,
expires_at
.
to_s
+
"
\n
"
)
end
end
def
fill_scopes
(
read_repository
:
,
read_registry
:
)
def
fill_scopes
(
read_repository:
false
,
read_registry:
false
,
read_package_registry:
false
)
check_element
(
:deploy_token_read_repository_checkbox
)
if
read_repository
check_element
(
:deploy_token_read_repository_checkbox
)
if
read_repository
check_element
(
:deploy_token_read_package_registry_checkbox
)
if
read_package_registry
check_element
(
:deploy_token_read_registry_checkbox
)
if
read_registry
check_element
(
:deploy_token_read_registry_checkbox
)
if
read_registry
end
end
...
...
qa/qa/resource/deploy_token.rb
View file @
85558bab
...
@@ -37,7 +37,7 @@ module QA
...
@@ -37,7 +37,7 @@ module QA
setting
.
expand_deploy_tokens
do
|
page
|
setting
.
expand_deploy_tokens
do
|
page
|
page
.
fill_token_name
(
name
)
page
.
fill_token_name
(
name
)
page
.
fill_token_expires_at
(
expires_at
)
page
.
fill_token_expires_at
(
expires_at
)
page
.
fill_scopes
(
read_repository:
true
,
read_
registry:
fals
e
)
page
.
fill_scopes
(
read_repository:
true
,
read_
package_registry:
tru
e
)
page
.
add_token
page
.
add_token
end
end
...
...
qa/qa/resource/package.rb
View file @
85558bab
...
@@ -15,11 +15,10 @@ module QA
...
@@ -15,11 +15,10 @@ module QA
end
end
attribute
:id
do
attribute
:id
do
packages
=
project
.
packages
this_package
=
project
.
packages
&
.
find
{
|
package
|
package
[
:name
]
==
name
}
return
unless
(
this_package
=
packages
&
.
find
{
|
package
|
package
[
:name
]
==
"
#{
project
.
path_with_namespace
}
/
#{
name
}
"
})
# rubocop:disable Cop/AvoidReturnFromBlocks
this_package
[
:id
]
this_package
.
try
(
:fetch
,
:id
)
end
end
def
fabricate!
def
fabricate!
...
...
qa/qa/specs/features/browser_ui/5_package/maven_gradle_repository_spec.rb
View file @
85558bab
...
@@ -3,39 +3,45 @@
...
@@ -3,39 +3,45 @@
module
QA
module
QA
RSpec
.
describe
'Package'
,
:orchestrated
,
:packages
do
RSpec
.
describe
'Package'
,
:orchestrated
,
:packages
do
describe
'Maven Repository with Gradle'
do
describe
'Maven Repository with Gradle'
do
using
RSpec
::
Parameterized
::
TableSyntax
include
Runtime
::
Fixtures
include
Runtime
::
Fixtures
let
(
:group_id
)
{
'com.gitlab.qa'
}
let
(
:group_id
)
{
'com.gitlab.qa'
}
let
(
:artifact_id
)
{
'maven_gradle'
}
let
(
:artifact_id
)
{
'maven_gradle'
}
let
(
:package_name
)
{
"
#{
group_id
}
/
#{
artifact_id
}
"
.
tr
(
'.'
,
'/'
)
}
let
(
:package_name
)
{
"
#{
group_id
}
/
#{
artifact_id
}
"
.
tr
(
'.'
,
'/'
)
}
let
(
:auth_token
)
do
let
(
:package_version
)
{
'1.3.7'
}
unless
Page
::
Main
::
Menu
.
perform
(
&
:signed_in?
)
Flow
::
Login
.
sign_in
end
Resource
::
PersonalAccessToken
.
fabricate!
.
token
let
(
:personal_access_token
)
{
Runtime
::
Env
.
personal_access_token
}
end
let
(
:project
)
do
let
(
:p
ackage_p
roject
)
do
Resource
::
Project
.
fabricate_via_api!
do
|
project
|
Resource
::
Project
.
fabricate_via_api!
do
|
project
|
project
.
name
=
'maven-with-gradle-project'
project
.
name
=
'maven-with-gradle-project'
project
.
initialize_with_readme
=
true
project
.
initialize_with_readme
=
true
project
.
visibility
=
:private
end
end
let
(
:client_project
)
do
Resource
::
Project
.
fabricate_via_api!
do
|
client_project
|
client_project
.
name
=
'gradle_client'
client_project
.
initialize_with_readme
=
true
client_project
.
group
=
package_project
.
group
end
end
end
end
let
(
:package
)
do
let
(
:package
)
do
Resource
::
Package
.
init
do
|
package
|
Resource
::
Package
.
init
do
|
package
|
package
.
name
=
package_name
package
.
name
=
package_name
package
.
project
=
project
package
.
project
=
p
ackage_p
roject
end
end
end
end
let
!
(
:runner
)
do
let
(
:runner
)
do
Resource
::
Runner
.
fabricate!
do
|
runner
|
Resource
::
Runner
.
fabricate!
do
|
runner
|
runner
.
name
=
"qa-runner-
#{
Time
.
now
.
to_i
}
"
runner
.
name
=
"qa-runner-
#{
Time
.
now
.
to_i
}
"
runner
.
tags
=
[
"runner-for-
#{
p
roject
.
name
}
"
]
runner
.
tags
=
[
"runner-for-
#{
p
ackage_project
.
group
.
name
}
"
]
runner
.
executor
=
:docker
runner
.
executor
=
:docker
runner
.
project
=
project
runner
.
token
=
package_project
.
group
.
runners_token
end
end
end
end
...
@@ -44,16 +50,15 @@ module QA
...
@@ -44,16 +50,15 @@ module QA
"
#{
uri
.
scheme
}
://
#{
uri
.
host
}
:
#{
uri
.
port
}
"
"
#{
uri
.
scheme
}
://
#{
uri
.
host
}
:
#{
uri
.
port
}
"
end
end
after
do
let
(
:project_deploy_token
)
do
runner
.
remove_via_api!
Resource
::
DeployToken
.
fabricate_via_browser_ui!
do
|
deploy_token
|
package
.
remove_via_api!
deploy_token
.
name
=
'maven-with-gradle-deploy-token'
deploy_token
.
project
=
package_project
end
end
end
it
'publishes a maven package via gradle'
,
testcase:
'https://gitlab.com/gitlab-org/quality/testcases/-/issues/1074'
do
let
(
:package_gitlab_ci_file
)
do
Resource
::
Repository
::
Commit
.
fabricate_via_api!
do
|
commit
|
{
commit
.
project
=
project
commit
.
commit_message
=
'Add .gitlab-ci.yml'
commit
.
add_files
([{
file_path:
'.gitlab-ci.yml'
,
file_path:
'.gitlab-ci.yml'
,
content:
content:
<<~
YAML
<<~
YAML
...
@@ -62,11 +67,14 @@ module QA
...
@@ -62,11 +67,14 @@ module QA
script:
script:
- 'gradle publish'
- 'gradle publish'
only:
only:
- "
#{
project
.
default_branch
}
"
- "
#{
package_
project
.
default_branch
}
"
tags:
tags:
- "runner-for-
#{
project
.
name
}
"
- "runner-for-
#{
package_project
.
group
.
name
}
"
YAML
YAML
},
}
end
let
(
:package_build_gradle_file
)
do
{
{
file_path:
'build.gradle'
,
file_path:
'build.gradle'
,
content:
content:
...
@@ -81,15 +89,16 @@ module QA
...
@@ -81,15 +89,16 @@ module QA
library(MavenPublication) {
library(MavenPublication) {
groupId '
#{
group_id
}
'
groupId '
#{
group_id
}
'
artifactId '
#{
artifact_id
}
'
artifactId '
#{
artifact_id
}
'
version '
#{
package_version
}
'
from components.java
from components.java
}
}
}
}
repositories {
repositories {
maven {
maven {
url "
#{
gitlab_address_with_port
}
/api/v4/projects/
#{
project
.
id
}
/packages/maven"
url "
#{
gitlab_address_with_port
}
/api/v4/projects/
#{
package_
project
.
id
}
/packages/maven"
credentials(HttpHeaderCredentials) {
credentials(HttpHeaderCredentials) {
name = "Private-Token"
name = "Private-Token"
value = "
#{
auth
_token
}
"
value = "
#{
personal_access
_token
}
"
}
}
authentication {
authentication {
header(HttpHeaderAuthentication)
header(HttpHeaderAuthentication)
...
@@ -98,10 +107,103 @@ module QA
...
@@ -98,10 +107,103 @@ module QA
}
}
}
}
EOF
EOF
}])
}
end
end
project
.
visit!
let
(
:client_gitlab_ci_file
)
do
{
file_path:
'.gitlab-ci.yml'
,
content:
<<~
YAML
build:
image: gradle:6.5-jdk11
script:
- 'gradle build'
only:
- "
#{
client_project
.
default_branch
}
"
tags:
- "runner-for-
#{
client_project
.
group
.
name
}
"
YAML
}
end
before
do
Flow
::
Login
.
sign_in_unless_signed_in
runner
end
after
do
runner
.
remove_via_api!
package
.
remove_via_api!
package_project
.
remove_via_api!
client_project
.
remove_via_api!
end
where
(
:authentication_token_type
,
:maven_header_name
)
do
:personal_access_token
|
'Private-Token'
:ci_job_token
|
'Job-Token'
:project_deploy_token
|
'Deploy-Token'
end
with_them
do
let
(
:token
)
do
case
authentication_token_type
when
:personal_access_token
"
\"
#{
personal_access_token
}
\"
"
when
:ci_job_token
'System.getenv("CI_JOB_TOKEN")'
when
:project_deploy_token
"
\"
#{
project_deploy_token
.
password
}
\"
"
end
end
let
(
:client_build_gradle_file
)
do
{
file_path:
'build.gradle'
,
content:
<<~
EOF
plugins {
id 'java'
id 'application'
}
repositories {
jcenter()
maven {
url "
#{
gitlab_address_with_port
}
/api/v4/projects/
#{
package_project
.
id
}
/packages/maven"
name "GitLab"
credentials(HttpHeaderCredentials) {
name = '
#{
maven_header_name
}
'
value =
#{
token
}
}
authentication {
header(HttpHeaderAuthentication)
}
}
}
dependencies {
implementation group: '
#{
group_id
}
', name: '
#{
artifact_id
}
', version: '
#{
package_version
}
'
testImplementation 'junit:junit:4.12'
}
application {
mainClassName = 'gradle_maven_app.App'
}
EOF
}
end
it
"pushes and pulls a maven package via gradle using
#{
params
[
:authentication_token_type
]
}
"
,
testcase:
'https://gitlab.com/gitlab-org/quality/testcases/-/issues/1074'
do
# pushing
Resource
::
Repository
::
Commit
.
fabricate_via_api!
do
|
commit
|
commit
.
project
=
package_project
commit
.
commit_message
=
'Add .gitlab-ci.yml'
commit
.
add_files
([
package_gitlab_ci_file
,
package_build_gradle_file
])
end
package_project
.
visit!
Flow
::
Pipeline
.
visit_latest_pipeline
Flow
::
Pipeline
.
visit_latest_pipeline
Page
::
Project
::
Pipeline
::
Show
.
perform
do
|
pipeline
|
Page
::
Project
::
Pipeline
::
Show
.
perform
do
|
pipeline
|
...
@@ -120,11 +222,28 @@ module QA
...
@@ -120,11 +222,28 @@ module QA
index
.
click_package
(
package_name
)
index
.
click_package
(
package_name
)
end
end
Page
::
Project
::
Packages
::
Show
.
perform
(
&
:click_delete
)
Page
::
Project
::
Packages
::
Show
.
perform
do
|
show
|
expect
(
show
).
to
have_package_info
(
package_name
,
package_version
)
end
Page
::
Project
::
Packages
::
Index
.
perform
do
|
index
|
# pulling
expect
(
index
).
to
have_content
(
"Package deleted successfully"
)
Resource
::
Repository
::
Commit
.
fabricate_via_api!
do
|
commit
|
expect
(
index
).
not_to
have_package
(
package_name
)
commit
.
project
=
client_project
commit
.
commit_message
=
'Add .gitlab-ci.yml'
commit
.
add_files
([
client_gitlab_ci_file
,
client_build_gradle_file
])
end
client_project
.
visit!
Flow
::
Pipeline
.
visit_latest_pipeline
Page
::
Project
::
Pipeline
::
Show
.
perform
do
|
pipeline
|
pipeline
.
click_job
(
'build'
)
end
Page
::
Project
::
Job
::
Show
.
perform
do
|
job
|
expect
(
job
).
to
be_successful
(
timeout:
800
)
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