Commit fd67f1a5 authored by Grzegorz Bizon's avatar Grzegorz Bizon

Merge branch '10io-speedup-npm-api-tests' into 'master'

Improve NPM api tests execution time

See merge request gitlab-org/gitlab!26810
parents 7e38a91d ef394614
...@@ -3,11 +3,13 @@ ...@@ -3,11 +3,13 @@
require 'spec_helper' require 'spec_helper'
describe API::NpmPackages do describe API::NpmPackages do
let(:group) { create(:group) } let_it_be(:user) { create(:user) }
let(:user) { create(:user) } let_it_be(:group) { create(:group) }
let(:project) { create(:project, :public, namespace: group) } let_it_be(:project, reload: true) { create(:project, :public, namespace: group) }
let(:token) { create(:oauth_access_token, scopes: 'api', resource_owner: user) } let_it_be(:package, reload: true) { create(:npm_package, project: project) }
let(:job) { create(:ci_build, user: user) } let_it_be(:token) { create(:oauth_access_token, scopes: 'api', resource_owner: user) }
let_it_be(:personal_access_token) { create(:personal_access_token, user: user) }
let_it_be(:job) { create(:ci_build, user: user) }
before do before do
project.add_developer(user) project.add_developer(user)
...@@ -35,11 +37,10 @@ describe API::NpmPackages do ...@@ -35,11 +37,10 @@ describe API::NpmPackages do
end end
describe 'GET /api/v4/packages/npm/*package_name' do describe 'GET /api/v4/packages/npm/*package_name' do
let(:package) { create(:npm_package, project: project) } let_it_be(:package_dependency_link1) { create(:packages_dependency_link, package: package, dependency_type: :dependencies) }
let!(:package_dependency_link1) { create(:packages_dependency_link, package: package, dependency_type: :dependencies) } let_it_be(:package_dependency_link2) { create(:packages_dependency_link, package: package, dependency_type: :devDependencies) }
let!(:package_dependency_link2) { create(:packages_dependency_link, package: package, dependency_type: :devDependencies) } let_it_be(:package_dependency_link3) { create(:packages_dependency_link, package: package, dependency_type: :bundleDependencies) }
let!(:package_dependency_link3) { create(:packages_dependency_link, package: package, dependency_type: :bundleDependencies) } let_it_be(:package_dependency_link4) { create(:packages_dependency_link, package: package, dependency_type: :peerDependencies) }
let!(:package_dependency_link4) { create(:packages_dependency_link, package: package, dependency_type: :peerDependencies) }
shared_examples 'returning the npm package info' do shared_examples 'returning the npm package info' do
it 'returns the package info' do it 'returns the package info' do
...@@ -106,7 +107,9 @@ describe API::NpmPackages do ...@@ -106,7 +107,9 @@ describe API::NpmPackages do
end end
context 'project path with a dot' do context 'project path with a dot' do
let(:project) { create(:project, :public, namespace: group, path: 'foo.bar') } before do
project.update!(path: 'foo.bar')
end
it_behaves_like 'returning the npm package info' it_behaves_like 'returning the npm package info'
end end
...@@ -159,8 +162,7 @@ describe API::NpmPackages do ...@@ -159,8 +162,7 @@ describe API::NpmPackages do
end end
describe 'GET /api/v4/projects/:id/packages/npm/*package_name/-/*file_name' do describe 'GET /api/v4/projects/:id/packages/npm/*package_name/-/*file_name' do
let(:package) { create(:npm_package, project: project) } let_it_be(:package_file) { package.package_files.first }
let(:package_file) { package.package_files.first }
shared_examples 'a package file that requires auth' do shared_examples 'a package file that requires auth' do
it 'returns the file with an access token' do it 'returns the file with an access token' do
...@@ -395,11 +397,10 @@ describe API::NpmPackages do ...@@ -395,11 +397,10 @@ describe API::NpmPackages do
end end
describe 'GET /api/v4/packages/npm/-/package/*package_name/dist-tags' do describe 'GET /api/v4/packages/npm/-/package/*package_name/dist-tags' do
let(:package) { create(:npm_package, project: project) } let_it_be(:package_tag1) { create(:packages_tag, package: package) }
let!(:package_tag1) { create(:packages_tag, package: package) } let_it_be(:package_tag2) { create(:packages_tag, package: package) }
let!(:package_tag2) { create(:packages_tag, package: package) }
let(:package_name) { package.name } let(:package_name) { package.name }
let(:user) { create(:user) }
let(:url) { "/packages/npm/-/package/#{package_name}/dist-tags" } let(:url) { "/packages/npm/-/package/#{package_name}/dist-tags" }
subject { get api(url) } subject { get api(url) }
...@@ -411,7 +412,7 @@ describe API::NpmPackages do ...@@ -411,7 +412,7 @@ describe API::NpmPackages do
context 'with public project' do context 'with public project' do
context 'with authenticated user' do context 'with authenticated user' do
subject { get api(url, user) } subject { get api(url, personal_access_token: personal_access_token) }
it_behaves_like 'returns package tags', :maintainer it_behaves_like 'returns package tags', :maintainer
it_behaves_like 'returns package tags', :developer it_behaves_like 'returns package tags', :developer
...@@ -425,10 +426,12 @@ describe API::NpmPackages do ...@@ -425,10 +426,12 @@ describe API::NpmPackages do
end end
context 'with private project' do context 'with private project' do
let(:project) { create(:project, :private) } before do
project.update!(visibility_level: Gitlab::VisibilityLevel::PRIVATE)
end
context 'with authenticated user' do context 'with authenticated user' do
subject { get api(url, user) } subject { get api(url, personal_access_token: personal_access_token) }
it_behaves_like 'returns package tags', :maintainer it_behaves_like 'returns package tags', :maintainer
it_behaves_like 'returns package tags', :developer it_behaves_like 'returns package tags', :developer
...@@ -452,10 +455,9 @@ describe API::NpmPackages do ...@@ -452,10 +455,9 @@ describe API::NpmPackages do
end end
describe 'PUT /api/v4/packages/npm/-/package/*package_name/dist-tags/:tag' do describe 'PUT /api/v4/packages/npm/-/package/*package_name/dist-tags/:tag' do
let(:package) { create(:npm_package, project: project) } let_it_be(:tag_name) { 'test' }
let(:package_name) { package.name } let(:package_name) { package.name }
let(:user) { create(:user) }
let(:tag_name) { 'test' }
let(:version) { package.version } let(:version) { package.version }
let(:url) { "/packages/npm/-/package/#{package_name}/dist-tags/#{tag_name}" } let(:url) { "/packages/npm/-/package/#{package_name}/dist-tags/#{tag_name}" }
...@@ -468,7 +470,7 @@ describe API::NpmPackages do ...@@ -468,7 +470,7 @@ describe API::NpmPackages do
context 'with public project' do context 'with public project' do
context 'with authenticated user' do context 'with authenticated user' do
subject { put api(url, user), env: { 'api.request.body': version } } subject { put api(url, personal_access_token: personal_access_token), env: { 'api.request.body': version } }
it_behaves_like 'create package tag', :maintainer it_behaves_like 'create package tag', :maintainer
it_behaves_like 'create package tag', :developer it_behaves_like 'create package tag', :developer
...@@ -482,10 +484,12 @@ describe API::NpmPackages do ...@@ -482,10 +484,12 @@ describe API::NpmPackages do
end end
context 'with private project' do context 'with private project' do
let(:project) { create(:project, :private) } before do
project.update!(visibility_level: Gitlab::VisibilityLevel::PRIVATE)
end
context 'with authenticated user' do context 'with authenticated user' do
subject { put api(url, user), env: { 'api.request.body': version } } subject { put api(url, personal_access_token: personal_access_token), env: { 'api.request.body': version } }
it_behaves_like 'create package tag', :maintainer it_behaves_like 'create package tag', :maintainer
it_behaves_like 'create package tag', :developer it_behaves_like 'create package tag', :developer
...@@ -509,9 +513,8 @@ describe API::NpmPackages do ...@@ -509,9 +513,8 @@ describe API::NpmPackages do
end end
describe 'DELETE /api/v4/packages/npm/-/package/*package_name/dist-tags/:tag' do describe 'DELETE /api/v4/packages/npm/-/package/*package_name/dist-tags/:tag' do
let(:package) { create(:npm_package, project: project) } let_it_be(:package_tag) { create(:packages_tag, package: package) }
let(:package_tag) { create(:packages_tag, package: package) }
let(:user) { create(:user) }
let(:package_name) { package.name } let(:package_name) { package.name }
let(:tag_name) { package_tag.name } let(:tag_name) { package_tag.name }
let(:url) { "/packages/npm/-/package/#{package_name}/dist-tags/#{tag_name}" } let(:url) { "/packages/npm/-/package/#{package_name}/dist-tags/#{tag_name}" }
...@@ -525,7 +528,7 @@ describe API::NpmPackages do ...@@ -525,7 +528,7 @@ describe API::NpmPackages do
context 'with public project' do context 'with public project' do
context 'with authenticated user' do context 'with authenticated user' do
subject { delete api(url, user) } subject { delete api(url, personal_access_token: personal_access_token) }
it_behaves_like 'delete package tag', :maintainer it_behaves_like 'delete package tag', :maintainer
it_behaves_like 'rejects package tags access', :developer, :forbidden it_behaves_like 'rejects package tags access', :developer, :forbidden
...@@ -539,10 +542,12 @@ describe API::NpmPackages do ...@@ -539,10 +542,12 @@ describe API::NpmPackages do
end end
context 'with private project' do context 'with private project' do
let(:project) { create(:project, :private) } before do
project.update!(visibility_level: Gitlab::VisibilityLevel::PRIVATE)
end
context 'with authenticated user' do context 'with authenticated user' do
subject { delete api(url, user) } subject { delete api(url, personal_access_token: personal_access_token) }
it_behaves_like 'delete package tag', :maintainer it_behaves_like 'delete package tag', :maintainer
it_behaves_like 'rejects package tags access', :developer, :forbidden it_behaves_like 'rejects package tags access', :developer, :forbidden
......
...@@ -73,8 +73,8 @@ RSpec.shared_examples 'create package tag' do |user_type| ...@@ -73,8 +73,8 @@ RSpec.shared_examples 'create package tag' do |user_type|
end end
context 'with already existing tag' do context 'with already existing tag' do
let(:package2) { create(:npm_package, project: project, name: package.name, version: '5.5.55') } let_it_be(:package2) { create(:npm_package, project: project, name: package.name, version: '5.5.55') }
let!(:tag) { create(:packages_tag, package: package2, name: tag_name) } let_it_be(:tag) { create(:packages_tag, package: package2, name: tag_name) }
it_behaves_like 'returning response status', :no_content it_behaves_like 'returning response status', :no_content
......
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