2019-05-07 19:47:50 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-10 00:04:54 +08:00
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
describe RepositoryAssetValue, type: :model do
|
2019-05-07 19:47:50 +08:00
|
|
|
let(:repository_asset_value) { build :repository_asset_value }
|
|
|
|
|
|
|
|
it 'is valid' do
|
|
|
|
expect(repository_asset_value).to be_valid
|
|
|
|
end
|
|
|
|
|
2018-03-10 00:04:54 +08:00
|
|
|
it 'should be of class RepositoryAssetValue' do
|
|
|
|
expect(subject.class).to eq RepositoryAssetValue
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'Database table' do
|
|
|
|
it { should have_db_column :asset_id }
|
|
|
|
it { should have_db_column :created_at }
|
|
|
|
it { should have_db_column :updated_at }
|
|
|
|
it { should have_db_column :created_by_id }
|
|
|
|
it { should have_db_column :last_modified_by_id }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'Relations' do
|
2019-07-26 18:40:36 +08:00
|
|
|
it { should belong_to(:created_by).class_name('User').optional }
|
|
|
|
it { should belong_to(:last_modified_by).class_name('User').optional }
|
2018-03-10 00:04:54 +08:00
|
|
|
it { should belong_to(:asset).dependent(:destroy) }
|
|
|
|
it { should have_one :repository_cell }
|
|
|
|
it { should accept_nested_attributes_for(:repository_cell) }
|
|
|
|
end
|
|
|
|
|
2019-05-07 19:47:50 +08:00
|
|
|
describe 'Validations' do
|
2018-03-10 00:04:54 +08:00
|
|
|
it { should validate_presence_of :repository_cell }
|
|
|
|
it { should validate_presence_of :asset }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#data' do
|
|
|
|
it 'returns the asset' do
|
2019-07-26 18:40:36 +08:00
|
|
|
asset = create :asset
|
2019-05-07 19:47:50 +08:00
|
|
|
repository_asset_value = create :repository_asset_value, asset: asset
|
|
|
|
|
2019-07-26 18:40:36 +08:00
|
|
|
expect(repository_asset_value.reload.formatted).to eq 'test.jpg'
|
2018-03-10 00:04:54 +08:00
|
|
|
end
|
|
|
|
end
|
2019-12-08 23:53:59 +08:00
|
|
|
|
|
|
|
describe 'data_changed?' do
|
|
|
|
it do
|
|
|
|
expect(repository_asset_value.data_changed?(anything)).to be_truthy
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'update_data!' do
|
|
|
|
let(:user) { create :user }
|
|
|
|
let(:new_file_base64) do
|
|
|
|
{
|
|
|
|
file_data: 'data:image/png;base64, someImageDataHere',
|
2019-12-10 16:21:24 +08:00
|
|
|
file_name: 'newFile.png'
|
2019-12-08 23:53:59 +08:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2019-12-10 15:41:09 +08:00
|
|
|
let(:new_file_with_direct_upload_token) { 'Token' }
|
2019-12-08 23:53:59 +08:00
|
|
|
|
2019-12-09 15:34:27 +08:00
|
|
|
context 'when update data' do
|
2019-12-09 20:48:24 +08:00
|
|
|
# context 'when has direct_upload_token' do
|
|
|
|
# it 'should change last_modified_by and data' do
|
|
|
|
# repository_asset_value.save
|
|
|
|
#
|
|
|
|
# expect { repository_asset_value.update_data!(new_file_with_direct_upload_token, user) }
|
|
|
|
# .to(change { repository_asset_value.reload.last_modified_by.id }
|
|
|
|
# .and(change { repository_asset_value.reload.data }))
|
|
|
|
# end
|
|
|
|
# end
|
|
|
|
|
|
|
|
context 'when has base64 file' do
|
2019-12-09 15:34:27 +08:00
|
|
|
it 'should change last_modified_by and data' do
|
|
|
|
repository_asset_value.save
|
2019-12-08 23:53:59 +08:00
|
|
|
|
2019-12-09 15:34:27 +08:00
|
|
|
expect { repository_asset_value.update_data!(new_file_base64, user) }
|
|
|
|
.to(change { repository_asset_value.reload.last_modified_by.id }
|
|
|
|
.and(change { repository_asset_value.reload.data }))
|
|
|
|
end
|
2019-12-08 23:53:59 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2019-12-09 20:48:24 +08:00
|
|
|
|
|
|
|
describe 'self.new_with_payload' do
|
|
|
|
let(:user) { create :user }
|
|
|
|
let(:column) { create :repository_column }
|
|
|
|
let(:cell) { build :repository_cell, repository_column: column }
|
|
|
|
let(:attributes) do
|
|
|
|
{
|
|
|
|
repository_cell: cell,
|
|
|
|
created_by: user,
|
|
|
|
last_modified_by: user
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
# context 'when has direct_upload_token' do
|
|
|
|
# let(:payload) { {direct_upload_token: 'Token'} }
|
|
|
|
#
|
|
|
|
# it do
|
|
|
|
# expect(RepositoryAssetValue.new_with_payload(payload, attributes))
|
|
|
|
# .to be_an_instance_of RepositoryAssetValue
|
|
|
|
# end
|
|
|
|
#
|
|
|
|
# it do
|
|
|
|
# expect { RepositoryAssetValue.new_with_payload(payload, attributes) }.to change(Asset, :count).by(1)
|
|
|
|
# end
|
|
|
|
# end
|
|
|
|
|
|
|
|
context 'when has base64 file' do
|
|
|
|
let(:payload) do
|
|
|
|
{
|
|
|
|
file_data: 'data:image/png;base64, someImageDataHere',
|
2019-12-10 16:21:24 +08:00
|
|
|
file_name: 'newFile.png'
|
2019-12-09 20:48:24 +08:00
|
|
|
}
|
|
|
|
end
|
|
|
|
it do
|
|
|
|
expect(RepositoryAssetValue.new_with_payload(payload, attributes))
|
|
|
|
.to be_an_instance_of RepositoryAssetValue
|
|
|
|
end
|
|
|
|
|
|
|
|
it do
|
|
|
|
expect { RepositoryAssetValue.new_with_payload(payload, attributes) }.to change(Asset, :count).by(1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-03-10 00:04:54 +08:00
|
|
|
end
|