mediawiki-extensions-Visual.../modules/ve/test/dm/ve.dm.Model.test.js
Timo Tijhof b463c5d377 jshint: Fix trailing comma
Due to the "es5: true" jshint option we enabled, these
warnings were surpressed. I've disabled the option since
we no longer require it. It was enabled in 07c86fc to fix
a bug with jshint. This bug has now been fixed.

Change-Id: I55b7d031eb5581af5f733f050cf2ea98dacb2af6
2013-06-05 13:00:49 +02:00

123 lines
2.3 KiB
JavaScript

/*!
* VisualEditor Model tests.
*
* @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
QUnit.module( 've.dm.Model' );
QUnit.test( 'matchesAttributeSpec', function ( assert ) {
var i, cases = [
{
'spec': true,
'attr': 'foo',
'result': true,
'msg': 'true matches anything'
},
{
'spec': false,
'attr': 'foo',
'result': false,
'msg': 'false matches nothing'
},
{
'spec': 'foo',
'attr': 'foo',
'result': true,
'msg': 'string matches exact value'
},
{
'spec': 'foo',
'attr': 'bar',
'result': false,
'msg': 'string does not match anything else'
},
{
'spec': /^foo/,
'attr': 'foobar',
'result': true,
'msg': 'regex matches'
},
{
'spec': /^foo/,
'attr': 'barfoo',
'result': false,
'msg': 'regex does not match anything else'
},
{
'spec': [ 'foo', /^bar/ ],
'attr': 'foo',
'result': true,
'msg': 'array of string and regex matches string'
},
{
'spec': [ 'foo', /^bar/ ],
'attr': 'barbaz',
'result': true,
'msg': 'array of string and regex matches regex match'
},
{
'spec': {
'blacklist': 'foo'
},
'attr': 'foo',
'result': false,
'msg': 'blacklisted attribute does not match'
},
{
'spec': {
'blacklist': 'foo'
},
'attr': 'bar',
'result': true,
'msg': 'non-blacklisted attribute matches'
},
{
'spec': {
'whitelist': /^foo/,
'blacklist': [ 'foobar', 'foobaz' ]
},
'attr': 'foobar',
'result': false,
'msg': 'blacklist overrides whitelist'
},
{
'spec': {
'whitelist': /^foo/,
'blacklist': [ 'foobar', 'foobaz' ]
},
'attr': 'foobaz',
'result': false,
'msg': 'blacklist overrides whitelist (2)'
},
{
'spec': {
'whitelist': /^foo/,
'blacklist': [ 'foobar', 'foobaz' ]
},
'attr': 'fooquux',
'result': true,
'msg': 'attribute on whitelist and not on blacklist matches'
},
{
'spec': {
'whitelist': /^foo/,
'blacklist': [ 'foobar', 'foobaz' ]
},
'attr': 'bar',
'result': false,
'msg': 'attribute on neither whitelist nor blacklist does not match'
}
];
QUnit.expect( cases.length );
for ( i = 0; i < cases.length; i++ ) {
assert.equal(
ve.dm.Model.matchesAttributeSpec( cases[i].attr, cases[i].spec ),
cases[i].result,
cases[i].msg
);
}
} );