Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(126)

Unified Diff: LayoutTests/fast/js/webidl-type-mapping.html

Issue 313993002: Bindings: Add ScalarValueString support (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Review feedback Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: LayoutTests/fast/js/webidl-type-mapping.html
diff --git a/LayoutTests/fast/js/webidl-type-mapping.html b/LayoutTests/fast/js/webidl-type-mapping.html
index 44c2bf0cb91c234248218b41e86c17f09fc8634f..f04cf2ee598ae104d93aa68a2c5ce7167534f38e 100644
--- a/LayoutTests/fast/js/webidl-type-mapping.html
+++ b/LayoutTests/fast/js/webidl-type-mapping.html
@@ -606,4 +606,32 @@ shouldBeUndefined("converter.testByteStringTreatReturnedNullStringAsUndefinedAtt
shouldBeNull("converter.getTestByteStringTreatReturnedNullStringAsNullMethod()");
shouldBeUndefined("converter.getTestByteStringTreatReturnedNullStringAsUndefinedMethod()");
+evalAndLog("converter.testScalarValueString = '!@#123ABCabc\\x00\\x80\\xFF\\r\\n\\t'");
+shouldBeEqualToString("converter.testScalarValueString", "!@#123ABCabc\x00\x80\xFF\r\n\t");
+evalAndLog("converter.testScalarValueString = '\\u0100'");
+shouldBeEqualToString("converter.testScalarValueString", "\u0100");
+shouldThrow("converter.testScalarValueString = {toString: function() { throw Error(); }}");
+shouldBeEqualToString("converter.testScalarValueString", "\u0100");
+[{input: "\uD800", expected: "\uFFFD"},
+ {input: "\uDC00", expected: "\uFFFD"},
+ {input: "\uD800\u0000", expected: "\uFFFD\u0000"},
+ {input: "\uDC00\u0000", expected: "\uFFFD\u0000"},
+ {input: "\uDC00\uD800", expected: "\uFFFD\uFFFD"},
+ {input: "\uD834\uDD1E", expected: "\uD834\uDD1E"},
+].forEach(function(test) {
+ evalAndLog("converter.testScalarValueString = " + JSON.stringify(test.input));
+ shouldBeEqualToString("converter.testScalarValueString", test.expected);
+});
+["true", "123", "null", "undefined"].forEach(function(value) {
+ evalAndLog("converter.testScalarValueString = " + value);
+ shouldBeEqualToString("converter.testScalarValueString", value);
+});
+shouldNotThrow("converter.setTestScalarValueString('abc')");
+shouldNotThrow("converter.setTestScalarValueStringDefaultNull('abc')");
+shouldNotThrow("converter.setTestScalarValueString('\\u0100')");
+shouldNotThrow("converter.setTestScalarValueStringDefaultNull('\\u0100')");
+shouldThrow("converter.setTestScalarValueString()");
+shouldNotThrow("converter.setTestScalarValueStringDefaultNull()");
+shouldBeEqualToString("converter.testScalarValueString", "");
+
</script>

Powered by Google App Engine
This is Rietveld 408576698