From 85dc423f7090da0a52c73eb66faf22ddb20efff9 Mon Sep 17 00:00:00 2001 From: GitLab Bot Date: Sat, 19 Sep 2020 01:45:44 +0000 Subject: Add latest changes from gitlab-org/gitlab@13-4-stable-ee --- .../_package_registry.html.haml_spec.rb | 65 ++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 spec/views/admin/application_settings/_package_registry.html.haml_spec.rb (limited to 'spec/views/admin/application_settings') diff --git a/spec/views/admin/application_settings/_package_registry.html.haml_spec.rb b/spec/views/admin/application_settings/_package_registry.html.haml_spec.rb new file mode 100644 index 00000000000..ef40829c29b --- /dev/null +++ b/spec/views/admin/application_settings/_package_registry.html.haml_spec.rb @@ -0,0 +1,65 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe 'admin/application_settings/_package_registry' do + let_it_be(:admin) { create(:admin) } + let_it_be(:default_plan_limits) { create(:plan_limits, :default_plan, :with_package_file_sizes) } + let_it_be(:application_setting) { build(:application_setting) } + let(:page) { Capybara::Node::Simple.new(rendered) } + + before do + assign(:application_setting, application_setting) + allow(view).to receive(:current_user) { admin } + allow(view).to receive(:expanded) { true } + end + + subject { render partial: 'admin/application_settings/package_registry' } + + context 'package file size limits' do + before do + assign(:plans, [default_plan_limits.plan]) + end + + it 'has fields for max package file sizes' do + subject + + expect(rendered).to have_field('Maximum Conan package file size in bytes', type: 'number') + expect(page.find_field('Maximum Conan package file size in bytes').value).to eq(default_plan_limits.conan_max_file_size.to_s) + + expect(rendered).to have_field('Maximum Maven package file size in bytes', type: 'number') + expect(page.find_field('Maximum Maven package file size in bytes').value).to eq(default_plan_limits.maven_max_file_size.to_s) + + expect(rendered).to have_field('Maximum NPM package file size in bytes', type: 'number') + expect(page.find_field('Maximum NPM package file size in bytes').value).to eq(default_plan_limits.npm_max_file_size.to_s) + + expect(rendered).to have_field('Maximum NuGet package file size in bytes', type: 'number') + expect(page.find_field('Maximum NuGet package file size in bytes').value).to eq(default_plan_limits.nuget_max_file_size.to_s) + + expect(rendered).to have_field('Maximum PyPI package file size in bytes', type: 'number') + expect(page.find_field('Maximum PyPI package file size in bytes').value).to eq(default_plan_limits.pypi_max_file_size.to_s) + end + + it 'does not display the plan name when there is only one plan' do + subject + + expect(page).not_to have_content('Default') + end + end + + context 'with multiple plans' do + let_it_be(:plan) { create(:plan, name: 'Gold') } + let_it_be(:gold_plan_limits) { create(:plan_limits, :with_package_file_sizes, plan: plan) } + + before do + assign(:plans, [default_plan_limits.plan, gold_plan_limits.plan]) + end + + it 'displays the plan name when there is more than one plan' do + subject + + expect(page).to have_content('Default') + expect(page).to have_content('Gold') + end + end +end -- cgit v1.2.3