ActiveRecord::Fixture::FixtureError: table "users" has no column named "activated_at".

window 7+ruby2.33+rails5.0. 

 

在测试的时候 rails test 报固件fixture错误: 没有某列字段存在

虽然可以直接通过开发框架去修改字段,但是开发过程中应该通过迁移文件来实现所有的修改

我错误的原因是,我在通过migration生成users表的时候把其中一个字段写错成actiavated_at(多了一个a),所以在测试固件找不到activated_at

1,第一步,rails db:rollback 撤销生成错误字段的migration文件

 或者 rails db:reset 重置整个数据库

                或者 重置数据报错无法执行的话,手动删除,方法如下 :

关闭项目,然后去db文件夹手动删除 test.sqlite3

 

2,然后修改之前的migration文件,修改好字段

 

3执行 rails db:migrate

4执行 rails db: miragte RAILS_ENV=test

再次测试rails test 没毛病

posted on 2018-03-03 09:28  一只猪儿虫  阅读(295)  评论(0编辑  收藏  举报