diff options
author | Louise Crow <louise.crow@gmail.com> | 2014-12-23 17:40:18 +0000 |
---|---|---|
committer | Louise Crow <louise.crow@gmail.com> | 2015-04-27 16:50:32 +0100 |
commit | 28428468c52037ea4ee40a31f37edce7a334973c (patch) | |
tree | 3158d36d3515cf2376834dd0f8b677d3f3ca4d7b /spec/controllers | |
parent | 5b99495ef39feda47da098f896a801beafc892c5 (diff) |
Use resource-based RESTful routing and separate controller
Diffstat (limited to 'spec/controllers')
-rw-r--r-- | spec/controllers/request_controller_spec.rb | 61 | ||||
-rw-r--r-- | spec/controllers/track_controller_spec.rb | 46 | ||||
-rw-r--r-- | spec/controllers/widgets_controller_spec.rb | 111 |
3 files changed, 111 insertions, 107 deletions
diff --git a/spec/controllers/request_controller_spec.rb b/spec/controllers/request_controller_spec.rb index cdd1b43f0..c4f3c847e 100644 --- a/spec/controllers/request_controller_spec.rb +++ b/spec/controllers/request_controller_spec.rb @@ -2764,64 +2764,3 @@ describe RequestController, "#select_authorities" do end end - -describe RequestController, "#widget" do - - before do - @info_request = FactoryGirl.create(:info_request) - end - - it 'should render the widget template' do - get :widget, :id => @info_request.id - expect(response).to render_template('widget') - end - - it 'should find the info request' do - get :widget, :id => @info_request.id - assigns[:info_request].should == @info_request - end - - it 'should create a track thing for the request' do - get :widget, :id => @info_request.id - assigns[:track_thing].info_request.should == @info_request - end - - it 'should assign the request status' do - get :widget, :id => @info_request.id - assigns[:status].should == @info_request.calculate_status - end - - context 'for a non-logged-in user' do - - context 'if no widget-vote cookie is set' do - - it 'should set a widget-vote cookie' do - cookies[:widget_vote].should be_nil - get :widget, :id => @info_request.id - cookies[:widget_vote].should_not be_nil - end - - end - - end - - -end - -describe RequestController, "#create_widget" do - - before do - @info_request = FactoryGirl.create(:info_request) - end - - it 'should render the create widget template' do - get :create_widget, :id => @info_request.id - expect(response).to render_template('create_widget') - end - - it 'should find the info request' do - get :create_widget, :id => @info_request.id - assigns[:info_request].should == @info_request - end - -end diff --git a/spec/controllers/track_controller_spec.rb b/spec/controllers/track_controller_spec.rb index b7f679cdb..29f5c7fe1 100644 --- a/spec/controllers/track_controller_spec.rb +++ b/spec/controllers/track_controller_spec.rb @@ -275,49 +275,3 @@ describe TrackController, "when tracking a public body" do end end - -describe TrackController do - include LinkToHelper - - describe :widget_vote do - - before do - @info_request = FactoryGirl.create(:info_request) - end - - it 'should find the info request' do - get :widget_vote, :info_request_id => @info_request.id - assigns[:info_request].should == @info_request - end - - it 'should redirect to the track path for the info request' do - get :widget_vote, :info_request_id => @info_request.id - track_thing = TrackThing.create_track_for_request(@info_request) - expect(response).to redirect_to(do_track_path(track_thing)) - end - - context 'when there is no logged-in user and a widget vote cookie' do - - before do - @cookie_value = 'x' * 20 - end - - it 'should create a widget vote if none exists for the info request and cookie' do - @info_request.widget_votes.where(:cookie => @cookie_value).size.should == 0 - request.cookies['widget_vote'] = @cookie_value - get :widget_vote, :info_request_id => @info_request.id - @info_request.widget_votes.where(:cookie => @cookie_value).size.should == 1 - end - - it 'should not create a widget vote if one exists for the info request and cookie' do - @info_request.widget_votes.create(:cookie => @cookie_value) - request.cookies['widget_vote'] = @cookie_value - get :widget_vote, :info_request_id => @info_request.id - @info_request.widget_votes.where(:cookie => @cookie_value).size.should == 1 - end - - end - - end - -end diff --git a/spec/controllers/widgets_controller_spec.rb b/spec/controllers/widgets_controller_spec.rb new file mode 100644 index 000000000..e60f1b3cb --- /dev/null +++ b/spec/controllers/widgets_controller_spec.rb @@ -0,0 +1,111 @@ +# coding: utf-8 +require File.expand_path(File.dirname(__FILE__) + '/../spec_helper') + +describe WidgetsController do + + include LinkToHelper + + describe "#show" do + + before do + @info_request = FactoryGirl.create(:info_request) + end + + it 'should render the widget template' do + get :show, :request_id => @info_request.id + expect(response).to render_template('show') + end + + it 'should find the info request' do + get :show, :request_id => @info_request.id + assigns[:info_request].should == @info_request + end + + it 'should create a track thing for the request' do + get :show, :request_id => @info_request.id + assigns[:track_thing].info_request.should == @info_request + end + + it 'should assign the request status' do + get :show, :request_id => @info_request.id + assigns[:status].should == @info_request.calculate_status + end + + context 'for a non-logged-in user' do + + context 'if no widget-vote cookie is set' do + + it 'should set a widget-vote cookie' do + cookies[:widget_vote].should be_nil + get :show, :request_id => @info_request.id + cookies[:widget_vote].should_not be_nil + end + + end + + end + + + end + + describe "#new" do + + before do + @info_request = FactoryGirl.create(:info_request) + end + + it 'should render the create widget template' do + get :new, :request_id => @info_request.id + expect(response).to render_template('new') + end + + it 'should find the info request' do + get :new, :request_id => @info_request.id + assigns[:info_request].should == @info_request + end + + end + + describe :update do + + before do + @info_request = FactoryGirl.create(:info_request) + end + + it 'should find the info request' do + get :update, :request_id => @info_request.id + assigns[:info_request].should == @info_request + end + + it 'should redirect to the track path for the info request' do + get :update, :request_id => @info_request.id + track_thing = TrackThing.create_track_for_request(@info_request) + expect(response).to redirect_to(do_track_path(track_thing)) + end + + context 'when there is no logged-in user and a widget vote cookie' do + + before do + @cookie_value = 'x' * 20 + end + + it 'should create a widget vote if none exists for the info request and cookie' do + @info_request.widget_votes.where(:cookie => @cookie_value).size.should == 0 + request.cookies['widget_vote'] = @cookie_value + get :update, :request_id => @info_request.id + @info_request.widget_votes.where(:cookie => @cookie_value).size.should == 1 + end + + it 'should not create a widget vote if one exists for the info request and cookie' do + @info_request.widget_votes.create(:cookie => @cookie_value) + request.cookies['widget_vote'] = @cookie_value + get :update, :request_id => @info_request.id + @info_request.widget_votes.where(:cookie => @cookie_value).size.should == 1 + end + + end + + end + +end + |