123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305 |
- /*
- * JavaScript Templates Test
- * https://github.com/blueimp/JavaScript-Templates
- *
- * Copyright 2011, Sebastian Tschan
- * https://blueimp.net
- *
- * Licensed under the MIT license:
- * https://opensource.org/licenses/MIT
- */
- /* global beforeEach, afterEach, describe, it */
- ;(function (context, expect, tmpl) {
- 'use strict'
- if (context.require === undefined) {
- // Override the template loading method:
- tmpl.load = function (id) {
- switch (id) {
- case 'template':
- return '{%=o.value%}'
- }
- }
- }
- var data
- beforeEach(function () {
- // Initialize the sample data:
- data = {
- value: 'value',
- nullValue: null,
- falseValue: false,
- zeroValue: 0,
- special: '<>&"\'\x00',
- list: [1, 2, 3, 4, 5],
- func: function () {
- return this.value
- },
- deep: {
- value: 'value'
- }
- }
- })
- afterEach(function () {
- // Purge the template cache:
- tmpl.cache = {}
- })
- describe('Template loading', function () {
- it('String template', function () {
- expect(
- tmpl('{%=o.value%}', data)
- ).to.equal(
- 'value'
- )
- })
- it('Load template by id', function () {
- expect(
- tmpl('template', data)
- ).to.equal(
- 'value'
- )
- })
- it('Retun function when called without data parameter', function () {
- expect(
- tmpl('{%=o.value%}')(data)
- ).to.equal(
- 'value'
- )
- })
- it('Cache templates loaded by id', function () {
- tmpl('template')
- expect(
- tmpl.cache.template
- ).to.be.a('function')
- })
- })
- describe('Interpolation', function () {
- it('Escape HTML special characters with {%=o.prop%}', function () {
- expect(
- tmpl('{%=o.special%}', data)
- ).to.equal(
- '<>&"''
- )
- })
- it('Allow HTML special characters with {%#o.prop%}', function () {
- expect(
- tmpl('{%#o.special%}', data)
- ).to.equal(
- '<>&"\'\x00'
- )
- })
- it('Function call', function () {
- expect(
- tmpl('{%=o.func()%}', data)
- ).to.equal(
- 'value'
- )
- })
- it('Dot notation', function () {
- expect(
- tmpl('{%=o.deep.value%}', data)
- ).to.equal(
- 'value'
- )
- })
- it('Handle single quotes', function () {
- expect(
- tmpl('\'single quotes\'{%=": \'"%}', data)
- ).to.equal(
- "'single quotes': '"
- )
- })
- it('Handle double quotes', function () {
- expect(
- tmpl('"double quotes"{%=": \\""%}', data)
- ).to.equal(
- '"double quotes": "'
- )
- })
- it('Handle backslashes', function () {
- expect(
- tmpl('\\backslashes\\{%=": \\\\"%}', data)
- ).to.equal(
- '\\backslashes\\: \\'
- )
- })
- it('Interpolate escaped falsy values except undefined or null', function () {
- expect(
- tmpl(
- '{%=o.undefinedValue%}' +
- '{%=o.nullValue%}' +
- '{%=o.falseValue%}' +
- '{%=o.zeroValue%}',
- data
- )
- ).to.equal(
- 'false0'
- )
- })
- it('Interpolate unescaped falsy values except undefined or null', function () {
- expect(
- tmpl(
- '{%#o.undefinedValue%}' +
- '{%#o.nullValue%}' +
- '{%#o.falseValue%}' +
- '{%#o.zeroValue%}',
- data
- )
- ).to.equal(
- 'false0'
- )
- })
- it('Preserve whitespace', function () {
- expect(
- tmpl(
- '\n\r\t{%=o.value%} \n\r\t{%=o.value%} ',
- data
- )
- ).to.equal(
- '\n\r\tvalue \n\r\tvalue '
- )
- })
- })
- describe('Evaluation', function () {
- it('Escape HTML special characters with print(data)', function () {
- expect(
- tmpl('{% print(o.special); %}', data)
- ).to.equal(
- '<>&"''
- )
- })
- it('Allow HTML special characters with print(data, true)', function () {
- expect(
- tmpl('{% print(o.special, true); %}', data)
- ).to.equal(
- '<>&"\'\x00'
- )
- })
- it('Print out escaped falsy values except undefined or null', function () {
- expect(
- tmpl(
- '{% print(o.undefinedValue); %}' +
- '{% print(o.nullValue); %}' +
- '{% print(o.falseValue); %}' +
- '{% print(o.zeroValue); %}',
- data
- )
- ).to.equal(
- 'false0'
- )
- })
- it('Print out unescaped falsy values except undefined or null', function () {
- expect(
- tmpl(
- '{% print(o.undefinedValue, true); %}' +
- '{% print(o.nullValue, true); %}' +
- '{% print(o.falseValue, true); %}' +
- '{% print(o.zeroValue, true); %}',
- data
- )
- ).to.equal(
- 'false0'
- )
- })
- it('Include template', function () {
- expect(
- tmpl('{% include("template", {value: "value"}); %}', data)
- ).to.equal(
- 'value'
- )
- })
- it('If condition', function () {
- expect(
- tmpl('{% if (o.value) { %}true{% } else { %}false{% } %}', data)
- ).to.equal(
- 'true'
- )
- })
- it('Else condition', function () {
- expect(
- tmpl(
- '{% if (o.undefinedValue) { %}false{% } else { %}true{% } %}',
- data
- )
- ).to.equal(
- 'true'
- )
- })
- it('For loop', function () {
- expect(
- tmpl(
- '{% for (var i=0; i<o.list.length; i++) { %}' +
- '{%=o.list[i]%}{% } %}',
- data
- )
- ).to.equal(
- '12345'
- )
- })
- it('For loop print call', function () {
- expect(
- tmpl(
- '{% for (var i=0; i<o.list.length; i++) {' +
- 'print(o.list[i]);} %}',
- data
- )
- ).to.equal(
- '12345'
- )
- })
- it('For loop include template', function () {
- expect(
- tmpl(
- '{% for (var i=0; i<o.list.length; i++) {' +
- 'include("template", {value: o.list[i]});} %}',
- data
- ).replace(/[\r\n]/g, '')
- ).to.equal(
- '12345'
- )
- })
- it('Modulo operator', function () {
- expect(
- tmpl(
- '{% if (o.list.length % 5 === 0) { %}5 list items{% } %}',
- data
- ).replace(/[\r\n]/g, '')
- ).to.equal(
- '5 list items'
- )
- })
- })
- }(
- this,
- (this.chai || require('chai')).expect,
- this.tmpl || require('../js/tmpl')
- ))
|