Chromium Code Reviews| Index: test/cctest/test-api.cc |
| diff --git a/test/cctest/test-api.cc b/test/cctest/test-api.cc |
| index 5a9df90e21fc8350c5e1d0dbc7bf5f8e8de9d1f4..71dd18cefe24edb29818558b1e8d99bcae89f35e 100644 |
| --- a/test/cctest/test-api.cc |
| +++ b/test/cctest/test-api.cc |
| @@ -5570,6 +5570,7 @@ THREADED_TEST(StringWrite) { |
| v8::Handle<String> str = v8_str("abcde"); |
| // abc<Icelandic eth><Unicode snowman>. |
| v8::Handle<String> str2 = v8_str("abc\303\260\342\230\203"); |
| + v8::Handle<String> str3 = v8::String::New("abc\0def", 7); |
| const int kStride = 4; // Must match stride in for loops in JS below. |
| CompileRun( |
| "var left = '';" |
| @@ -5780,6 +5781,29 @@ THREADED_TEST(StringWrite) { |
| CHECK_NE(0, strcmp(utf8buf, "abc\303\260\342\230\203")); |
| utf8buf[8] = '\0'; |
| CHECK_EQ(0, strcmp(utf8buf, "abc\303\260\342\230\203")); |
| + |
| + memset(utf8buf, 0x1, sizeof(utf8buf)); |
| + utf8buf[5] = 'X'; // Test that the sixth character is left untouched. |
|
Toon Verwaest
2012/07/23 13:07:21
This comment probably belongs on line 5790.
|
| + len = str->WriteUtf8(utf8buf, sizeof(utf8buf), &charlen, |
| + String::NO_NULL_TERMINATION); |
| + CHECK_EQ(5, len); |
| + CHECK_EQ('X', utf8buf[5]); |
| + CHECK_EQ(5, charlen); |
| + CHECK_EQ(0, strncmp(utf8buf, "abcde", 5)); |
| + utf8buf[5] = '\0'; |
| + CHECK_EQ(0, strcmp(utf8buf, "abcde")); |
|
Toon Verwaest
2012/07/23 13:07:21
Testing with strcmp and strncmp seems superfluous.
|
| + |
| + memset(buf, 0x1, sizeof(buf)); |
| + len = str3->WriteAscii(buf); |
| + CHECK_EQ(7, len); |
| + CHECK_EQ(0, strcmp("abc def", buf)); |
| + |
| + memset(buf, 0x1, sizeof(buf)); |
| + len = str3->WriteAscii(buf, 0, -1, String::PRESERVE_ASCII_NULL); |
| + CHECK_EQ(7, len); |
| + CHECK_EQ(0, strcmp("abc", buf)); |
| + CHECK_EQ(0, buf[3]); |
| + CHECK_EQ(0, strcmp("def", buf + 4)); |
| } |