2011-02-12 2 views
1

Ceci est l'erreur que je vois:Essayer de mettre en œuvre l'enregistrement dans Rails, mais l'exécution expire lorsque le formulaire soumis

Timeout::Error in Devise/registrationsController#create 

execution expired 

C'est ce que mon development.rb ressemble:

MyApp::Application.configure do 
    # Settings specified here will take precedence over those in config/environment.rb 

    # In the development environment your application's code is reloaded on 
    # every request. This slows down response time but is perfect for development 
    # since you don't have to restart the webserver when you make code changes. 
    config.cache_classes = false 

    # Log error messages when you accidentally call methods on nil. 
    config.whiny_nils = true 

    # Show full error reports and disable caching 
    config.consider_all_requests_local  = true 
    config.action_view.debug_rjs    = true 
    config.action_controller.perform_caching = false 

    # Don't care if the mailer can't send 
    config.action_mailer.raise_delivery_errors = true 

    # Print deprecation notices to the Rails logger 
    config.active_support.deprecation = :log 

    # Only use best-standards-support built into browsers 
    config.action_dispatch.best_standards_support = :builtin 


    config.action_mailer.default_url_options = { :host => 'localhost:3000' } #Make sure to set 'host' to domain name in production. 
    config.action_mailer.delivery_method = :smtp 
    config.action_mailer.perform_deliveries = false 
    config.action_mailer.raise_delivery_errors = true 
    config.action_mailer.default :charset => "utf-8" 

end 

Je vérifie ma les journaux, ce que je vois, une fois que je clique sur le bouton « Soumettre » sur le formulaire d'inscription:

Started GET "https://stackoverflow.com/users/register" for 127.0.0.1 at 2011-02-11 19:19:23 -0500 
    Processing by Devise::RegistrationsController#new as HTML 
nil 
Rendered devise/shared/_links.erb (2.4ms) 
Rendered devise/registrations/new.html.erb within layouts/application (98.1ms) 
Completed 200 OK in 160ms (Views: 109.0ms | ActiveRecord: 0.0ms) 


Started POST "/users" for 127.0.0.1 at 2011-02-11 19:20:03 -0500 
    Processing by Devise::RegistrationsController#create as HTML 
    Parameters: {"utf8"=>"✓", "authenticity_token"=>"qWs4IOH3L+GT/Sld8rZRlhXi8JM0pe0NtWG4Tn9XRIU=", "user"=>{"username"=>"marcamillion", "f_name"=>"marc", "l_name"=>"gayle", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]", "email"=>"[email protected]"}, "commit"=>"Register"} 
nil 
WARNING: Can't mass-assign protected attributes: f_name, l_name 
    User Load (0.2ms) SELECT "users"."id" FROM "users" WHERE (LOWER("users"."email") = LOWER('[email protected]')) LIMIT 1 
    User Load (0.1ms) SELECT "users"."id" FROM "users" WHERE (LOWER("users"."username") = LOWER('marcamillion')) LIMIT 1 
    CACHE (0.0ms) SELECT "users"."id" FROM "users" WHERE (LOWER("users"."email") = LOWER('[email protected]')) LIMIT 1 
    User Load (0.2ms) SELECT "users".* FROM "users" WHERE ("users"."confirmation_token" = 'DCo8QgqWQfnYWq20n5Uf') LIMIT 1 
    AREL (31.0ms) INSERT INTO "users" ("email", "encrypted_password", "password_salt", "reset_password_token", "remember_token", "remember_created_at", "sign_in_count", "current_sign_in_at", "last_sign_in_at", "current_sign_in_ip", "last_sign_in_ip", "username", "f_name", "l_name", "created_at", "updated_at", "invitation_token", "invitation_sent_at", "plan_id", "current_state", "confirmation_token", "confirmed_at", "confirmation_sent_at") VALUES ('[email protected]', '$2a$10$55hQTGZpUKbeT5n30/eyau96jf5zzd18t19jV/Y4g8Urou/El4vKy', '$2a$10$55hQTGZpUKbeT5n30/eyau', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 'marcamillion', NULL, NULL, '2011-02-12 00:20:03.699983', '2011-02-12 00:20:03.699983', NULL, NULL, NULL, NULL, 'DCo8QgqWQfnYWq20n5Uf', NULL, '2011-02-12 00:20:03.699855') 
Rendered devise/mailer/confirmation_instructions.html.erb (1.0ms) 

Sent mail to [email protected] (30009ms) 
Date: Fri, 11 Feb 2011 19:20:03 -0500 
From: [email protected] 
To: [email protected] 
Message-ID: <[email protected]> 
Subject: Confirmation instructions 
Mime-Version: 1.0 
Content-Type: text/html; 
charset=UTF-8 
Content-Transfer-Encoding: 7bit 

<p>Welcome [email protected]!</p> 

<p>You can confirm your account through the link below:</p> 

<p><a href="http://localhost:3000/users/confirmation?confirmation_token=DCo8QgqWQfnYWq20n5Uf">Confirm my account</a></p> 
Completed in 30349ms 

Timeout::Error (execution expired): 
+0

Avez-vous un serveur SMTP fonctionnant sur localhost? – johnmcaliley

+0

hrmm .... Je ne l'ai jamais explicitement mis en place. Mais, en ce qui me concerne, je pensais que la seule chose que je devais avoir était l'ensemble ci-dessus dans mon fichier development.rb. Comment vérifier si le serveur SMTP est en cours d'exécution? – marcamillion

+0

Je doute que vous en ayez un à moins que vous ne l'ayez installé manuellement et/ou que vous l'ayez démarré localement. J'ai ajouté une réponse – johnmcaliley

Répondre

2

Je suppose que vous ne faites pas avoir un serveur SMTP s'exécutant localement. À moins que vous avez vraiment besoin du courrier à livrer dans le développement, vous pouvez supprimer ce genre de choses et il ne faut pas erreur sur vous:

config.action_mailer.default_url_options = { :host => 'localhost:3000' } #Make sure to set 'host' to domain name in production. 
config.action_mailer.delivery_method = :smtp 
config.action_mailer.perform_deliveries = false 
config.action_mailer.raise_delivery_errors = true 
config.action_mailer.default :charset => "utf-8" 

Si vous ne voulez courrier livré en dev, puis la mise en google place un serveur smtp. Ou vous pouvez même utiliser quelque chose comme Gmail comme serveur SMTP

+0

en regardant de plus près, effectuer des livraisons est défini sur false, donc je m'attendrais à ce qu'il ne tente pas de se connecter à smtp ... J'essayerais toujours de supprimer la config et de voir ce qui se passe. – johnmcaliley

+0

Cela fonctionne bien. Je l'ai juste commenté et je n'ai plus le temps de le faire. Merci. – marcamillion

Questions connexes