scinote-web/spec/models/repository_row_spec.rb

205 lines
6.5 KiB
Ruby

# 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 }
it { should have_db_column :parent_connections_count }
it { should have_db_column :child_connections_count }
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 }
it { should have_many(:child_connections).class_name('RepositoryRowConnection').with_foreign_key('parent_id').dependent(:destroy).inverse_of(:parent) }
it { should have_many(:child_repository_rows).through(:child_connections).source(:child) }
it { should have_many(:parent_connections).class_name('RepositoryRowConnection').with_foreign_key('child_id').dependent(:destroy).inverse_of(:child) }
it { should have_many(:parent_repository_rows).through(:parent_connections).source(:parent) }
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
describe '.relationship_count' do
context 'when first created' do
let(:repository_row) { create :repository_row }
it 'returns zero' do
expect(repository_row.relationship_count).to be_zero
end
end
context 'when it has only parents' do
let(:nbr_of_parents) { 3 }
let(:repository_row) { create :repository_row, :with_parents, nbr_of_parents: nbr_of_parents }
it 'returns the number of parents' do
expect(repository_row.relationship_count).to be_eql(nbr_of_parents)
end
end
context 'when it has only children' do
let(:nbr_of_children) { 4 }
let(:repository_row) { create :repository_row, :with_children, nbr_of_children: nbr_of_children }
it 'returns the number of children' do
expect(repository_row.relationship_count).to be_eql(nbr_of_children)
end
end
context 'when it has both children and parents' do
let(:nbr_of_children) { 4 }
let(:nbr_of_parents) { 5 }
let(:repository_row) { create :repository_row,
:with_children,
:with_parents,
nbr_of_parents: nbr_of_parents,
nbr_of_children: nbr_of_children }
it 'returns the total sum of children and parents' do
expect(repository_row.relationship_count).to be_eql(nbr_of_children + nbr_of_parents)
end
end
end
end