diff options
author | Michael Koziarski <michael@koziarski.com> | 2012-07-04 12:37:31 +1200 |
---|---|---|
committer | Michael Koziarski <michael@koziarski.com> | 2012-10-01 14:22:19 +1300 |
commit | def2ccb8e3534e06ec1bb9c33aeee35a52b40138 (patch) | |
tree | d38907288811267ca37d9828afff26c0973226f9 /activesupport/test/key_generator_test.rb | |
parent | a6cfd33865a11eefcb3431450c8f2ad2b2766066 (diff) | |
download | rails-def2ccb8e3534e06ec1bb9c33aeee35a52b40138.tar.gz rails-def2ccb8e3534e06ec1bb9c33aeee35a52b40138.tar.bz2 rails-def2ccb8e3534e06ec1bb9c33aeee35a52b40138.zip |
Add ActiveSupport::KeyGenerator as a simple wrapper around PBKDF2
This will be used to derive keys from the secret and a salt, in order to allow us to
do things like encrypted cookie stores without using the secret for multiple
purposes directly.
Diffstat (limited to 'activesupport/test/key_generator_test.rb')
-rw-r--r-- | activesupport/test/key_generator_test.rb | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/activesupport/test/key_generator_test.rb b/activesupport/test/key_generator_test.rb new file mode 100644 index 0000000000..525082d313 --- /dev/null +++ b/activesupport/test/key_generator_test.rb @@ -0,0 +1,32 @@ +require 'abstract_unit' + +begin + require 'openssl' + OpenSSL::PKCS5 +rescue LoadError, NameError + $stderr.puts "Skipping KeyGenerator test: broken OpenSSL install" +else + +require 'active_support/time' +require 'active_support/json' + +class KeyGeneratorTest < ActiveSupport::TestCase + def setup + @secret = SecureRandom.hex(64) + @generator = ActiveSupport::KeyGenerator.new(@secret, :iterations=>2) + end + + test "Generating a key of the default length" do + derived_key = @generator.generate_key("some_salt") + assert_kind_of String, derived_key + assert_equal OpenSSL::Digest::SHA1.new.block_length, derived_key.length, "Should have generated a key of the default size" + end + + test "Generating a key of an alternative length" do + derived_key = @generator.generate_key("some_salt", 32) + assert_kind_of String, derived_key + assert_equal 32, derived_key.length, "Should have generated a key of the right size" + end +end + +end |