diff options
| author | Louise Crow <louise.crow@gmail.com> | 2014-09-04 11:32:57 +0100 | 
|---|---|---|
| committer | Louise Crow <louise.crow@gmail.com> | 2014-09-04 11:32:57 +0100 | 
| commit | 43edd82fb495e1dda39bdfa0c76de29f6bbbc57a (patch) | |
| tree | 4065de56b6def0b03a0d0c2bfdd121d8cb4ed9d2 | |
| parent | 6d215fba5cc709c43f12f86da39a643e4be5922b (diff) | |
Fix for purging of cached attachments for non-default locales.0.17.0.4hotfix/0.17.0.4
| -rw-r--r-- | app/controllers/admin_controller.rb | 3 | ||||
| -rw-r--r-- | app/controllers/application_controller.rb | 8 | ||||
| -rw-r--r-- | app/models/info_request.rb | 13 | ||||
| -rw-r--r-- | spec/integration/alaveteli_dsl.rb | 9 | ||||
| -rw-r--r-- | spec/integration/view_request_spec.rb | 22 | ||||
| -rw-r--r-- | spec/models/info_request_spec.rb | 17 | 
6 files changed, 62 insertions, 10 deletions
| diff --git a/app/controllers/admin_controller.rb b/app/controllers/admin_controller.rb index 8b606ea85..3bf40b8f9 100644 --- a/app/controllers/admin_controller.rb +++ b/app/controllers/admin_controller.rb @@ -25,8 +25,7 @@ class AdminController < ApplicationController      def expire_for_request(info_request)          # Clear out cached entries, by removing files from disk (the built in          # Rails fragment cache made doing this and other things too hard) -        cache_subpath = foi_fragment_cache_all_for_request(info_request) -        FileUtils.rm_rf(cache_subpath) +        info_request.foi_fragment_cache_directories.each{ |dir| FileUtils.rm_rf(dir) }          # Remove any download zips          FileUtils.rm_rf(info_request.download_zip_dir) diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb index 370e8e15c..921b9a2f5 100644 --- a/app/controllers/application_controller.rb +++ b/app/controllers/application_controller.rb @@ -188,14 +188,6 @@ class ApplicationController < ActionController::Base          return File.join(File.split(path).map{|x| x[0...max_file_length]})      end -    def foi_fragment_cache_all_for_request(info_request) -        # return stub path so admin can expire it -        first_three_digits = info_request.id.to_s()[0..2] -        path = "views/request/#{first_three_digits}/#{info_request.id}" -        foi_cache_path = File.expand_path(File.join(File.dirname(__FILE__), '../../cache')) -        return File.join(foi_cache_path, path) -    end -      def foi_fragment_cache_exists?(key_path)          return File.exists?(key_path)      end diff --git a/app/models/info_request.rb b/app/models/info_request.rb index 47ad435cb..cd020c27c 100644 --- a/app/models/info_request.rb +++ b/app/models/info_request.rb @@ -1038,6 +1038,19 @@ public          File.join(Rails.root, "cache", "zips", "#{Rails.env}")      end +    def foi_fragment_cache_directories +        # return stub path so admin can expire it +        directories = [] +        path = File.join("request", request_dirs) +        foi_cache_path = File.expand_path(File.join(Rails.root, 'cache', 'views')) +        directories << File.join(foi_cache_path, path) +        I18n.available_locales.each do |locale| +            directories << File.join(foi_cache_path, locale.to_s, path) +        end + +        directories +    end +      def request_dirs          first_three_digits = id.to_s()[0..2]          File.join(first_three_digits.to_s, id.to_s) diff --git a/spec/integration/alaveteli_dsl.rb b/spec/integration/alaveteli_dsl.rb index 119bb05a0..1d56abbdf 100644 --- a/spec/integration/alaveteli_dsl.rb +++ b/spec/integration/alaveteli_dsl.rb @@ -64,5 +64,14 @@ def close_request(request)      request.save!  end +def cache_directories_exist?(request) +    cache_path = File.join(Rails.root, 'cache', 'views') +    paths = [File.join(cache_path, 'request', request.request_dirs)] +    I18n.available_locales.each do |locale| +        paths << File.join(cache_path, locale.to_s, 'request', request.request_dirs) +    end +    paths.any?{ |path| File.exist?(path) } +end + diff --git a/spec/integration/view_request_spec.rb b/spec/integration/view_request_spec.rb index 814e20fb3..eecb984f5 100644 --- a/spec/integration/view_request_spec.rb +++ b/spec/integration/view_request_spec.rb @@ -19,6 +19,28 @@ describe "When viewing requests" do         @unregistered.browses_request("#{@info_request.url_title}?action=add")      end +    context "when a request is hidden by an admin" do + +        it 'should not retain any cached attachments to be served up by the webserver' do +            admin = login(FactoryGirl.create(:admin_user)) +            non_owner = login(FactoryGirl.create(:user)) +            info_request = FactoryGirl.create(:info_request_with_incoming_attachments) +            incoming_message = info_request.incoming_messages.first +            attachment_url = "/es/request/#{info_request.id}/response/#{incoming_message.id}/attach/2/interesting.pdf" +            non_owner.get(attachment_url) +            cache_directories_exist?(info_request).should be_true + +            # Admin makes the incoming message requester only +            post_data = {:incoming_message => {:prominence => 'hidden', +                                               :prominence_reason => 'boring'}} +            admin.post_via_redirect "/admin/incoming/update/#{info_request.incoming_messages.first.id}", post_data +            admin.response.should be_success + +            cache_directories_exist?(info_request).should be_false +        end + +    end +      context 'when a response has prominence "normal"' do          before do diff --git a/spec/models/info_request_spec.rb b/spec/models/info_request_spec.rb index 9766f928f..1dda253a8 100644 --- a/spec/models/info_request_spec.rb +++ b/spec/models/info_request_spec.rb @@ -146,6 +146,23 @@ describe InfoRequest do      end +    describe 'when managing the cache directories' do +        before do +            @info_request = info_requests(:fancy_dog_request) +        end + +        it 'should return the default locale cache path without locale parts' do +            default_locale_path = File.join(Rails.root, 'cache', 'views', 'request', '101', '101') +            @info_request.foi_fragment_cache_directories.include?(default_locale_path).should == true +        end + +        it 'should return the cache path for any other locales' do +            other_locale_path =  File.join(Rails.root, 'cache', 'views', 'es', 'request', '101', '101') +            @info_request.foi_fragment_cache_directories.include?(other_locale_path).should == true +        end + +    end +      describe " when emailing" do          before do | 
