2011-11-27 14 views
9

He tratando de resolver un problema con mis pruebas de especificaciones y me sale el siguiente error fracasos:RSPEC y niña fábrica SystemStackError: nivel de pila demasiado profundo

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 

Antes de esto he tenido problemas con las asociaciones con mi suerte.

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 

y mis pruebas de sesión hasta el momento son:

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 

Realmente no estoy seguro de lo que está creando el problema. En mi modelo, asigno una función predeterminada a cada usuario como "Registrado" y la función "Administrador" para el primer usuario.

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 

Cualquier consejo sería muy bienvenida. Gracias

+0

Posible duplicado de [FactoryGirl problema de modelo de asociación: "SystemStackError: stack level too deep"] (http://stackoverflow.com/questions/7479031/factorygirl-association-model-trouble-systemstackerror-stack-level-too- profundo) –

Respuesta

20

La línea problema es el siguiente:

@user = Factory(:user) 

tiene una referencia circular: su fábrica :user crea una fábrica :role y :admin. Luego, las fábricas :role y :admin crean cada una otra fábrica :user, que luego crea otra fábrica más :role y :admin, y así sucesivamente hasta que obtiene un error de nivel de pila demasiado profundo.

Deberá eliminar las asociaciones de algunos de estos. Recomiendo eliminar las líneas role.association de :role y :admin. Siempre que cree un :user, aún creará las líneas :role y :admin por usted.

+0

Gracias Dylan, entiendo el problema del bucle, pero ahora estoy recuperando mi antiguo error 'NoMethodError: método indefinido' role = 'for # '. Al menos entiendo el ciclo que se creó :). –

Cuestiones relacionadas