Sha256: 6f42047cb07bbf30cc63aacdedccc3f5fb2831b4e529bc82dc21225070b52823
Contents?: true
Size: 1.61 KB
Versions: 3
Compression:
Stored size: 1.61 KB
Contents
RSpec.describe ROM::SQL::Association::OneToMany do subject(:assoc) { ROM::SQL::Association::OneToMany.new(:users, :tasks) } include_context 'users and tasks' let(:users) { container.relations[:users] } let(:tasks) { container.relations[:tasks] } with_adapters do before do conf.relation(:tasks) do schema do attribute :id, ROM::SQL::Types::Serial attribute :user_id, ROM::SQL::Types::ForeignKey(:users) attribute :title, ROM::SQL::Types::String end end end describe '#result' do specify { expect(ROM::SQL::Association::OneToMany.result).to be(:many) } end describe '#call' do it 'prepares joined relations' do relation = assoc.call(container.relations) expect(relation.attributes).to eql(%i[id user_id title]) expect(relation.order(:tasks__id).to_a).to eql([ { id: 1, user_id: 2, title: "Joe's task" }, { id: 2, user_id: 1, title: "Jane's task" } ]) expect(relation.where(user_id: 1).to_a).to eql([ { id: 2, user_id: 1, title: "Jane's task" } ]) expect(relation.where(user_id: 2).to_a).to eql([ { id: 1, user_id: 2, title: "Joe's task" } ]) end end describe ROM::Plugins::Relation::SQL::AutoCombine, '#for_combine' do it 'preloads relation based on association' do relation = tasks.for_combine(assoc).call(users.call) expect(relation.to_a).to eql([ { id: 1, user_id: 2, title: "Joe's task" }, { id: 2, user_id: 1, title: "Jane's task" } ]) end end end end
Version data entries
3 entries across 3 versions & 1 rubygems