scinote-web/spec/models/repository_row_spec.rb
2020-06-24 11:42:59 +02:00

157 lines
4.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 }
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