ruby-on-rails - Rails 没有将用户数据输入到 postgresql

标签 ruby-on-rails postgresql rspec

我遇到 Rails 没有向 postgresql 输入值的问题。数据库本身是连接的。当我运行 db:create:all(来自 database.yml 的片段)

development:
  adapter: postgresql
  encoding: unicode
  database: website_development
  username: postgres
  password: *******
  host: 127.0.0.1
  port: 9435

(测试:相同,但数据库:website_test 而不是 website_development)所有数据库都是为测试和开发而创建的。当我运行我的 db:migration 时,也会创建用户表,例如迁移文件“date”_create_user.rb 的片段

class CreateUsers < ActiveRecord::Migration
  def self.up

    create_table :users do |t|
      t.string :username
      t.string :email

      t.timestamps
    end
  end

  def self.down
    drop_table :users
  end
end

(我检查了 pgAdmin 并找到了创建的表)但是当我尝试从控制台插入数据时,例如(这是在沙箱中运行的)

irb(main):001:0> User.create!(:username => "John", :email => "john@example.com)
=> #<User id: 1, username: nil, email: nil, created_at: "2011-04-26 22:00:28", u
pdated_at: "2011-04-26 22:00:28">

这是在不同的创建上生成的 sql!我已经跑了

[1m[35mSQL (2.0ms)[0m  INSERT INTO "users" ("username", "email", "created_at", "updated_at") VALUES (NULL, NULL, '2011-04-26 20:53:43.363908', '2011-04-26 20:53:43.363908') RETURNING "id"

关于为什么 rails 可以很好地创建数据库和表但找不到正确的用户名和电子邮件以输入 sql 的任何帮助。

附言我正在为我的测试运行 Rspec,并针对用户名和电子邮件的值不为 nil 进行了多项测试,所有测试均成功。

......................
Finished in 1.62 seconds
22 examples, 0 failures
Notification failed: 201 - The destination server was not reachable
Notification failed: 201 - The destination server was not reachable

如您所见,所有 Rspec 测试都是绿色的,但它无法连接到 postgres 服务器

预先感谢您的任何建议。

更新:添加了用户模型片段

class User < ActiveRecord::Base

    attr_accessor :username, :email

    email_regex = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i
    username_regex = /\A[\w\d]+\z/i

    validates :username, :presence   => true,
                         :format     => { :with => username_regex },
                         :length     => { :maximum => 30},
                         :uniqueness => { :case_sensitive => false }
    validates :email,    :presence   => true,
                         :format     => { :with => email_regex },
                         :uniqueness => { :case_sensitive => false }
end

==答案==

这些是我的错误:

第 1 部分:通过将 attr_accessor 更改为 attr_accessible,我的所有测试都正常工作,所有需要变为红色的内容,这也让我可以添加 :电子邮件 详细信息但不是 :username 详细信息,这导致第 2 部分。

第 2 部分:由于某些原因,rails 不喜欢我的表被命名为 :user 而我的列被命名为 :username。所以我尝试将 :username 更改为 :loginname ,这完全解决了问题。

谢谢大家的帮助。

最佳答案

要隔离此问题,您可能需要构建一个单元测试来重现问题,然后根据需要进行修复。起初我怀疑这是 protected 属性的情况,但看起来您已经使它们可访问,这是正确的做法。

直接调用 create! 有点危险,因为在发生异常时您不容易捕捉到创建了一半的对象。这是因为尽管异常包含对模型的引用,但如果不进行额外挖掘,尚不清楚是用户模型还是其他模型首先导致了异常。

更靠谱的做法是这样的:

def test_create_example
  user = User.new(:username => "John", :email => "john@example.com")

  assert_equal 'John', user.username
  assert_equal 'john@example.com', email

  user.save

  assert_equal [ ], user.errors.full_messages
  assert_equal false, user.new_record?
end

如果验证流中发生错误,您将看到错误列在应该为空数组的旁边。它还通过测试记录是否不再是新记录来检查记录是否已保存,因为记录可能有效但如果 before_savebefore_create 过滤器返回 false,这是偶然发生的事情。

如果您调用 new 然后调用 save,您将有机会在保存之前和之后检查新准备的对象。

关于ruby-on-rails - Rails 没有将用户数据输入到 postgresql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5797204/

相关文章:

postgresql - 基于 Web 的 PostgreSQL 数据库管理和浏览

ruby-on-rails - 测试 401 错误且未找到记录时 Rspec 挂起

mysql - 在 Ruby on Rails 中添加到数组

ruby-on-rails - 断开并取消订阅 Action Cable on Rails 6

database-design - 审计表数据库设计 : Does creating Audit Tables for Join Tables make sense

rspec - watir-rspec 记者的自定义屏幕截图

ruby-on-rails - 功能测试错误 - 未初始化常量 FFaker::File

ruby-on-rails - 用于测试的未定义方法 `users'

ruby-on-rails - Rails paperclip-dropbox 未上传到 Dropbox

arrays - 使用 excel 文件内容初始化对象并保存到数据库