Authlogic openid: получение неопределенного метода openid_identifier? ошибка в функциональном тесте
Я использую Authlogic с надстройкой Authlogic-openid (я установил ruby- openid и скрипт / плагин установил git://github.com/rails/open_id_authentication.git) и получаю две ошибки.
Во-первых, при запуске функционального тестирования я получаю неопределенный метод openid_identifier? сообщение в строке в моем файле new.html.erb при запуске UsersControllerTest. Линия это:
<% if @user.openid_identifier? %>
При запуске скрипта / консоли я могу получить доступ к этому методу без проблем.
Во-вторых, при тестировании функциональности openid и регистрации нового пользователя в моем приложении с использованием openid и моей учетной записи blogspot для этого я получаю в файле журнала следующее:
Generated checkid_setup request to http://www.blogger.com/openid-server.g
with assocication ...
Redirected to http://www.blogger.com/openid-server.g?openid.assoc_handle=...
NoMethodError (You have a nil object when you didn't expect it!
The error occurred while evaluating nil.call):
app/controllers/users_controller.rb:44:in `create'
/usr/lib/ruby/1.8/webrick/httpserver.rb:104:in `service'
/usr/lib/ruby/1.8/webrick/httpserver.rb:65:in `run'
/usr/lib/ruby/1.8/webrick/server.rb:173:in `start_thread'
/usr/lib/ruby/1.8/webrick/server.rb:162:in `start'
/usr/lib/ruby/1.8/webrick/server.rb:162:in `start_thread'
/usr/lib/ruby/1.8/webrick/server.rb:95:in `start'
/usr/lib/ruby/1.8/webrick/server.rb:92:in `each'
/usr/lib/ruby/1.8/webrick/server.rb:92:in `start'
/usr/lib/ruby/1.8/webrick/server.rb:23:in `start'
/usr/lib/ruby/1.8/webrick/server.rb:82:in `start'
Код в users_controller прост:
def create
respond_to do |format|
@user.save do |result|
if result
flash[:notice] = t('Thanks for signing up!')
format.html { redirect_to :action => 'index' }
format.xml { render :xml => @user, :status => :created, :location => @user }
else
format.html { render :action => "new" }
format.xml { render :xml => @user.errors, :status => :unprocessable_entity }
end
end
end
end
Строка, сообщающая об ошибке: @user.save do |result|...
Я чувствую, что упускаю что-то довольно простое, но я слишком долго на это смотрю, потому что не могу найти, что это такое. Я проверил с помощью кода на эпизодах Railscasts 160 и 170 и проекта кости GitHub, но ничего не нашел.
Спасибо за вашу помощь, usr
2 ответа
Проблема заключается в том, что плагины authlogic_oauth и authlogic_openid использовались одновременно. Это означает, что метод save для пользователя будет обрабатываться кодом openid, установленным из кода oauth.
Возможно, библиотека authlogic_rpx может успешно объединить два метода, мне нужно еще это проверить.
Вы уверены, что @user установлен? Сдается мне, что проблема в том, что @user - ноль.