# frozen_string_literal: true

require 'rails_helper'

describe RepositoryRow, type: :model do
  let(:repository_row) { build :repository_row }

  it 'is valid' do
    expect(repository_row).to be_valid
  end

  it 'should be of class RepositoryRow' do
    expect(subject.class).to eq RepositoryRow
  end

  describe 'Database table' do
    it { should have_db_column :repository_id }
    it { should have_db_column :created_by_id }
    it { should have_db_column :last_modified_by_id }
    it { should have_db_column :name }
    it { should have_db_column :created_at }
    it { should have_db_column :updated_at }
  end

  describe 'Relations' do
    it { should belong_to(:repository) }
    it { should belong_to(:created_by).class_name('User') }
    it { should belong_to(:last_modified_by).class_name('User') }
    it { should have_many :repository_cells }
    it { should have_many :repository_columns }
    it { should have_many :my_module_repository_rows }
    it { should have_many :my_modules }
  end

  describe 'Validations' do
    describe '#name' do
      it { is_expected.to validate_presence_of :name }
      it { is_expected.to(validate_length_of(:name).is_at_most(Constants::NAME_MAX_LENGTH)) }
    end

    describe '#created_by' do
      it { is_expected.to validate_presence_of :created_by }
    end
  end

  describe '.archived' do
    context 'when archived' do
      let(:repository_row) { build :repository_row, :archived }
      it 'returns true' do
        expect(repository_row.archived).to be_truthy
      end
    end

    context 'when not archived' do
      context 'when parent not archived' do
        let(:repository_row) { build :repository_row }

        it 'returns false' do
          expect(repository_row.archived).to be_falsey
        end
      end

      context 'when parent archived' do
        let(:repository_row) { build :repository_row, repository: archived_repository }
        let(:archived_repository) { create :repository, :archived }

        it 'returns true' do
          expect(repository_row.archived).to be_truthy
        end
      end
    end
  end

  describe '.archived?' do
    context 'when archived' do
      let(:repository_row) { build :repository_row, :archived }
      it 'returns true' do
        expect(repository_row.archived?).to be_truthy
      end
    end

    context 'when not archived' do
      context 'when parent not archived' do
        let(:repository_row) { build :repository_row }

        it 'returns false' do
          expect(repository_row.archived?).to be_falsey
        end
      end

      context 'when parent archived' do
        let(:repository_row) { build :repository_row, repository: archived_repository }
        let(:archived_repository) { create :repository, :archived }

        it 'returns true' do
          expect(repository_row.archived?).to be_truthy
        end
      end
    end
  end

  describe '.archived_by' do
    context 'when archived' do
      let(:repository_row) { build :repository_row, :archived }
      it 'returns user' do
        expect(repository_row.archived_by).to be_instance_of User
      end
    end

    context 'when not archived' do
      context 'when parent not archived' do
        let(:repository_row) { build :repository_row }

        it 'returns nil' do
          expect(repository_row.archived_by).to be_nil
        end
      end

      context 'when parent archived' do
        let(:repository_row) { build :repository_row, repository: archived_repository }
        let(:archived_repository) { create :repository, :archived }

        it 'returns repository archived_by user' do
          expect(repository_row.archived_by).to be_eql(archived_repository.archived_by)
        end
      end
    end
  end

  describe '.archived_on' do
    context 'when archived' do
      let(:repository_row) { build :repository_row, :archived }
      it 'returns time' do
        expect(repository_row.archived_on).not_to be_nil
      end
    end

    context 'when not archived' do
      context 'when parent not archived' do
        let(:repository_row) { build :repository_row }

        it 'returns nil' do
          expect(repository_row.archived_on).to be_nil
        end
      end

      context 'when parent archived' do
        let(:repository_row) { create :repository_row, repository: archived_repository }
        let(:archived_repository) { create :repository, :archived }

        it 'returns times of archiving parent' do
          expect(repository_row.archived_on).to be_eql(archived_repository.archived_on)
        end
      end
    end
  end
end