diff options
| author | (no author) <(no author)@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-07-01 03:01:07 +0000 |
|---|---|---|
| committer | (no author) <(no author)@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-07-01 03:01:07 +0000 |
| commit | f3a97d4cbb5af3d4daaeb9de95ee6b69a5869bf6 (patch) | |
| tree | f29cefcfff3689ffba9ea03f1c5ff9b4596777fd /test/openssl/test_cipher.rb | |
| parent | 476d1394e7f6c4b9ff26304531f7bfcea3075774 (diff) | |
| download | ruby-f3a97d4cbb5af3d4daaeb9de95ee6b69a5869bf6.tar.gz ruby-f3a97d4cbb5af3d4daaeb9de95ee6b69a5869bf6.tar.xz ruby-f3a97d4cbb5af3d4daaeb9de95ee6b69a5869bf6.zip | |
This commit was manufactured by cvs2svn to create branch 'ruby_1_8'.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@6554 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/openssl/test_cipher.rb')
| -rw-r--r-- | test/openssl/test_cipher.rb | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/test/openssl/test_cipher.rb b/test/openssl/test_cipher.rb new file mode 100644 index 000000000..8711e46aa --- /dev/null +++ b/test/openssl/test_cipher.rb @@ -0,0 +1,62 @@ +begin + require "openssl" +rescue LoadError +end +require "test/unit" + +if defined?(OpenSSL) + +class OpenSSL::TestCipher < Test::Unit::TestCase + def setup + @c1 = OpenSSL::Cipher::Cipher.new("DES-EDE3-CBC") + @c2 = OpenSSL::Cipher::DES.new(:EDE3, "CBC") + @key = "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" + @iv = @key + @hexkey = "0000000000000000000000000000000000000000000000" + @hexiv = "0000000000000000" + @data = "DATA" + end + + def teardown + @c1 = @c2 = nil + end + + def test_crypt + s1 = @c1.encrypt(@key, @iv).update(@data) + @c1.final + s2 = @c2.encrypt(@key, @iv).update(@data) + @c2.final + assert_equal(s1, s2, "encrypt") + assert_equal(@data, @c1.decrypt(@key, @iv).update(s2)+@c1.final, "decrypt") + assert_equal(@data, @c2.decrypt(@key, @iv).update(s1)+@c2.final, "decrypt") + end + + def test_info + assert_equal("DES-EDE3-CBC", @c1.name, "name") + assert_equal("DES-EDE3-CBC", @c2.name, "name") + assert_kind_of(Fixnum, @c1.key_len, "key_len") + assert_kind_of(Fixnum, @c1.iv_len, "iv_len") + end + + def test_dup + assert_equal(@c1.name, @c1.dup.name, "dup") + assert_equal(@c1.name, @c1.clone.name, "clone") + @c1.encrypt + @c1.key = @key + @c1.iv = @iv + tmpc = @c1.dup + s1 = @c1.update(@data) + @c1.final + s2 = tmpc.update(@data) + tmpc.final + assert_equal(s1, s2, "encrypt dup") + end + + def test_reset + @c1.encrypt + @c1.key = @key + @c1.iv = @iv + s1 = @c1.update(@data) + @c1.final + @c1.reset + s2 = @c1.update(@data) + @c1.final + assert_equal(s1, s2, "encrypt reset") + end +end + +end |
