aboutsummaryrefslogtreecommitdiffstats
path: root/external
diff options
context:
space:
mode:
authorAlexander Schmitz <arschmitz@gmail.com>2015-04-29 10:49:41 -0400
committerAlexander Schmitz <arschmitz@gmail.com>2015-05-01 07:11:35 -0400
commit6a03b0f2ba422ec8edbf642eab692cbd20af2f4d (patch)
treeb2a5aa8acf0cb891edd5d5b5d241f62bce17d2b0 /external
parent8b89f8c59bacb1261639c909ee60fe3b856b36e4 (diff)
downloadjquery-ui-6a03b0f2ba422ec8edbf642eab692cbd20af2f4d.tar.gz
jquery-ui-6a03b0f2ba422ec8edbf642eab692cbd20af2f4d.zip
Build: Update to qunit-assert-classes to V 1.0.2
Closes gh-1547
Diffstat (limited to 'external')
-rw-r--r--external/qunit-assert-classes/qunit-assert-classes.js158
1 files changed, 140 insertions, 18 deletions
diff --git a/external/qunit-assert-classes/qunit-assert-classes.js b/external/qunit-assert-classes/qunit-assert-classes.js
index f61046bc8..93edebf9d 100644
--- a/external/qunit-assert-classes/qunit-assert-classes.js
+++ b/external/qunit-assert-classes/qunit-assert-classes.js
@@ -1,47 +1,169 @@
-( function( QUnit ) {
+( function( factory ) {
+ if ( typeof define === "function" && define.amd ) {
+
+ // AMD. Register as an anonymous module.
+ define( [
+ "qunit"
+ ], factory );
+ } else {
+
+ // Browser globals
+ factory( QUnit );
+ }
+}( function( QUnit ) {
+
function inArray( haystack, needle ) {
for ( var i = 0; i < haystack.length; i++ ) {
- if ( haystack[ i ] === needle ) {
+ if (
+ ( needle instanceof RegExp && needle.test( haystack[ i ] ) )||
+ ( typeof needle === "string" && haystack[ i ] === needle )
+ ) {
return true;
}
}
return false;
}
- function check( element, classes, stateVal, message ) {
- var i, result, classAttribute, elementClassArray,
- classArray = classes.split( " " ),
+
+ function check( element, search ) {
+ var i, classAttribute, elementClassArray,
missing = [],
found = [];
if ( element.jquery && element.length !== 1 ) {
- throw( "Class checks can only be performed on a single element on a collection" );
+ throw new Error( "Class checks can only be performed on a single element on a collection" );
}
+
element = element.jquery ? element[ 0 ] : element;
classAttribute = element.getAttribute( "class" );
- message = message || "Element must " + ( stateVal? "" : "not " ) + "have classes";
+
if ( classAttribute ) {
- elementClassArray = classAttribute.split( " " );
- for( i = 0; i < classArray.length; i++ ) {
- if ( !inArray( elementClassArray, classArray[ i ] ) ) {
- missing.push( classArray[ i ] );
+ elementClassArray = splitClasses( classAttribute );
+ if ( search instanceof RegExp ) {
+ if ( inArray( elementClassArray, search ) ) {
+ found.push( search );
} else {
- found.push( classArray[ i ] );
+ missing.push( search );
+ }
+ } else {
+ for( i = 0; i < search.length; i++ ) {
+ if ( !inArray( elementClassArray, search[ i ] ) ) {
+ missing.push( search[ i ] );
+ } else {
+ found.push( search[ i ] );
+ }
}
}
} else {
- missing = classArray;
+ missing = search;
}
- result = stateVal ? !missing.length : !found.length;
- QUnit.push( result, classes, result ? classes : found.join( " " ), message );
+ return {
+ missing: missing,
+ found: found,
+ element: element,
+ classAttribute: classAttribute
+ };
+ }
+
+ function splitClasses( classes ) {
+ return classes.match( /\S+/g ) || [];
+ }
+
+ function pluralize( message, classes ) {
+ return message + ( classes.length > 1 ? "es" : "" );
}
QUnit.extend( QUnit.assert, {
hasClasses: function( element, classes, message ) {
- check( element, classes, true, message );
+ var classArray = splitClasses( classes ),
+ results = check( element, classArray );
+
+ message = message || pluralize( "Element must have class", classArray );
+
+ this.push( !results.missing.length, results.found.join( " " ), classes, message );
},
lacksClasses: function( element, classes, message ) {
- check( element, classes, false, message );
+ var classArray = splitClasses( classes ),
+ results = check( element, classArray );
+
+ message = message || pluralize( "Element must not have class", classArray );
+
+ this.push( !results.found.length, results.found.join( " " ), classes, message );
+ },
+ hasClassesStrict: function( element, classes, message ) {
+ var result,
+ classArray = splitClasses( classes ),
+ results = check( element, classArray );
+
+ message = message || pluralize( "Element must only have class", classArray );
+
+ result = !results.missing.length && results.element.getAttribute( "class" ) &&
+ splitClasses( results.element.getAttribute( "class" ) ).length ===
+ results.found.length;
+
+ this.push( result, results.found.join( " " ), classes, message );
+ },
+ hasClassRegex: function( element, regex, message ) {
+ var results = check( element, regex );
+
+ message = message || "Element must have class matching " + regex;
+
+ this.push( !!results.found.length, results.found.join( " " ), regex, message );
+ },
+ lacksClassRegex: function( element, regex, message ) {
+ var results = check( element, regex );
+
+ message = message || "Element must not have class matching " + regex;
+
+ this.push( results.missing.length, results.missing.join( " " ), regex, message );
+ },
+ hasClassStart: function( element, partialClass, message ) {
+ var results = check( element, new RegExp( "^" + partialClass ) );
+
+ message = message || "Element must have class starting with " + partialClass;
+
+ this.push( results.found.length, results.found.join( " " ), partialClass, message );
+ },
+ lacksClassStart: function( element, partialClass, message ) {
+ var results = check( element, new RegExp( "^" + partialClass ) );
+
+ message = message || "Element must not have class starting with " + partialClass;
+
+ this.push( results.missing.length, results.missing.join( " " ), partialClass, message );
+ },
+ hasClassPartial: function( element, partialClass, message ) {
+ var results = check( element, new RegExp( partialClass ) );
+
+ message = message || "Element must have class containing '" + partialClass + "'";
+
+ this.push( results.found.length, results.found.join( " " ), partialClass, message );
+ },
+ lacksClassPartial: function( element, partialClass, message ) {
+ var results = check( element, new RegExp( partialClass ) );
+
+ message = message || "Element must not have class containing '" + partialClass + "'";
+
+ this.push( results.missing.length, results.missing.join( " " ), partialClass, message );
+ },
+ lacksAllClasses: function( element, message ) {
+ element = element.jquery ? element[ 0 ] : element;
+
+ var classAttribute = element.getAttribute( "class" ) || "",
+ classes = splitClasses( classAttribute );
+
+ message = message || "Element must not have any classes";
+
+ this.push( !classes.length, !classes.length, true, message );
+ },
+ hasSomeClass: function( element, message ) {
+ element = element.jquery ? element[ 0 ] : element;
+
+ var classAttribute = element.getAttribute( "class" ) || "",
+ classes = splitClasses( classAttribute );
+
+ message = message || "Element must have a class";
+
+ this.push( classes.length, classes.length, true, message );
}
});
-})( QUnit ); \ No newline at end of file
+} ) );