用户测试无法正常工作

时间:2018-05-08 19:36:00

标签: ruby-on-rails ruby unit-testing

所以这是我第一次在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

class DeviseCreateUsers&lt; ActiveRecord的::迁移[5.1]

 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

ActiveRecord :: Schema.define(版本:20180413094453)做

  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

1 个答案:

答案 0 :(得分:0)

祝贺测试。它总是比调试好。试试rake db:test:prepare