HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux vmi1674223.contaboserver.net 5.4.0-182-generic #202-Ubuntu SMP Fri Apr 26 12:29:36 UTC 2024 x86_64
User: root (0)
PHP: 7.4.3-4ubuntu2.22
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //opt/openproject/spec/helpers/users_helper_spec.rb
#-- copyright
# OpenProject is an open source project management software.
# Copyright (C) 2012-2020 the OpenProject GmbH
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
#
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
# Copyright (C) 2006-2017 Jean-Philippe Lang
# Copyright (C) 2010-2013 the ChiliProject Team
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
#
# See docs/COPYRIGHT.rdoc for more details.
#++

require 'spec_helper'

describe UsersHelper, type: :helper do
  include UsersHelper

  def build_user(status, blocked)
    user = FactoryBot.build(:user)
    allow(user).to receive(:status).and_return(User::STATUSES[status])
    allow(user).to receive(:failed_too_many_recent_login_attempts?).and_return(blocked)
    allow(user).to receive(:failed_login_count).and_return(3)
    user
  end

  describe 'full_user_status' do
    test_cases = {
      [:active, false] => I18n.t(:active, scope: :user),
      [:active, true] => I18n.t(:blocked_num_failed_logins,
                                count: 3,
                                scope: :user),
      [:locked, false] => I18n.t(:locked, scope: :user),
      [:locked, true] => I18n.t(:status_user_and_brute_force,
                                user: I18n.t(:locked, scope: :user),
                                brute_force: I18n.t(:blocked_num_failed_logins,
                                                    count: 3,
                                                    scope: :user),
                                scope: :user),
      [:registered, false] => I18n.t(:registered, scope: :user),
      [:registered, true] => I18n.t(:status_user_and_brute_force,
                                    user: I18n.t(:registered, scope: :user),
                                    brute_force: I18n.t(:blocked_num_failed_logins,
                                                        count: 3,
                                                        scope: :user),
                                    scope: :user)
    }

    test_cases.each do |(status, blocked), expectation|
      describe "with status #{status} and blocked #{blocked}" do
        before do
          user = build_user(status, blocked)
          @status = full_user_status(user, true)
        end

        it "should return #{expectation}" do
          expect(@status).to eq(expectation)
        end
      end
    end
  end

  describe 'change_user_status_buttons' do
    test_cases = {
      [:active, false] => :lock,
      [:locked, false] => :unlock,
      [:locked, true] => :unlock_and_reset_failed_logins,
      [:registered, false] => :activate,
      [:registered, true] => :activate_and_reset_failed_logins
    }

    test_cases.each do |(status, blocked), expectation_symbol|
      describe "with status #{status} and blocked #{blocked}" do
        expectation = I18n.t(expectation_symbol, scope: :user)
        before do
          user = build_user(status, blocked)
          @buttons = change_user_status_buttons(user)
        end
        it "should contain '#{expectation}'" do
          expect(@buttons).to include(expectation)
        end

        it 'should contain a single button' do
          expect(@buttons.scan('<input').count).to eq(1)
        end
      end
    end

    describe 'with status active and blocked True' do
      before do
        user = build_user(:active, true)
        @buttons = change_user_status_buttons(user)
      end

      it 'should return inputs (buttons)' do
        expect(@buttons.scan('<input').count).to eq(2)
      end

      it "should contain 'Lock' and 'Reset Failed logins'" do
        expect(@buttons).to include(I18n.t(:lock, scope: :user))
        expect(@buttons).to include(I18n.t(:reset_failed_logins, scope: :user))
      end
    end
  end
end