特定の日付範囲に一致するレコード、または nil 値を持つレコードの Mongoid クエリを作成しようとしています。これは、Mongoid クエリに変換したい関数を実行する私の ruby コードです。
class MyModel
include Mongoid::Document
field :name
field :enabled, type: Boolean, default: false
field :start_date, type: DateTime
field :end_date, type: DateTime
def self.active
documents = where(enabled: true)
documents = documents.keep_if {|doc| doc.start_date.nil? || doc.start_date <= Date.today}
documents = documents.keep_if {|doc| doc.end_date.nil? || doc.end_date >= Date.tomorrow}
documents
end
end
このメソッドを Mongoid クエリに変換してパフォーマンスを改善するにはどうすればよいですか?
アップデート:
正しい動作を検証するために使用しているRSpecテストは次のとおりです。
describe '.active' do
let!(:disabled){ Fabricate(:model, enabled: false, name: 'disabled') }
let!(:enabled_without_date){ Fabricate(:active_model, name: 'enabled_without_date') }
let!(:past){ Fabricate(:active_model, start_date: 1.week.ago, end_date: Date.yesterday, name: 'past') }
let!(:current){ Fabricate(:active_model, start_date: Date.today, end_date: Date.tomorrow, name: 'current') }
let!(:future){ Fabricate(:active_model, start_date: Date.tomorrow, end_date: 1.week.from_now, name: 'future') }
it 'returns only enabled and within the current time' do
MyModel.count.should == 5
models = MyModel.active.to_a
models.should_not be_empty
models.should_not include disabled
models.should_not include past
models.should_not include future
models.should include enabled_without_date
models.should include current
end
end