Sha256: 4a03a87ba6ac274a8fbb9cb3dd82d385b8f42589e41408d33ceb878cf91b3a71
Contents?: true
Size: 1.27 KB
Versions: 27
Compression:
Stored size: 1.27 KB
Contents
require File.join(File.dirname(File.expand_path(__FILE__)), "spec_helper") describe "Sequel::Plugins::InvertedSubsets" do it "should add an inverted subset method which inverts the condition" do c = Class.new(Sequel::Model(:a)) c.plugin :inverted_subsets c.subset(:published, :published => true) c.not_published.sql.must_equal 'SELECT * FROM a WHERE (published IS NOT TRUE)' end it "should support a configuration block to customise the inverted method name" do c = Class.new(Sequel::Model(:a)) c.plugin(:inverted_subsets){|name| "exclude_#{name}"} c.subset(:published, :published => true) c.exclude_published.sql.must_equal 'SELECT * FROM a WHERE (published IS NOT TRUE)' end it "should chain to existing dataset" do c = Class.new(Sequel::Model(:a)) c.plugin :inverted_subsets c.subset(:published, :published => true) c.where(1=>0).not_published.sql.must_equal 'SELECT * FROM a WHERE ((1 = 0) AND (published IS NOT TRUE))' end it "should work in subclasses" do c = Class.new(Sequel::Model) c.plugin(:inverted_subsets){|name| "exclude_#{name}"} c = Class.new(c) c.dataset = :a c.subset(:published, :published => true) c.exclude_published.sql.must_equal 'SELECT * FROM a WHERE (published IS NOT TRUE)' end end
Version data entries
27 entries across 26 versions & 2 rubygems