diff options
| author | Louise Crow <louise.crow@gmail.com> | 2013-10-03 12:19:52 +0100 | 
|---|---|---|
| committer | Louise Crow <louise.crow@gmail.com> | 2013-10-03 12:19:52 +0100 | 
| commit | 1f6771c1545e320437a2fbecf7ddd0f8abdf77d1 (patch) | |
| tree | c32f5117ea27b2b7bc1f980b6eca11c2d2d5fcdd | |
| parent | 666a7a0b53974ce5bd545d1e69a50aa46b59ee79 (diff) | |
| parent | dd229afcec3ed124603e1875636135972434b7e7 (diff) | |
Merge branch 'hotfix/0.14.0.2' into wdtk
| -rw-r--r-- | app/controllers/track_controller.rb | 3 | ||||
| -rw-r--r-- | spec/controllers/track_controller_spec.rb | 33 | ||||
| -rw-r--r-- | spec/factories.rb | 7 | 
3 files changed, 42 insertions, 1 deletions
| diff --git a/app/controllers/track_controller.rb b/app/controllers/track_controller.rb index 40fa69290..72c092221 100644 --- a/app/controllers/track_controller.rb +++ b/app/controllers/track_controller.rb @@ -181,7 +181,8 @@ class TrackController < ApplicationController          if new_medium == 'delete'              track_thing.destroy              flash[:notice] = _("You are no longer following {{track_description}}.", :track_description => track_thing.params[:list_description]) -            redirect_to params[:r] +            redirect_to URI.parse(params[:r]).path +          # Reuse code like this if we let medium change again.          #elsif new_medium == 'email_daily'          #    track_thing.track_medium = new_medium diff --git a/spec/controllers/track_controller_spec.rb b/spec/controllers/track_controller_spec.rb index a16024828..57d084f6b 100644 --- a/spec/controllers/track_controller_spec.rb +++ b/spec/controllers/track_controller_spec.rb @@ -55,6 +55,39 @@ describe TrackController, "when making a new track on a request" do  end +describe TrackController, "when unsubscribing from a track" do + +    before do +        @track_thing = FactoryGirl.create(:track_thing) +    end + +    it 'should destroy the track thing' do +        get :update, {:track_id => @track_thing.id, +                      :track_medium => 'delete', +                      :r => 'http://example.com'}, +                     {:user_id => @track_thing.tracking_user.id} +        TrackThing.find(:first, :conditions => ['id = ? ', @track_thing.id]).should == nil +    end + +    it 'should redirect to a URL on the site' do +        get :update, {:track_id => @track_thing.id, +                      :track_medium => 'delete', +                      :r => '/'}, +                     {:user_id => @track_thing.tracking_user.id} +        response.should redirect_to('/') +    end + +    it 'should not redirect to a url on another site' do +        track_thing = FactoryGirl.create(:track_thing) +        get :update, {:track_id => @track_thing.id, +                      :track_medium => 'delete', +                      :r => 'http://example.com/'}, +                     {:user_id => @track_thing.tracking_user.id} +        response.should redirect_to('/') +    end + +end +  describe TrackController, "when sending alerts for a track" do      render_views diff --git a/spec/factories.rb b/spec/factories.rb index 653525920..7d8f94ac1 100644 --- a/spec/factories.rb +++ b/spec/factories.rb @@ -137,4 +137,11 @@ FactoryGirl.define do          last_edit_comment "Making an edit"      end +    factory :track_thing do +        association :tracking_user, :factory => :user +        track_medium 'email_daily' +        track_type 'search_query' +        track_query 'Example Query' +    end +  end | 
