Ich habe ein Szenario, das funktioniert gut, wenn ich echte Omniauth, aber scheitert, wenn ich es mit dem Mock Auth in Gurke/Capybara laufen.Callback Umleitung nicht Sitzung beibehalten
Im Rückruf, wenn ich sign_in @user
mache, erstellt er erfolgreich den Benutzer und meldet sich an ... current_user
ist gesetzt. Aber wenn ich dann redirect_to request.env['omniauth.origin'] || '/'
mache, ist current_user
in der folgenden Aktion jetzt Null.
Ich habe per Screenshots/Pause des Browsers bestätigt, dass es nicht mit der Mock-Auth funktioniert. Derselbe Fehler tritt bei Firefox- und Chrome-Treibern auf.
Irgendeine Idee, warum das passieren würde?
/features/support/env.rb:
Cucumber::Rails::Database.javascript_strategy = :truncation
Szenario:
@javascript
Scenario:
Given I am on the home page
When I press "Login"
And I should see "Login with Twitter" in the selector "#login-modal"
Given Omniauth returns a user with provider "twitter" and uid "1" and nickname "foo"
When I login with Twitter
Then I should be logged in as "foo"
Schritt Definitionen:
Given(/^Omniauth returns a user with provider "(.*?)" and uid "(.*?)" and nickname "(.*?)"$/) do |provider, uid, nickname|
OmniAuth.config.test_mode = true
OmniAuth.config.add_mock(provider.to_sym, {
:uid => uid,
:info => {
:name => nickname
}
})
end
Then(/^I should be logged in as "(.*?)"$/) do |nickname|
expect(page).to have_content(nickname)
end
Auth Rückruf:
def twitter
@user = User.from_omniauth(request.env["omniauth.auth"]) # this works-- I get the mock
sign_in @user
puts ">> in auth callback: just signed in user #{current_user.id}"
redirect_to request.env['omniauth.origin'] || '/'
end
Controller:
def new
puts ">> in my_controller#new: current_user = #{current_user.id if current_user}"
end
Gurke Ausgang:
Given Omniauth returns a user with provider "twitter" and uid "1" and nickname "foo"
>> in auth callback: just signed in user 1
>> in my_controller#new: current_user =
When I login with Twitter
Then I should be logged in as "foo"
expected to find text "foo" in [redacted] (RSpec::Expectations::ExpectationNotMetError)
Jede Lösung für dieses Problem? Hast du etwas gefunden? –
Nein, immer noch fest. – joshwa
gut bitte überprüfen Sie die Kopfzeile der Anfrage für real und für die Mock, möglicherweise sollten Sie etwas in der Mock hinzufügen – ikirachen