Я новичок в рельсах, и у меня возникли проблемы с консолью. Я хотел бы добавить записи в мою таблицу Users и протестировать некоторые функции. Однако каждый раз, когда я выполняю User.create
или аналогичную функцию, она успешно завершается, а затем сразу же возвращается к предыдущему состоянию. Как мне предотвратить немедленный откат?
Я не в режиме песочницы.
Ниже приведен вывод, который я получаю в консоли при попытке создать пользователя. Он говорит, что пользователь существует, а затем немедленно откатывает транзакцию. Затем я запускаю User.all
, чтобы показать, что транзакция действительно откатилась.
>>> User.create(first_name: "derek", last_name: "harrington", email: "derek@gmail.com")
(0.1ms) begin transaction
User Exists (0.2ms) SELECT 1 FROM "users" WHERE "users"."email" = 'derek@gmail.com' LIMIT 1
(0.1ms) rollback transaction
=> #<User id: nil, first_name: "derek", last_name: "harrington", email: "derek@gmail.com", password_digest: nil, credit_card_id: nil, address_id: nil, created_at: nil, updated_at: nil>
>>> User.all
User Load (0.3ms) SELECT "users".* FROM "users"
=> []
Как сделать эти изменения постоянными и предотвратить откат?
Изменить:
Вот содержимое моей User
модели
class User < ActiveRecord::Base
attr_accessible :first_name, :last_name, :email, :password, :password_confirmation
has_secure_password
validates :first_name, presence: true, length: { maximum: 50 }
validates :last_name, presence: true, length: { maximum: 50 }
VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i
validates :email, presence: true,
format: { with: VALID_EMAIL_REGEX },
uniqueness: true
validates :password, confirmation: true, length: { minimum: 6, maximum: 50 }
validates :password_confirmation, presence: true
end