2011-11-27 3 views
9

ho cercando di risolvere un problema con il mio test Spec e ottengo il seguente errore Fallimenti:RSPEC e Factory Girl SystemStackError: livello di stack troppo in profondità

problemi
1) SessionsController POST 'create' with valid email and password should sign in the user 
    Failure/Error: Unable to find matching line from backtrace 
    SystemStackError: 
     stack level too deep 
    # /Users/Aurelien/.rvm/gems/[email protected]/gems/activerecord-3.1.0/lib/active_record/connection_adapters/abstract/connection_specification.rb:103 

Finished in 37.77 seconds 
9 examples, 1 failure 

Failed examples: 

rspec ./spec/controllers/sessions_controller_spec.rb:35 # SessionsController POST 'create' with valid email and password should sign in the user 

Prima di questo ho avuto con le associazioni con la mia fabbriche.

Factory.define :role do |role| 
    role.name     "Registered" 
    role.association :user, :factory => :user 
end 

Factory.define :admin do |role| 
    role.name     "Admin" 
    role.association :user, :factory => :user 
end 

Factory.define :user do |user| 
    user.first_name    "Foo" 
    user.last_name    "Bar" 
    user.email     "[email protected]" 
    user.password    "foobar" 
    user.password_confirmation "foobar" 
    user.status     "At foobar" 
    user.description   "Lorem Ipsum sit dolor amet." 
    user.username    "foobar" 
    user.association :role, :factory => :role 
    user.association :admin, :factory => :role 
end 

Factory.define :user_with_admin_role, :parent => :user do |user| 
    user.after_create { |u| Factory(:role, :user => u) } 
end 

Factory.define :reg_user do |user| 
    user.first_name    "bar" 
    user.last_name    "foo" 
    user.email     "[email protected]" 
    user.password    "foobar" 
    user.password_confirmation "foobar" 
    user.status     "At foobar" 
    user.description   "Lorem Ipsum sit dolor amet." 
    user.username    "barfoo" 
    user.association :role, :factory => :role 
end 

e le mie prove di sessione finora sono:

describe "POST 'create'" do 
    describe "invalid signin" do 
     before(:each) do 
     @attr = { :email => "[email protected]", :password => "invalid" } 
     end 

     it "should re-render the 'new' page with a flash error" do 
     post :create, :session => @attr 
     flash.now[:error] =~ /invalid/i 
     response.should render_template('new') 
     end 

    end 

    describe "with valid email and password" do 

     before(:each) do 
     @user = Factory(:user) 
     @attr = { :email => @user.email, :password => @user.password} 
     end 

     it "should sign in the user" do 
     post :create, :session => @attr 
     controller.current_user.should == @user 
     end 

    end 

    end 

io non sono davvero sicuro di quello che sta creando il problema. Nel mio modello assegno un ruolo predefinito a ogni utente come "Registrato" e il ruolo "Amministratore" per il primo utente.

user.rb

def assign_default_role 
    if User.count == 0 
     self.roles << Role.find_by_name("Admin") 
     self.roles << Role.find_by_name("Registered") 
    end 
    self.roles << Role.find_by_name("Registered") unless User.count == 0 
    end 

Qualsiasi consiglio sarà il benvenuto. Grazie

+0

Possibile duplicato di [problema modello associazione FactoryGirl: "SystemStackError: livello stack troppo profondo"] (http://stackoverflow.com/questions/7479031/factorygirl-association-model-trouble-systemstackerror-stack-level-too- deep) –

risposta

20

La linea problema è questo:

@user = Factory(:user) 

Hai un riferimento circolare: la vostra fabbrica :user crea una fabbrica :role e :admin. Quindi le fabbriche :role e :admin creano ciascuna un altro factory :user, che crea quindi un altro :role e :admin factory, e così via finché non si ottiene un errore di livello troppo profondo.

È necessario rimuovere le associazioni da alcuni di questi. Mi consiglia di rimuovere le linee role.association da entrambi :role e :admin. Ogni volta che crei un :user, creerà comunque le linee :role e :admin per te.

+0

Grazie, Dylan, capisco il problema del loop, ma ora sto recuperando il mio errore precedente 'NoMethodError: metodo non definito' role = 'per # '. Almeno capisco il ciclo che è stato creato :). –