2019-05-08 15:24:11 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-08-30 00:49:07 +08:00
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
describe Result, type: :model do
|
2019-05-08 15:24:11 +08:00
|
|
|
let(:result) { build :result }
|
|
|
|
|
|
|
|
it 'is valid' do
|
|
|
|
expect(result).to be_valid
|
|
|
|
end
|
2019-05-08 19:49:43 +08:00
|
|
|
|
2017-08-30 00:49:07 +08:00
|
|
|
it 'should be of class Result' do
|
|
|
|
expect(subject.class).to eq Result
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'Database table' do
|
|
|
|
it { should have_db_column :name }
|
|
|
|
it { should have_db_column :my_module_id }
|
|
|
|
it { should have_db_column :user_id }
|
|
|
|
it { should have_db_column :created_at }
|
|
|
|
it { should have_db_column :updated_at }
|
|
|
|
it { should have_db_column :archived }
|
|
|
|
it { should have_db_column :archived_on }
|
|
|
|
it { should have_db_column :last_modified_by_id }
|
|
|
|
it { should have_db_column :archived_by_id }
|
|
|
|
it { should have_db_column :restored_by_id }
|
|
|
|
it { should have_db_column :restored_on }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'Relations' do
|
|
|
|
it { should belong_to :user }
|
|
|
|
it { should belong_to :my_module }
|
2019-07-26 18:40:36 +08:00
|
|
|
it { should belong_to(:archived_by).class_name('User').optional }
|
|
|
|
it { should belong_to(:last_modified_by).class_name('User').optional }
|
|
|
|
it { should belong_to(:restored_by).class_name('User').optional }
|
2017-08-30 00:49:07 +08:00
|
|
|
it { should have_one :result_asset }
|
|
|
|
it { should have_one :asset }
|
|
|
|
it { should have_one :result_table }
|
|
|
|
it { should have_one :table }
|
|
|
|
it { should have_one :result_text }
|
|
|
|
it { should have_many :result_comments }
|
|
|
|
it { should have_many :report_elements }
|
|
|
|
end
|
|
|
|
|
2019-05-08 15:24:11 +08:00
|
|
|
describe 'Validations' do
|
2017-08-30 00:49:07 +08:00
|
|
|
it { should validate_presence_of :user }
|
|
|
|
it do
|
|
|
|
should validate_length_of(:name).is_at_most(Constants::NAME_MAX_LENGTH)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|