所以这是我第一次在rails中运行测试,这是我得到的错误。
运行:
电子
错误:PostsControllerTest#test_should_show_post: ActiveRecord :: StatementInvalid:找不到表'users'
bin / rails test test / controllers / posts_controller_test.rb:26
电子
错误:PostsControllerTest#test_should_update_post: ActiveRecord :: StatementInvalid:找不到表'users'
bin / rails test test / controllers / posts_controller_test.rb:36
电子
错误:PostsControllerTest#test_should_create_post: ActiveRecord :: StatementInvalid:找不到表'users'
bin / rails test test / controllers / posts_controller_test.rb:18
电子
错误:PostsControllerTest#test_should_destroy_post: ActiveRecord :: StatementInvalid:找不到表'users'
bin / rails test test / controllers / posts_controller_test.rb:41
电子
错误:PostsControllerTest#test_should_get_new: ActiveRecord :: StatementInvalid:找不到表'users'
bin / rails test test / controllers / posts_controller_test.rb:13
电子
错误:PostsControllerTest#test_should_get_index: ActiveRecord :: StatementInvalid:找不到表'users'
bin / rails test test / controllers / posts_controller_test.rb:8
电子
错误:PostsControllerTest#test_should_get_edit: ActiveRecord :: StatementInvalid:找不到表'users'
bin / rails test test / controllers / posts_controller_test.rb:31
电子
错误:UserTest#test_user_should_be_valid: ActiveRecord :: StatementInvalid:找不到表'users'
bin / rails test test / models / user_test.rb:8
电子
错误:
HomeControllerTest#test_should_get_index: ActiveRecord :: StatementInvalid:找不到表'users'
bin / rails test test / controllers / home_controller_test.rb:4
以0.316289s结束,28.4550次/秒,0.0000次断言/秒。 9次运行,0次断言,0次失败,9次错误,0次跳过
说无法找到用户表,为什么会这样。继承我的代码。
require 'test_helper'
class UserTest < ActiveSupport::TestCase
def setup
@user=User.new(name:"minhaj")
end
test "user should be valid" do
assert @category.valid?
end
end
def change
create_table :users do |t|
## Database authenticatable
t.string :email, null: false, default: ""
t.string :encrypted_password, null: false, default: ""
## Recoverable
t.string :reset_password_token
t.datetime :reset_password_sent_at
## Rememberable
t.datetime :remember_created_at
## Trackable
t.integer :sign_in_count, default: 0, null: false
t.datetime :current_sign_in_at
t.datetime :last_sign_in_at
t.string :current_sign_in_ip
t.string :last_sign_in_ip
## Confirmable
# t.string :confirmation_token
# t.datetime :confirmed_at
# t.datetime :confirmation_sent_at
# t.string :unconfirmed_email # Only if using reconfirmable
## Lockable
# t.integer :failed_attempts, default: 0, null: false # Only if lock strategy is :failed_attempts
# t.string :unlock_token # Only if unlock strategy is :email or :both
# t.datetime :locked_at
t.timestamps null: false
end
add_index :users, :email, unique: true
add_index :users, :reset_password_token, unique: true
# add_index :users, :confirmation_token, unique: true
# add_index :users, :unlock_token, unique: true
end
end
create_table "posts", force: :cascade do |t|
t.datetime "date"
t.string "name"
t.integer "user_id"
t.text "description"
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.float "latitude"
t.float "longitude"
t.string "address"
end
create_table "rsvps", force: :cascade do |t|
t.integer "user_id"
t.integer "post_id"
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.index ["post_id"], name: "index_rsvps_on_post_id"
t.index ["user_id"], name: "index_rsvps_on_user_id"
end
# Could not dump table "users" because of following StandardError
# Unknown type 'false' for column 'admin_role'
end
答案 0 :(得分:0)
祝贺测试。它总是比调试好。试试rake db:test:prepare
。