From 946cf0e700fd7ed540f18a01a4796642ba2f10ae Mon Sep 17 00:00:00 2001 From: akr Date: Sat, 16 Feb 2008 09:02:12 +0000 Subject: * encoding.c (rb_enc_compatible): empty strings are always compatible. * string.c (rb_enc_cr_str_buf_cat): ditto. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@15506 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/ruby/test_utf16.rb | 42 +++++++++++++++++++++++++++++++++++++++++- 1 file changed, 41 insertions(+), 1 deletion(-) (limited to 'test/ruby') diff --git a/test/ruby/test_utf16.rb b/test/ruby/test_utf16.rb index 6e4fb4016..9074aa723 100644 --- a/test/ruby/test_utf16.rb +++ b/test/ruby/test_utf16.rb @@ -169,9 +169,49 @@ EOT enccall("aa".force_encoding("UTF-16BE"), :slice!, -1) end - def test_concat + def test_plus_empty1 s1 = "" s2 = "aa".force_encoding("utf-16be") + assert_nothing_raised("#{encdump s1} << #{encdump s2}") { + s1 + s2 + } + end + + def test_plus_empty2 + s1 = "aa" + s2 = "".force_encoding("utf-16be") + assert_nothing_raised("#{encdump s1} << #{encdump s2}") { + s1 + s2 + } + end + + def test_plus_nonempty + s1 = "aa" + s2 = "bb".force_encoding("utf-16be") + assert_raise(ArgumentError, "#{encdump s1} << #{encdump s2}") { + s1 + s2 + } + end + + def test_concat_empty1 + s1 = "" + s2 = "aa".force_encoding("utf-16be") + assert_nothing_raised("#{encdump s1} << #{encdump s2}") { + s1 << s2 + } + end + + def test_concat_empty2 + s1 = "aa" + s2 = "".force_encoding("utf-16be") + assert_nothing_raised("#{encdump s1} << #{encdump s2}") { + s1 << s2 + } + end + + def test_concat_nonempty + s1 = "aa" + s2 = "bb".force_encoding("utf-16be") assert_raise(ArgumentError, "#{encdump s1} << #{encdump s2}") { s1 << s2 } -- cgit