123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- # frozen_string_literal: true
- require 'rails_helper'
- describe Admin::DashboardHelper do
- describe 'relevant_account_timestamp' do
- context 'with an account with older sign in' do
- let(:account) { Fabricate(:account) }
- let(:stamp) { 10.days.ago }
- it 'returns a time element' do
- account.user.update(current_sign_in_at: stamp)
- result = helper.relevant_account_timestamp(account)
- expect(result).to match('time-ago')
- expect(result).to match(I18n.l(stamp))
- end
- end
- context 'with an account with newer sign in' do
- let(:account) { Fabricate(:account) }
- it 'returns a time element' do
- account.user.update(current_sign_in_at: 10.hours.ago)
- result = helper.relevant_account_timestamp(account)
- expect(result).to eq(I18n.t('generic.today'))
- end
- end
- context 'with an account where the user is pending' do
- let(:account) { Fabricate(:account) }
- it 'returns a time element' do
- account.user.update(current_sign_in_at: nil)
- account.user.update(approved: false)
- result = helper.relevant_account_timestamp(account)
- expect(result).to match('time-ago')
- expect(result).to match(I18n.l(account.user.created_at))
- end
- end
- context 'with an account with a last status value' do
- let(:account) { Fabricate(:account) }
- let(:stamp) { 5.minutes.ago }
- it 'returns a time element' do
- account.user.update(current_sign_in_at: nil)
- account.account_stat.update(last_status_at: stamp)
- result = helper.relevant_account_timestamp(account)
- expect(result).to match('time-ago')
- expect(result).to match(I18n.l(stamp))
- end
- end
- context 'with an account without sign in or last status or pending' do
- let(:account) { Fabricate(:account) }
- it 'returns a time element' do
- account.user.update(current_sign_in_at: nil)
- result = helper.relevant_account_timestamp(account)
- expect(result).to eq('-')
- end
- end
- end
- end
|