require File.dirname(__FILE__) + '/test_helper.rb' class TestConditionTypes < Test::Unit::TestCase def test_sanitize condition = Searchgasm::Condition::BeginsWith.new(Account, :column => Account.columns_hash["name"]) condition.value = "Binary" assert_equal ["\"accounts\".\"name\" LIKE ?", "Binary%"], condition.sanitize condition = Searchgasm::Condition::Blank.new(Account, :column => Account.columns_hash["id"]) condition.value = "true" assert_equal "\"accounts\".\"id\" is NULL or \"accounts\".\"id\" = '' or \"accounts\".\"id\" = false", condition.sanitize condition = Searchgasm::Condition::Blank.new(Account, :column => Account.columns_hash["id"]) condition.value = "false" assert_equal "\"accounts\".\"id\" is NOT NULL and \"accounts\".\"id\" != '' and \"accounts\".\"id\" != false", condition.sanitize condition = Searchgasm::Condition::Blank.new(Account, :column => Account.columns_hash["id"]) condition.value = true assert_equal "\"accounts\".\"id\" is NULL or \"accounts\".\"id\" = '' or \"accounts\".\"id\" = false", condition.sanitize condition = Searchgasm::Condition::Blank.new(Account, :column => Account.columns_hash["id"]) condition.value = false assert_equal "\"accounts\".\"id\" is NOT NULL and \"accounts\".\"id\" != '' and \"accounts\".\"id\" != false", condition.sanitize condition = Searchgasm::Condition::Blank.new(Account, :column => Account.columns_hash["id"]) condition.value = nil assert_equal nil, condition.sanitize condition = Searchgasm::Condition::Blank.new(Account, :column => Account.columns_hash["id"]) condition.value = "" assert_equal nil, condition.sanitize condition = Searchgasm::Condition::ChildOf.new(User) condition.value = User.first.id assert_equal ["\"users\".\"parent_id\" = ?", User.first.id], condition.sanitize condition = Searchgasm::Condition::ChildOf.new(User) condition.value = User.first assert_equal ["\"users\".\"parent_id\" = ?", User.first.id], condition.sanitize condition = Searchgasm::Condition::DescendantOf.new(User) condition.value = User.find(1) assert_equal ["\"users\".\"id\" = ? OR \"users\".\"id\" = ?", 2, 3], condition.sanitize condition = Searchgasm::Condition::EndsWith.new(Account, :column => Account.columns_hash["name"]) condition.value = "Binary" assert_equal ["\"accounts\".\"name\" LIKE ?", "%Binary"], condition.sanitize condition = Searchgasm::Condition::Equals.new(Account, :column => Account.columns_hash["id"]) condition.value = 12 assert_equal ["\"accounts\".\"id\" = ?", 12], condition.sanitize condition = Searchgasm::Condition::Equals.new(Account, :column => Account.columns_hash["id"]) condition.value = [1,2,3,4] assert_equal ["\"accounts\".\"id\" IN (?)", [1, 2, 3, 4]], condition.sanitize condition = Searchgasm::Condition::Equals.new(Account, :column => Account.columns_hash["id"]) condition.value = (1..10) assert_equal ["\"accounts\".\"id\" BETWEEN ? AND ?", 1, 10], condition.sanitize condition = Searchgasm::Condition::GreaterThan.new(Account, :column => Account.columns_hash["id"]) condition.value = 2 assert_equal ["\"accounts\".\"id\" > ?", 2], condition.sanitize condition = Searchgasm::Condition::GreaterThanOrEqualTo.new(Account, :column => Account.columns_hash["id"]) condition.value = 2 assert_equal ["\"accounts\".\"id\" >= ?", 2], condition.sanitize condition = Searchgasm::Condition::InclusiveDescendantOf.new(User) condition.value = User.find(1) assert_equal ["(\"users\".\"id\" = ?) OR (\"users\".\"id\" = ? OR \"users\".\"id\" = ?)", 1, 2, 3], condition.sanitize condition = Searchgasm::Condition::Like.new(Account, :column => Account.columns_hash["name"]) condition.value = "Binary and blah" assert_equal ["\"accounts\".\"name\" LIKE ?", "%Binary and blah%"], condition.sanitize condition = Searchgasm::Condition::Nil.new(Account, :column => Account.columns_hash["id"]) condition.value = true assert_equal "\"accounts\".\"id\" is NULL", condition.sanitize condition = Searchgasm::Condition::Nil.new(Account, :column => Account.columns_hash["id"]) condition.value = false assert_equal "\"accounts\".\"id\" is NOT NULL", condition.sanitize condition = Searchgasm::Condition::Nil.new(Account, :column => Account.columns_hash["id"]) condition.value = "true" assert_equal "\"accounts\".\"id\" is NULL", condition.sanitize condition = Searchgasm::Condition::Nil.new(Account, :column => Account.columns_hash["id"]) condition.value = "false" assert_equal "\"accounts\".\"id\" is NOT NULL", condition.sanitize condition = Searchgasm::Condition::Nil.new(Account, :column => Account.columns_hash["id"]) condition.value = nil assert_equal nil, condition.sanitize condition = Searchgasm::Condition::Nil.new(Account, :column => Account.columns_hash["id"]) condition.value = "" assert_equal nil, condition.sanitize condition = Searchgasm::Condition::NotEqual.new(Account, :column => Account.columns_hash["id"]) condition.value = 12 assert_equal ["\"accounts\".\"id\" != ?", 12], condition.sanitize condition = Searchgasm::Condition::NotEqual.new(Account, :column => Account.columns_hash["id"]) condition.value = [1,2,3,4] assert_equal ["\"accounts\".\"id\" NOT IN (?)", [1, 2, 3, 4]], condition.sanitize condition = Searchgasm::Condition::NotEqual.new(Account, :column => Account.columns_hash["id"]) condition.value = (1..10) assert_equal ["\"accounts\".\"id\" NOT BETWEEN ? AND ?", 1, 10], condition.sanitize condition = Searchgasm::Condition::Keywords.new(Account, :column => Account.columns_hash["name"]) condition.value = "freedom yeah, freedom YEAH right" assert_equal ["\"accounts\".\"name\" LIKE ? AND \"accounts\".\"name\" LIKE ? AND \"accounts\".\"name\" LIKE ?", "%freedom%", "%yeah%", "%right%"], condition.sanitize condition = Searchgasm::Condition::Keywords.new(Account, :column => Account.columns_hash["name"]) condition.value = "%^$*(^$)" assert_equal nil, condition.sanitize condition = Searchgasm::Condition::LessThan.new(Account, :column => Account.columns_hash["id"]) condition.value = 2 assert_equal ["\"accounts\".\"id\" < ?", 2], condition.sanitize condition = Searchgasm::Condition::LessThanOrEqualTo.new(Account, :column => Account.columns_hash["id"]) condition.value = 2 assert_equal ["\"accounts\".\"id\" <= ?", 2], condition.sanitize condition = Searchgasm::Condition::SiblingOf.new(User) condition.value = User.find(2) assert_equal ["(\"users\".\"id\" != ?) AND (\"users\".\"parent_id\" = ?)", 2, 1], condition.sanitize end end