UNPKG

@apache-royale/royale-js

Version:

Apache Royale (formerly FlexJS)

103 lines (82 loc) 3.43 kB
// Copyright 2014 The Closure Library Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS-IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. /** * @fileoverview Unit tests for goog.html.SafeScript and its builders. */ goog.provide('goog.html.safeScriptTest'); goog.require('goog.html.SafeScript'); goog.require('goog.object'); goog.require('goog.string.Const'); goog.require('goog.testing.jsunit'); goog.setTestOnly('goog.html.safeScriptTest'); function testSafeScript() { var script = 'var string = \'hello\';'; var safeScript = goog.html.SafeScript.fromConstant(goog.string.Const.from(script)); var extracted = goog.html.SafeScript.unwrap(safeScript); assertEquals(script, extracted); assertEquals(script, safeScript.getTypedStringValue()); assertEquals('SafeScript{' + script + '}', String(safeScript)); // Interface marker is present. assertTrue(safeScript.implementsGoogStringTypedString); } /** @suppress {checkTypes} */ function testUnwrap() { var privateFieldName = 'privateDoNotAccessOrElseSafeScriptWrappedValue_'; var markerFieldName = 'SAFE_SCRIPT_TYPE_MARKER_GOOG_HTML_SECURITY_PRIVATE_'; var propNames = goog.object.getKeys( goog.html.SafeScript.fromConstant(goog.string.Const.from(''))); assertContains(privateFieldName, propNames); assertContains(markerFieldName, propNames); var evil = {}; evil[privateFieldName] = 'var string = \'evil\';'; evil[markerFieldName] = {}; var exception = assertThrows(function() { goog.html.SafeScript.unwrap(evil); }); assertContains('expected object of type SafeScript', exception.message); } function testFromConstant_allowsEmptyString() { assertEquals( goog.html.SafeScript.EMPTY, goog.html.SafeScript.fromConstant(goog.string.Const.from(''))); } function testEmpty() { assertEquals('', goog.html.SafeScript.unwrap(goog.html.SafeScript.EMPTY)); } function testFromConstantAndArgs() { var script = goog.html.SafeScript.fromConstantAndArgs( goog.string.Const.from( 'function(str, num, nul, json) { foo(str, num, nul, json); }'), 'hello world', 42, null, {'foo': 'bar'}); assertEquals( '(function(str, num, nul, json) { foo(str, num, nul, json); })' + '("hello world", 42, null, {"foo":"bar"});', goog.html.SafeScript.unwrap(script)); } function testFromConstantAndArgs_escaping() { var script = goog.html.SafeScript.fromConstantAndArgs( goog.string.Const.from('function(str) { alert(str); }'), '</script</script'); assertEquals( '(function(str) { alert(str); })' + '("\\x3c/script\\x3c/script");', goog.html.SafeScript.unwrap(script)); } function testFromConstantAndArgs_eval() { var script = goog.html.SafeScript.fromConstantAndArgs( goog.string.Const.from('function(arg1, arg2) { return arg1 * arg2; }'), 21, 2); var result = eval(goog.html.SafeScript.unwrap(script)); assertEquals(42, result); }