# frozen_string_literal: true require 'spec_helper' RSpec.describe VersionCheckHelper do include StubVersion let_it_be(:user) { create(:user) } describe '#show_version_check?' do describe 'return conditions' do where(:enabled, :consent, :is_admin, :result) do [ [false, false, false, false], [false, false, true, false], [false, true, false, false], [false, true, true, false], [true, false, false, false], [true, false, true, true], [true, true, false, false], [true, true, true, false] ] end with_them do before do stub_application_setting(version_check_enabled: enabled) allow(User).to receive(:single_user).and_return(double(user, requires_usage_stats_consent?: consent)) allow(helper).to receive(:current_user).and_return(user) allow(user).to receive(:can_read_all_resources?).and_return(is_admin) end it 'returns correct results' do expect(helper.show_version_check?).to eq result end end end end describe '#gitlab_version_check' do before do allow_next_instance_of(VersionCheck) do |instance| allow(instance).to receive(:response).and_return({ "severity" => "success" }) end end it 'returns an instance of the VersionCheck class' do expect(helper.gitlab_version_check).to eq({ "severity" => "success" }) end end describe '#show_security_patch_upgrade_alert?' do describe 'return conditions' do where(:show_version_check, :gitlab_version_check, :result) do [ [false, nil, false], [false, { "severity" => "success" }, false], [false, { "severity" => "danger" }, false], [false, { "severity" => "danger", "critical_vulnerability" => 'some text' }, false], [false, { "severity" => "danger", "critical_vulnerability" => 'false' }, false], [false, { "severity" => "danger", "critical_vulnerability" => false }, false], [false, { "severity" => "danger", "critical_vulnerability" => 'true' }, false], [false, { "severity" => "danger", "critical_vulnerability" => true }, false], [true, nil, false], [true, { "severity" => "success" }, nil], [true, { "severity" => "danger" }, nil], [true, { "severity" => "danger", "critical_vulnerability" => 'some text' }, nil], [true, { "severity" => "danger", "critical_vulnerability" => 'false' }, false], [true, { "severity" => "danger", "critical_vulnerability" => false }, false], [true, { "severity" => "danger", "critical_vulnerability" => 'true' }, true], [true, { "severity" => "danger", "critical_vulnerability" => true }, true] ] end with_them do before do allow(helper).to receive(:show_version_check?).and_return(show_version_check) allow(helper).to receive(:gitlab_version_check).and_return(gitlab_version_check) end it 'returns correct results' do expect(helper.show_security_patch_upgrade_alert?).to eq result end end end end describe '#link_to_version' do let(:release_url) { 'https://gitlab.com/gitlab-org/gitlab-foss/-/tags/deadbeef' } before do allow(Gitlab::Source).to receive(:release_url).and_return(release_url) end context 'for a pre-release' do before do stub_version('8.0.2-pre', 'deadbeef') end it 'links to commit sha' do expect(helper.link_to_version).to eq("8.0.2-pre deadbeef") end end context 'for a normal release' do before do stub_version('8.0.2-ee', 'deadbeef') end it 'links to version tag' do expect(helper.link_to_version).to include("v8.0.2-ee") end end end end