aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/test
diff options
context:
space:
mode:
authorSantiago Pastorino <santiago@wyeworks.com>2011-09-22 10:03:54 -0700
committerSantiago Pastorino <santiago@wyeworks.com>2011-09-22 10:03:54 -0700
commit855184c468aefac2540367cefce603e7d45a937b (patch)
tree80df612d8aabe1321230b92b82ab2669ab8a6f3d /activesupport/test
parent43d27e9105b385f64ec195f60d10ab3d64281bd4 (diff)
parenta0352a425f4995f7f1e1035290fe59c93ac0d24f (diff)
downloadrails-855184c468aefac2540367cefce603e7d45a937b.tar.gz
rails-855184c468aefac2540367cefce603e7d45a937b.tar.bz2
rails-855184c468aefac2540367cefce603e7d45a937b.zip
Merge pull request #3096 from phuibonhoa/master
FileStore key_file_path does not properly limit filenames to 255 characters
Diffstat (limited to 'activesupport/test')
-rw-r--r--activesupport/test/caching_test.rb11
1 files changed, 10 insertions, 1 deletions
diff --git a/activesupport/test/caching_test.rb b/activesupport/test/caching_test.rb
index 6bb13ec9b8..b692a41312 100644
--- a/activesupport/test/caching_test.rb
+++ b/activesupport/test/caching_test.rb
@@ -357,7 +357,7 @@ module CacheStoreBehavior
def test_really_long_keys
key = ""
- 1000.times{key << "x"}
+ 900.times{key << "x"}
assert_equal true, @cache.write(key, "bar")
assert_equal "bar", @cache.read(key)
assert_equal "bar", @cache.fetch(key)
@@ -557,6 +557,15 @@ class FileStoreTest < ActiveSupport::TestCase
key = @cache_with_pathname.send(:key_file_path, "views/index?id=1")
assert_equal "views/index?id=1", @cache_with_pathname.send(:file_path_key, key)
end
+
+ # Because file systems have a maximum filename size, filenames > max size should be split in to directories
+ # If filename is 'AAAAB', where max size is 4, the returned path should be AAAA/B
+ def test_key_transformation_max_filename_size
+ key = "#{'A' * ActiveSupport::Cache::FileStore::FILENAME_MAX_SIZE}B"
+ path = @cache.send(:key_file_path, key)
+ assert path.split('/').all? { |dir_name| dir_name.size <= ActiveSupport::Cache::FileStore::FILENAME_MAX_SIZE}
+ assert_equal 'B', File.basename(path)
+ end
end
class MemoryStoreTest < ActiveSupport::TestCase