2014-12-04 78 views
1

我想寫一個rspec測試,將;rspec水豚選擇器軌4

  • 訪問商店頁面
  • 選擇在各國家的價值選擇框
  • ,並測試值存在(最初在國家框,但我也將被測試的城市是依賴於國家在第二次測試)

HTML頁面

<!DOCTYPE html> 
<html> 
    <head> 
    <title>Ruby on Rails Tutorial Sample App</title> 
    <link data-turbolinks-track="true" href="/assets/application.css?body=1" media="all" rel="stylesheet" /> 
<link data-turbolinks-track="true" href="/assets/custom.css?body=1" media="all" rel="stylesheet" /> 
<link data-turbolinks-track="true" href="/assets/password_resets.css?body=1" media="all" rel="stylesheet" /> 
<link data-turbolinks-track="true" href="/assets/people.css?body=1" media="all" rel="stylesheet" /> 
<link data-turbolinks-track="true" href="/assets/products.css?body=1" media="all" rel="stylesheet" /> 
<link data-turbolinks-track="true" href="/assets/scaffolds.css?body=1" media="all" rel="stylesheet" /> 
<link data-turbolinks-track="true" href="/assets/sessions.css?body=1" media="all" rel="stylesheet" /> 
<link data-turbolinks-track="true" href="/assets/static_pages.css?body=1" media="all" rel="stylesheet" /> 
<link data-turbolinks-track="true" href="/assets/store.css?body=1" media="all" rel="stylesheet" /> 
<link data-turbolinks-track="true" href="/assets/users.css?body=1" media="all" rel="stylesheet" /> 
    <script data-turbolinks-track="true" src="/assets/jquery.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/jquery_ujs.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/bootstrap.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/turbolinks.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/password_resets.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/people.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/products.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/sessions.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/static_pages.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/store.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/users.js?body=1"></script> 
<script data-turbolinks-track="true" src="/assets/application.js?body=1"></script> 
    <meta content="authenticity_token" name="csrf-param" /> 
<meta content="NcsV3Ve7QqLTjeLNz5MLuCxzvG8urc63NiDk7RZTGtM=" name="csrf-token" /> 
    <!--[if lt IE 9]> 
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script> 
<![endif]--> 

    </head> 
    <body> 
    <header class="navbar navbar-fixed-top navbar-inverse"> 
    <div class="navbar-inner"> 
    <div class="container"> 
     <a href="/" id="logo">sample app</a> 
     <nav> 
     <ul class="nav btn-group navbar-nav navbar-right list-inline"> 
        <li><a href="/">Home</a></li> 
      <li><a href="/help">Help</a></li> 
      <li><a href="/signin">Sign in</a></li> 
     </ul> 
     </div> 
     </ul> 
     </nav> 
    </div> 
    </div> 
</header> 


     <div class="container"> 




<h2>some text</h2> 
<div class="row"> 
    <div class="col-md-4 col-md-offset-4"> 
    <div class="row"> 
     <div class="col-md-6 col-md-offset-2"> 
     <form accept-charset="UTF-8" action="/store/show" method="get"><div style="display:none"><input name="utf8" type="hidden" value="&#x2713;" /></div> 

      <label for="catalogue_country">Country</label> 
      <select id="countries_select" name="catalogue[country_id]"><option selected="selected" value="1">France</option> 
<option value="2">Italy</option> 
<option value="3">United Kingdom</option></select> 

     <div class="pull-right"> 
      <input class="btn brn-large btn-primary" name="commit" type="submit" value="Add to Cart" /> 
</form>  </div> 
     </div> 
    </div> 
    </div> 
</div> 


     <footer class="footer"> 
    <small> 
    <a href="http://railstutorial.org/">Rails Tutorial</a> 
    by Michael Hartl 
    </small> 
    <nav> 
    <ul> 
     <li><a href="/about">About</a></li> 
     <li><a href="/contact">Contact</a></li> 
     <li><a href="http://news.railstutorial.org/">News</a></li> 
    </ul> 
    </nav> 
</footer> 


     <pre class="debug_dump">--- !ruby/hash:ActionController::Parameters 
controller: store 
action: index 
</pre> 

    </div> 
    </body> 

</html> 

我的測試

require 'spec_helper' 

describe "index" do 

    subject { page } 

    before do 

    visit store_path 

    select "United Kingdom", :from => "catalogue[country_id]" 

    end 

    it { should have_select('country_id', :selected => 'United Kingdom') } 

end 

的故障

失敗:

1)索引 故障/錯誤:訪問store_path NoMethodError: 未定義的方法`ID」的零:NilClass

軌道控制檯[ app.store_path]驗證store_path是'/ store'

選擇框是動態的根據此博客的方向posting

任何幫助表示讚賞盟友填充,在此先感謝

有路由

match '/store', to: 'store#index', as: :store, via: 'get' 

    get 'store/show' 

    match 'store/update_cities', to: 'store#update_cities', as: :update_cities, via: 'get' 

    match 'store/update_currencies', to: 'store#update_currencies', as: :update_currencies, via: 'get' 

它的一個索引頁(store_path),其中有一個國家選擇框。

這是存儲控制器

def index 

    @countries = Country.all 

    @cities = City.where("country_id = ?", Country.first.id) 

    @currencies = Currency.where("country_id = ?", Country.first.id) 

    @locations = Location.where("city_id = ?", Location.first.id) 

    @products = Product.where("Location_id = ?", Product.first.id) 

    @plugs = Plug.where("Location_id = ?", Plug.first.id) 

    end 

    def show 
    end 

    def update_cities 

    @cities = City.where("country_id = ?", params[:country_id]) 

    respond_to do |format| 

     format.js 

    end 
    end 

回答

2

你試圖訪問一個特定的商店,或者列出所有的商店?

你的情況,您嘗試訪問,你需要在這種情況下傳遞參數爲它的商店ID

要知道在控制檯的確切路徑寫一個特定的商店:

rake routes 

,你會發現每個路徑的網址,如果你想列出你需要寫的所有商店:代替

stores_path 

store_path 

store_path是/存儲/:ID

+0

我已經加入上述路線和控制器,該「/存儲」路徑路由到store_index.html.erb,這一個頁面有3個選擇框,第一個國家,然後是城市,貨幣。它是我希望測試的選擇框中的值。 – Conor 2014-12-04 20:46:56

+0

國家模式是否有任何條目?可能在種子什麼的?因爲如果沒有,這意味着國家模式中沒有條目。在這種情況下,您正在嘗試查找無對象的ID如同您在索引操作中所說的:Country.first.id, 要自己測試它,請嘗試在索引操作中使用調試器 – 2014-12-06 21:43:36

+0

您可以定義種子中的國家或嘗試爲其創建工廠 – 2014-12-06 21:46:58