Ho scritto alcuni test utilizzando capybara per test delle richieste usando poltergeist e phantomjs come driver javascript.Capybara: impossibile trovare il campo modulo con js: true
i seguenti passaggi per la compilazione di un form di login grandi opere senza js:
it "signs in" do
visit new_user_session_path
fill_in "Email", with: user
fill_in "Password", with: password||"foobar"
click_button "Login"
end
Se io definisco il mio test con js it "signs in", js: true do
mia prova non riesce con l'errore:
Capybara::ElementNotFound: Unable to find field "Email"
Il modulo di login in sé è costruito usando simple_form come generatore di moduli e bootstrap in frontend. I campi non hanno un'etichetta. il testo di ricerca è contenuto solo nell'attributo segnaposto.
= simple_form_for(resource, :as => resource_name, :url => session_path(resource_name)) do |f|
= f.input :email, :placeholder => User.human_attribute_name(:email), :label => false, :input_html => {:class => 'input-xlarge'}
= f.input :password, :placeholder => User.human_attribute_name(:password), :label => false, :input_html => {:class => 'input-xlarge'}
%div
= f.button :submit, "Login", :class => 'btn btn-large btn-primary'
Questo codice genera il seguente codice html
<form accept-charset="UTF-8" action="https://stackoverflow.com/users/login" class="simple_form new_user" id="new_user" method="post" novalidate="novalidate">
<div style="margin:0;padding:0;display:inline">
<input name="utf8" type="hidden" value="✓">
</div>
<div class="control-group email required user_email">
<div class="controls">
<input class="string email required input-xlarge" id="user_email" name="user[email]" placeholder="Email" size="50" type="email" value="">
</div>
</div>
<div class="control-group password required user_password">
<div class="controls">
<input class="password required input-xlarge" id="user_password" name="user[password]" placeholder="Password" size="50" type="password">
</div>
</div>
<div>
<input class="btn btn btn-large btn-primary" name="commit" type="submit" value="Login">
</div>
</form>
Avete qualche idea di come garantire che i campi si trovano anche se JS è attivato?
Sei mai riuscito a trovare una soluzione di lavoro per questo? – Scott
Prova questo link che vi aiuterà http://stackoverflow.com/questions/15784398/test-case-for-hidden-field-is-not-working-with-cucumber – Arvind