mirror of
https://github.com/discourse/discourse.git
synced 2024-12-13 11:46:30 +08:00
c9dab6fd08
It's very easy to forget to add `require 'rails_helper'` at the top of every core/plugin spec file, and omissions can cause some very confusing/sporadic errors. By setting this flag in `.rspec`, we can remove the need for `require 'rails_helper'` entirely.
48 lines
1.4 KiB
Ruby
48 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
describe HasSearchData do
|
|
context "belongs to its model" do
|
|
before do
|
|
DB.exec("create temporary table model_items(id SERIAL primary key)")
|
|
DB.exec("create temporary table model_item_search_data(model_item_id int primary key, search_data tsvector, raw_data text, locale text)")
|
|
|
|
class ModelItem < ActiveRecord::Base
|
|
has_one :model_item_search_data, dependent: :destroy
|
|
end
|
|
|
|
class ModelItemSearchData < ActiveRecord::Base
|
|
include HasSearchData
|
|
end
|
|
end
|
|
|
|
after do
|
|
DB.exec("drop table model_items")
|
|
DB.exec("drop table model_item_search_data")
|
|
|
|
# this weakref in the descendant tracker should clean up the two tests
|
|
# if this becomes an issue we can revisit (watch out for erratic tests)
|
|
Object.send(:remove_const, :ModelItem)
|
|
Object.send(:remove_const, :ModelItemSearchData)
|
|
end
|
|
|
|
let(:item) do
|
|
item = ModelItem.create!
|
|
item.create_model_item_search_data!(
|
|
model_item_id: item.id,
|
|
search_data: 'a',
|
|
raw_data: 'a',
|
|
locale: 'en')
|
|
item
|
|
end
|
|
|
|
it 'sets its primary key into associated model' do
|
|
expect(ModelItemSearchData.primary_key).to eq 'model_item_id'
|
|
end
|
|
|
|
it 'can access the model' do
|
|
record_id = item.id
|
|
expect(ModelItemSearchData.find_by(model_item_id: record_id).model_item_id).to eq record_id
|
|
end
|
|
end
|
|
end
|