开发者

Rails ActiveRecord doesn't seem to handle null values correctly in the test enviornment

Everything seems to work well in the development and production environments:

> script/console
Loading development environment (Rails 2.3.8)
ruby-1.8.7-p302 > Tape.find(:first, :conditions => "deleted_at is not null").deleted_at.nil?
 => false 
ruby-1.8.7-p302 > Tape.find(:first, :conditions => "deleted_at is null").deleted_at.nil?
 => true

So why am I getting the exact opposite results in the test environment?

> script/console test
Loading test environment (Rails 2.3开发者_如何学C.8)
ruby-1.8.7-p302 > Tape.find(:first, :conditions => "deleted_at is not null").deleted_at.nil?
 => true

Searching for deleted_at is null never returns any records in the test environment, even when some calls have deleted_at = nil and some have a timestamp there.

Here's a partial readout of the mysql table:

mysql> describe tapes;
+-----------------+--------------+------+-----+---------+----------------+
| Field           | Type         | Null | Key | Default | Extra          |
+-----------------+--------------+------+-----+---------+----------------+
| id              | int(11)      | NO   | PRI | NULL    | auto_increment |
...
| deleted_at      | datetime     | YES  |     | NULL    |                |
+-----------------+--------------+------+-----+---------+----------------+

Does anyone know what's going on? Is this a bug?


Are your test and production databases both MySQL or is the test database SQLite? Some databases (like SQLite) may treat a null value the same as an empty string, so you want to use blank? instead of nil?.


So it turns out that the method I was using to create null values in my fixture was incorrect. It seems that if you want a real null value from a csv fixture is to have that field default to null and just don't include that column in your csv. Hopefully this will help someone else :)

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜