diff options
author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-12-08 16:48:52 +0000 |
---|---|---|
committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-12-08 16:48:52 +0000 |
commit | 4466d4baa94bb23f0cfb9aa48252a5ce0b6a1976 (patch) | |
tree | d61fc43ac6427095b34d31f6e884ef4303e00b52 /test/ruby/test_string.rb | |
parent | f679a6b10692729dbaa5248f1708e889143ed307 (diff) | |
download | ruby-4466d4baa94bb23f0cfb9aa48252a5ce0b6a1976.tar.gz |
* string.c (rb_str_init): now accepts new option parameter `encoding'.
[Feature #11785]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52976 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/ruby/test_string.rb')
-rw-r--r-- | test/ruby/test_string.rb | 33 |
1 files changed, 30 insertions, 3 deletions
diff --git a/test/ruby/test_string.rb b/test/ruby/test_string.rb index 824c0e6b1c..eed7c69a02 100644 --- a/test/ruby/test_string.rb +++ b/test/ruby/test_string.rb @@ -11,12 +11,39 @@ class TestString < Test::Unit::TestCase super end - def S(str) - @cls.new(str) + def S(*args) + @cls.new(*args) end def test_s_new - assert_equal("RUBY", S("RUBY")) + assert_equal("", S()) + assert_equal(Encoding::ASCII_8BIT, S().encoding) + + assert_equal("", S("")) + assert_equal(__ENCODING__, S("").encoding) + + src = "RUBY" + assert_equal(src, S(src)) + assert_equal(__ENCODING__, S(src).encoding) + + src.force_encoding("euc-jp") + assert_equal(src, S(src)) + assert_equal(Encoding::EUC_JP, S(src).encoding) + + + assert_equal("", S(encoding: "euc-jp")) + assert_equal(Encoding::EUC_JP, S(encoding: "euc-jp").encoding) + + assert_equal("", S("", encoding: "euc-jp")) + assert_equal(Encoding::EUC_JP, S("", encoding: "euc-jp").encoding) + + src = "RUBY" + assert_equal(src, S(src, encoding: "euc-jp")) + assert_equal(Encoding::EUC_JP, S(src, encoding: "euc-jp").encoding) + + src.force_encoding("euc-jp") + assert_equal(src, S(src, encoding: "utf-8")) + assert_equal(Encoding::UTF_8, S(src, encoding: "utf-8").encoding) end def test_AREF # '[]' |