Nuevo error en ActiveRecord al activar usuario desde rails c

Anteriormente (hasta hace unos meses), he podido crear usuarios con:

sudo -s
cd /var/discourse
./launcher enter app
rails c
u = User.create(username: "dunderhead", email: "dunderhead@live.com", password: "password")
u.activate

Ahora el paso de activación falla con:

[7] pry(main)> u.activate
ActiveRecord::RecordNotSaved: No puedes llamar a create a menos que el padre se guarde
from /var/www/discourse/vendor/bundle/ruby/3.2.0/gems/activerecord-7.0.8/lib/active_record
/associations/collection_association.rb:342:in `_create_record'

¿Qué necesito hacer?

¿El usuario recibe un ID de usuario cuando lo creas? Sospecho que no, pero no sé por qué.

1 me gusta

No.

[4] pry(main)> u = User.create(username: "dunderhead", email: "dunderhead@live.com", password: "password")
=> #<User:0x00007fb0c48b17e0
 id: nil,
 username: "dunderhead",
 created_at: nil,
 updated_at: nil,
 name: nil,
 seen_notification_id: 0,
 last_posted_at: nil,
 password_hash: nil,
 salt: nil,
 active: false,
 username_lower: nil,
 last_seen_at: nil,
 admin: false,
 last_emailed_at: nil,
 trust_level: 0,
 approved: false,
 approved_by_id: nil,
 approved_at: nil,
 previous_visit_at: nil,
 suspended_at: nil,
 suspended_till: nil,
 date_of_birth: nil,
 views: 0,
 flag_level: 0,
 ip_address: nil,
 moderator: false,
 title: nil,
 uploaded_avatar_id: nil,
 locale: nil,
 primary_group_id: nil,
 registration_ip_address: nil,
 staged: false,
 first_seen_at: nil,
 silenced_till: nil,
 group_locked_trust_level: nil,
 manual_locked_trust_level: nil,
 secure_identifier: nil,
 last_digest_at: nil,
 flair_group_id: nil,
 last_seen_reviewable_id: nil,
 password_algorithm: nil>

Intenté guardar el usuario antes de activarlo, como sugería el error, pero no sirvió de nada. No sé a qué se refiere el mensaje de error con “padre”.

[5] pry(main)> u.save
=> false
[6] pry(main)> u.activate
ActiveRecord::RecordNotSaved: No puedes llamar a create a menos que el padre se guarde
from /var/www/discourse/vendor/bundle/ruby/3.2.0/gems/activerecord-7.0.8/lib/active_record/
associations/collection_association.rb:342:in `_create_record'

Estás fallando la validación aquí, por eso.

por ejemplo, la contraseña es demasiado corta.

Puedes propagar la excepción haciendo esto:

u.save!

lo que da, por ejemplo:

ActiveRecord::RecordInvalid: Validation failed: Password is too short (minimum is 10 characters)
from /home/robert/.rbenv/versions/3.2.2/lib/ruby/gems/3.2.0/gems/activerecord-7.0.8.1/lib/active_record/validations.rb:80:in `raise_validation_error'

Una forma más rápida de llegar a eso habría sido añadir un signo de exclamación después del create:

 u = User.create!(username: "dunderhead", email: "dunderhead@live.com", password: "password")

No se asignará un ID hasta que proporciones al objeto atributos completamente válidos, ya sea en la creación o al guardar después de corregirlos.

Solo cuando tengas un objeto instanciado podrás ejecutar métodos sobre él.

4 Me gusta

Gracias chicos, la contraseña era demasiado corta. Todo bien ahora.

1 me gusta

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.