Commit 9948be54 authored by Desiree Chevalier's avatar Desiree Chevalier

Add test case links to some parameterized e2e specs

parent 164d66e0
...@@ -3,6 +3,8 @@ ...@@ -3,6 +3,8 @@
module QA module QA
RSpec.describe 'Package', :orchestrated, :registry, only: { pipeline: :main } do RSpec.describe 'Package', :orchestrated, :registry, only: { pipeline: :main } do
describe 'Dependency Proxy' do describe 'Dependency Proxy' do
using RSpec::Parameterized::TableSyntax
let(:project) do let(:project) do
Resource::Project.fabricate_via_api! do |project| Resource::Project.fabricate_via_api! do |project|
project.name = 'dependency-proxy-project' project.name = 'dependency-proxy-project'
...@@ -40,12 +42,13 @@ module QA ...@@ -40,12 +42,13 @@ module QA
runner.remove_via_api! runner.remove_via_api!
end end
where(:docker_client_version) do where(:case_name, :docker_client_version, :testcase) do
%w[docker:19.03.12 docker:20.10] 'using docker:19.03.12' | 'docker:19.03.12' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347605'
'using docker:20.10' | 'docker:20.10' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347604'
end end
with_them do with_them do
it "pulls an image using the dependency proxy" do it "pulls an image using the dependency proxy", testcase: params[:testcase] do
Support::Retrier.retry_on_exception(max_attempts: 3, sleep_interval: 2) do Support::Retrier.retry_on_exception(max_attempts: 3, sleep_interval: 2) do
Resource::Repository::Commit.fabricate_via_api! do |commit| Resource::Repository::Commit.fabricate_via_api! do |commit|
commit.project = project commit.project = project
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
module QA module QA
RSpec.describe 'Package', :orchestrated, :packages, :object_storage do RSpec.describe 'Package', :orchestrated, :packages, :object_storage do
describe 'Helm Registry' do describe 'Helm Registry' do
using RSpec::Parameterized::TableSyntax
include Runtime::Fixtures include Runtime::Fixtures
include_context 'packages registry qa scenario' include_context 'packages registry qa scenario'
...@@ -10,8 +11,13 @@ module QA ...@@ -10,8 +11,13 @@ module QA
let(:package_version) { '1.3.7' } let(:package_version) { '1.3.7' }
let(:package_type) { 'helm' } let(:package_type) { 'helm' }
%i[personal_access_token ci_job_token project_deploy_token].each do |authentication_token_type| where(:case_name, :authentication_token_type, :testcase) do
context "using a #{authentication_token_type}" do 'using personal access token' | :personal_access_token | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347586'
'using ci job token' | :ci_job_token | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347587'
'using project deploy token' | :project_deploy_token | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347588'
end
with_them do
let(:username) do let(:username) do
case authentication_token_type case authentication_token_type
when :personal_access_token when :personal_access_token
...@@ -34,7 +40,7 @@ module QA ...@@ -34,7 +40,7 @@ module QA
end end
end end
it "pushes and pulls a helm chart" do it "pushes and pulls a helm chart", testcase: params[:testcase] do
Support::Retrier.retry_on_exception(max_attempts: 3, sleep_interval: 2) do Support::Retrier.retry_on_exception(max_attempts: 3, sleep_interval: 2) do
Resource::Repository::Commit.fabricate_via_api! do |commit| Resource::Repository::Commit.fabricate_via_api! do |commit|
helm_upload_yaml = ERB.new(read_fixture('package_managers/helm', 'helm_upload_package.yaml.erb')).result(binding) helm_upload_yaml = ERB.new(read_fixture('package_managers/helm', 'helm_upload_package.yaml.erb')).result(binding)
...@@ -109,5 +115,4 @@ module QA ...@@ -109,5 +115,4 @@ module QA
end end
end end
end end
end
end end
...@@ -68,10 +68,10 @@ module QA ...@@ -68,10 +68,10 @@ module QA
another_project.remove_via_api! another_project.remove_via_api!
end end
where(:authentication_token_type, :token_name) do where(:case_name, :authentication_token_type, :token_name, :testcase) do
:personal_access_token | 'Personal Access Token' 'using personal access token' | :personal_access_token | 'Personal Access Token' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347600'
:ci_job_token | 'CI Job Token' 'using ci job token' | :ci_job_token | 'CI Job Token' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347599'
:project_deploy_token | 'Deploy Token' 'using project deploy token' | :project_deploy_token | 'Deploy Token' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347598'
end end
with_them do with_them do
...@@ -86,7 +86,7 @@ module QA ...@@ -86,7 +86,7 @@ module QA
end end
end end
it "push and pull a npm package via CI using a #{params[:token_name]}" do it 'push and pull a npm package via CI', testcase: params[:testcase] do
Support::Retrier.retry_on_exception(max_attempts: 3, sleep_interval: 2) do Support::Retrier.retry_on_exception(max_attempts: 3, sleep_interval: 2) do
npm_upload_yaml = ERB.new(read_fixture('package_managers/npm', 'npm_upload_package_instance.yaml.erb')).result(binding) npm_upload_yaml = ERB.new(read_fixture('package_managers/npm', 'npm_upload_package_instance.yaml.erb')).result(binding)
package_json = ERB.new(read_fixture('package_managers/npm', 'package_instance.json.erb')).result(binding) package_json = ERB.new(read_fixture('package_managers/npm', 'package_instance.json.erb')).result(binding)
......
...@@ -59,10 +59,10 @@ module QA ...@@ -59,10 +59,10 @@ module QA
project.remove_via_api! project.remove_via_api!
end end
where(:authentication_token_type, :token_name) do where(:case_name, :authentication_token_type, :token_name, :testcase) do
:personal_access_token | 'Personal Access Token' 'using personal access token' | :personal_access_token | 'Personal Access Token' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347592'
:ci_job_token | 'CI Job Token' 'using ci job token' | :ci_job_token | 'CI Job Token' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347594'
:project_deploy_token | 'Deploy Token' 'using project deploy token' | :project_deploy_token | 'Deploy Token' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347593'
end end
with_them do with_them do
...@@ -77,7 +77,7 @@ module QA ...@@ -77,7 +77,7 @@ module QA
end end
end end
it "push and pull a npm package via CI using a #{params[:token_name]}" do it 'push and pull a npm package via CI', testcase: params[:testcase] do
Resource::Repository::Commit.fabricate_via_api! do |commit| Resource::Repository::Commit.fabricate_via_api! do |commit|
npm_upload_install_yaml = ERB.new(read_fixture('package_managers/npm', 'npm_upload_install_package_project.yaml.erb')).result(binding) npm_upload_install_yaml = ERB.new(read_fixture('package_managers/npm', 'npm_upload_install_package_project.yaml.erb')).result(binding)
package_json = ERB.new(read_fixture('package_managers/npm', 'package_project.json.erb')).result(binding) package_json = ERB.new(read_fixture('package_managers/npm', 'package_project.json.erb')).result(binding)
......
...@@ -63,10 +63,10 @@ module QA ...@@ -63,10 +63,10 @@ module QA
package.remove_via_api! package.remove_via_api!
end end
where(:authentication_token_type, :token_name) do where(:case_name, :authentication_token_type, :token_name, :testcase) do
:personal_access_token | 'Personal Access Token' 'using personal access token' | :personal_access_token | 'Personal Access Token' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347597'
:ci_job_token | 'CI Job Token' 'using ci job token' | :ci_job_token | 'CI Job Token' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347595'
:group_deploy_token | 'Deploy Token' 'using group deploy token' | :group_deploy_token | 'Deploy Token' | 'https://gitlab.com/gitlab-org/gitlab/-/quality/test_cases/347596'
end end
with_them do with_them do
...@@ -92,7 +92,7 @@ module QA ...@@ -92,7 +92,7 @@ module QA
end end
end end
it "publishes a nuget package at the project level, installs and deletes it at the group level using a #{params[:token_name]}" do it 'publishes a nuget package at the project level, installs and deletes it at the group level', testcase: params[:testcase] do
Flow::Login.sign_in Flow::Login.sign_in
Support::Retrier.retry_on_exception(max_attempts: 3, sleep_interval: 2) do Support::Retrier.retry_on_exception(max_attempts: 3, sleep_interval: 2) do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment