Nuovo errore in ActiveRecord quando si attiva un utente da rails c

In precedenza (fino a qualche mese fa), sono stato in grado di creare utenti con:

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

Ora il passaggio activate fallisce con:

[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

Cosa devo fare?

L’utente ottiene un ID utente quando lo crei? Sospetto di no, ma non so perché.

1 Mi Piace

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>

Ho provato a salvare l’utente prima di attivarlo, come suggerito dall’errore, ma senza successo. Non so cosa intenda il messaggio di errore con “parent”.

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

Stai fallendo la validazione qui, ecco perché.

ad esempio la password è troppo corta.

Puoi far emergere l’eccezione facendo questo:

u.save!

che restituisce, ad esempio:

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'

Un modo piĂą rapido per arrivarci sarebbe stato aggiungere un punto esclamativo dopo il create:

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

Non verrà assegnato un ID finché non avrai fornito all’oggetto attributi completamente validi, o al momento della creazione o al momento del salvataggio dopo averli corretti.

Solo quando hai un oggetto istanziato puoi procedere all’esecuzione di metodi su di esso.

4 Mi Piace

Grazie ragazzi, la password era troppo corta. Tutto a posto ora.

1 Mi Piace

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