I’m running a simple unit test to validate that ActiveRecord raises an
exception when I try and update a column with a duplicate foreign key.
Inside the unit test,
charge.time_logs << time_logs(:first)
will generate
ActiveRecord::StatementInvalid: Mysql::Error: #23000Duplicate entry
‘20’ for key 2: UPDATE time_logs SET task_id = 1, date_created =
NULL, time_charge_id = 20, hours = 2.0, log_entry = NULL WHERE id
= 2
However,
assert_raise ActiveRecord::StatementInvalid do
charge.time_logs << time_logs(:first)
end
will generate
ActiveRecord::StatementInvalid exception expected but none was
thrown.
What am I doing wrong?