mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-10 17:39:38 +08:00
107 lines
3.3 KiB
Ruby
107 lines
3.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe RepositoryListValue, type: :model do
|
|
let(:repository_list_value) { build :repository_list_value }
|
|
|
|
it 'is valid' do
|
|
expect(repository_list_value).to be_valid
|
|
end
|
|
|
|
it 'should be of class RepositoryListValue' do
|
|
expect(subject.class).to eq RepositoryListValue
|
|
end
|
|
|
|
describe 'Database table' do
|
|
it { should have_db_column :created_by_id }
|
|
it { should have_db_column :last_modified_by_id }
|
|
it { should have_db_column :repository_list_item_id }
|
|
end
|
|
|
|
describe 'Relations' do
|
|
it { should belong_to(:created_by).class_name('User') }
|
|
it { should belong_to(:last_modified_by).class_name('User') }
|
|
it { should belong_to(:repository_list_item) }
|
|
it { should accept_nested_attributes_for(:repository_cell) }
|
|
end
|
|
|
|
describe '#formatted' do
|
|
let(:list_item) { create :repository_list_item, data: 'my item' }
|
|
|
|
it 'returns the formatted data of a selected item' do
|
|
repository_list_value = create :repository_list_value, repository_list_item: list_item
|
|
|
|
expect(repository_list_value.reload.formatted).to eq 'my item'
|
|
end
|
|
end
|
|
|
|
describe '#data' do
|
|
let(:list_item) { create :repository_list_item, data: 'my item' }
|
|
let(:repository_list_value) { create :repository_list_value, repository_list_item: list_item }
|
|
|
|
it 'returns the data of a selected item' do
|
|
expect(repository_list_value.reload.data).to eq 'my item'
|
|
end
|
|
|
|
# Not sure if this test make sense, because validation will fail before hit this function. Updated in SCI-3183
|
|
it 'retuns only the item related to the list' do
|
|
repository_list_value.repository_list_item = nil
|
|
repository_list_value.save(validate: false)
|
|
|
|
expect(repository_list_value.reload.data).to be_nil
|
|
end
|
|
end
|
|
|
|
describe 'data_changed?' do
|
|
context 'when has new data' do
|
|
it do
|
|
expect(repository_list_value.data_changed?('-1')).to be_truthy
|
|
end
|
|
end
|
|
|
|
context 'when has same data' do
|
|
it do
|
|
repository_list_value.save
|
|
id = repository_list_value.repository_list_item.id
|
|
|
|
expect(repository_list_value.data_changed?(id)).to be_falsey
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'update_data!' do
|
|
let(:user) { create :user }
|
|
let(:new_list_item) do
|
|
create :repository_list_item, repository_column: repository_list_value.repository_list_item.repository_column
|
|
end
|
|
context 'when update data' do
|
|
it 'should change last_modified_by and data' do
|
|
repository_list_value.save
|
|
|
|
expect { repository_list_value.update_data!(new_list_item.id, user) }
|
|
.to(change { repository_list_value.reload.last_modified_by.id }
|
|
.and(change { repository_list_value.reload.data }))
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'self.new_with_payload' do
|
|
let(:user) { create :user }
|
|
let(:column) { create :repository_column }
|
|
let(:list_item) { create :repository_list_item, repository_column: column }
|
|
let(:cell) { build :repository_cell, repository_column: column }
|
|
let(:attributes) do
|
|
{
|
|
repository_cell: cell,
|
|
created_by: user,
|
|
last_modified_by: user
|
|
}
|
|
end
|
|
|
|
it do
|
|
expect(RepositoryListValue.new_with_payload(list_item.id, attributes))
|
|
.to be_an_instance_of RepositoryListValue
|
|
end
|
|
end
|
|
end
|