Omniauth-facebook Devise Rspec, undefined method `extra' for nil:NilClass-Collection of common programming errors

I’m trying to test omniauth-facebook integration in my app, but i keep getting this failures:

Failure/Error: get :facebook
 NoMethodError:
   undefined method `extra' for nil:NilClass
 # ./app/models/user.rb:17:in `find_for_facebook_oauth'
 # ./app/controllers/users/omniauth_callbacks_controller.rb:4:in `facebook'
 # ./spec/controllers/users/omniauth_callbacks_controller_spec.rb:18:in `block (4 levels) in '

Here is the code lines raising the failure:

user.rb :

def self.find_for_facebook_oauth(auth, signed_in_resource=nil)
  data = auth.extra.raw_info # this is line 17
  if user = User.where(:email => data.email).first
    user
  else
    user = User.new
    user
  end
end

omniauth_callbacks_controller.rb :

def facebook
  @user = User.find_for_facebook_oauth(request.env["omniauth.auth"], current_user) # this is line 4

  if @user.persisted?
    flash[:notice] = I18n.t "devise.omniauth_callbacks.success", :kind => "Facebook"
    sign_in_and_redirect @user, :event => :authentication
  else
    flash[:notice] = "Authentication was successful, please continue your registration process."
    session["devise.facebook_data"] = request.env["omniauth.auth"]
    redirect_to new_user_registration_url
  end
end

omniauth_callbacks_controller_spec.rb :

before(:each) do
  stub_env_for_omniauth

  get :facebook # this is line 18
  @user = User.where(:email => "[email protected]").first
end

def stub_env_for_omniauth
  request.env["devise.mapping"] = Devise.mappings[:user]
  pre = { "omniauth.auth" => { "provider" => "facebook", "uid" => "1234", "credentials" => {"token" => "abcdefg"}, "extra"=>{"raw_info" => {"id" => "1234567", "email" => "[email protected]", "name" => "Mark", "gender" => "male" }}}}
  env = OmniAuth::AuthHash.new(pre)
  @controller.stub!(:env).and_return(env)
end

And this is spec_helper.rb :

require 'omniauth'
OmniAuth.config.test_mode = true

Any ideas?

  1. hey just add following line in facebook method

    def facebook
    raise request.env["omniauth.auth"].to_yaml
    ....
    end
    

    and then check what response you are getting from facebook-omniauth.This might help you to detect the problem.

Originally posted 2013-11-09 22:41:17.