Novo erro no ActiveRecord ao ativar usuário do rails c

Anteriormente (até alguns meses atrás), eu conseguia criar usuários com:

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

Agora, a etapa de ativação falha com:

[7] pry(main)> u.activate
ActiveRecord::RecordNotSaved: You cannot call create unless the parent is saved
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

O que preciso fazer?

O usuário recebe um ID de usuário quando você o cria? Suspeito que não, mas não sei por quê.

1 curtida

Não.

[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>

Eu tentei salvar o usuário antes de ativá-lo, como o erro sugeriu, mas não adiantou. Não sei o que a mensagem de erro quer dizer com “parent” (pai/mãe).

[5] pry(main)> u.save
=> false
[6] pry(main)> u.activate
ActiveRecord::RecordNotSaved: You cannot call create unless the parent is saved
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'

Você está falhando na validação aqui, é por isso.

Por exemplo, a senha é muito curta.

Você pode propagar a exceção fazendo isso:

u.save!

o que resulta, por exemplo:

ActiveRecord::RecordInvalid: Falha na validação: A senha é muito curta (o mínimo são 10 caracteres)
de /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'

Uma maneira mais rápida de chegar a isso teria sido adicionar um ponto de exclamação após o create:

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

Um ID não será atribuído até que você forneça ao objeto atributos totalmente válidos, seja na criação ou ao salvar após corrigi-los.

Somente quando você tiver um objeto instanciado poderá executar métodos nele.

4 curtidas

Obrigado pessoal, a senha era muito curta. Tudo certo agora.

1 curtida

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