Skip to content
Browse files

Add QUnit testing during Grunt build

- Updated QUnit to 1.12
- Use root copies of toaster for the tests page
- Remove toastr copies under test
- Use the bower version of jQuery
  • Loading branch information...
1 parent e5dee6b commit 00f575abe3249e89ab29f40310ac09fb83ea34b8 @nschonni nschonni committed Sep 5, 2013
Showing with 1,646 additions and 1,338 deletions.
  1. +6 −2 Gruntfile.js
  2. +2 −1 package.json
  3. +45 −26 tests/qunit/qunit.css
  4. +1,589 −829 tests/qunit/qunit.js
  5. +3 −4 tests/toastr-tests.html
  6. +0 −174 tests/toastr.css
  7. +0 −301 tests/toastr.js
  8. +1 −1 tests/unit/toastr-tests.js
View
8 Gruntfile.js
@@ -22,11 +22,15 @@ module.exports = function(grunt) {
"toastr.min.js": "toastr.js"
}
}
- }
+ },
+ qunit: {
+ all: ['tests/toastr-tests.html']
+ }
});
grunt.loadNpmTasks('grunt-contrib-less');
grunt.loadNpmTasks('grunt-contrib-uglify');
+ grunt.loadNpmTasks('grunt-contrib-qunit');
- grunt.registerTask('default', ['less', 'uglify']);
+ grunt.registerTask('default', ['less', 'qunit', 'uglify']);
};
View
3 package.json
@@ -29,6 +29,7 @@
],
"devDependencies": {
"grunt-contrib-uglify": "~0.2.2",
- "grunt-contrib-less": "~0.6.4"
+ "grunt-contrib-less": "~0.6.4",
+ "grunt-contrib-qunit": "~0.2.2"
}
}
View
71 tests/qunit/qunit.css
@@ -1,11 +1,11 @@
/**
- * QUnit - A JavaScript Unit Testing Framework
+ * QUnit v1.12.0 - A JavaScript Unit Testing Framework
*
- * http://docs.jquery.com/QUnit
+ * http://qunitjs.com
*
- * Copyright (c) 2011 John Resig, Jörn Zaefferer
- * Dual licensed under the MIT (MIT-LICENSE.txt)
- * or GPL (GPL-LICENSE.txt) licenses.
+ * Copyright 2012 jQuery Foundation and other contributors
+ * Released under the MIT license.
+ * http://jquery.org/license
*/
/** Font Family and Sizes */
@@ -20,7 +20,7 @@
/** Resets */
-#qunit-tests, #qunit-tests ol, #qunit-header, #qunit-banner, #qunit-userAgent, #qunit-testresult {
+#qunit-tests, #qunit-header, #qunit-banner, #qunit-userAgent, #qunit-testresult, #qunit-modulefilter {
margin: 0;
padding: 0;
}
@@ -38,10 +38,10 @@
line-height: 1em;
font-weight: normal;
- border-radius: 15px 15px 0 0;
- -moz-border-radius: 15px 15px 0 0;
- -webkit-border-top-right-radius: 15px;
- -webkit-border-top-left-radius: 15px;
+ border-radius: 5px 5px 0 0;
+ -moz-border-radius: 5px 5px 0 0;
+ -webkit-border-top-right-radius: 5px;
+ -webkit-border-top-left-radius: 5px;
}
#qunit-header a {
@@ -54,6 +54,11 @@
color: #fff;
}
+#qunit-testrunner-toolbar label {
+ display: inline-block;
+ padding: 0 .5em 0 .1em;
+}
+
#qunit-banner {
height: 5px;
}
@@ -62,6 +67,7 @@
padding: 0.5em 0 0.5em 2em;
color: #5E740B;
background-color: #eee;
+ overflow: hidden;
}
#qunit-userAgent {
@@ -71,6 +77,9 @@
text-shadow: rgba(0, 0, 0, 0.5) 2px 2px 1px;
}
+#qunit-modulefilter-container {
+ float: right;
+}
/** Tests: Pass/Fail */
@@ -102,19 +111,24 @@
color: #000;
}
-#qunit-tests ol {
+#qunit-tests li .runtime {
+ float: right;
+ font-size: smaller;
+}
+
+.qunit-assert-list {
margin-top: 0.5em;
padding: 0.5em;
background-color: #fff;
- border-radius: 15px;
- -moz-border-radius: 15px;
- -webkit-border-radius: 15px;
+ border-radius: 5px;
+ -moz-border-radius: 5px;
+ -webkit-border-radius: 5px;
+}
- box-shadow: inset 0px 2px 13px #999;
- -moz-box-shadow: inset 0px 2px 13px #999;
- -webkit-box-shadow: inset 0px 2px 13px #999;
+.qunit-collapsed {
+ display: none;
}
#qunit-tests table {
@@ -157,8 +171,7 @@
#qunit-tests b.failed { color: #710909; }
#qunit-tests li li {
- margin: 0.5em;
- padding: 0.4em 0.5em 0.4em 0.5em;
+ padding: 5px;
background-color: #fff;
border-bottom: none;
list-style-position: inside;
@@ -167,9 +180,9 @@
/*** Passing Styles */
#qunit-tests li li.pass {
- color: #5E740B;
+ color: #3c510c;
background-color: #fff;
- border-left: 26px solid #C6E746;
+ border-left: 10px solid #C6E746;
}
#qunit-tests .pass { color: #528CE0; background-color: #D2E0E6; }
@@ -185,14 +198,15 @@
#qunit-tests li li.fail {
color: #710909;
background-color: #fff;
- border-left: 26px solid #EE5757;
+ border-left: 10px solid #EE5757;
+ white-space: pre;
}
#qunit-tests > li:last-child {
- border-radius: 0 0 15px 15px;
- -moz-border-radius: 0 0 15px 15px;
- -webkit-border-bottom-right-radius: 15px;
- -webkit-border-bottom-left-radius: 15px;
+ border-radius: 0 0 5px 5px;
+ -moz-border-radius: 0 0 5px 5px;
+ -webkit-border-bottom-right-radius: 5px;
+ -webkit-border-bottom-left-radius: 5px;
}
#qunit-tests .fail { color: #000000; background-color: #EE5757; }
@@ -215,11 +229,16 @@
border-bottom: 1px solid white;
}
+#qunit-testresult .module-name {
+ font-weight: bold;
+}
/** Fixture */
#qunit-fixture {
position: absolute;
top: -10000px;
left: -10000px;
+ width: 1000px;
+ height: 1000px;
}
View
2,418 tests/qunit/qunit.js
1,589 additions, 829 deletions not shown because the diff is too large. Please use a local Git client to view these changes.
View
7 tests/toastr-tests.html
@@ -2,7 +2,7 @@
<html>
<head>
<title>toastr QUnit Tests</title>
- <link href="toastr.css" rel="stylesheet" type="text/css" />
+ <link href="../toastr.css" rel="stylesheet" type="text/css" />
<link href="qunit/qunit.css" rel="stylesheet" type="text/css" />
</head>
<body>
@@ -13,9 +13,8 @@ <h2 id="qunit-banner"></h2>
<h2 id="qunit-userAgent"></h2>
<ol id="qunit-tests"></ol>
<div id="qunit-fixture">test markup, will be hidden</div>
- <!--<script src="../Scripts/jquery-1.7.2.js" type="text/javascript"></script>-->
- <script src="http://code.jquery.com/jquery.js" type="text/javascript"></script>
- <script src="toastr.js" type="text/javascript"></script>
+ <script src="../bower_components/jquery/jquery.js" type="text/javascript"></script>
+ <script src="../toastr.js" type="text/javascript"></script>
<script src="qunit/qunit.js" type="text/javascript"></script>
<script src="unit/toastr-tests.js" type="text/javascript"></script>
</body>
View
174 tests/toastr.css
@@ -1,174 +0,0 @@
-.toast-title {
- font-weight: bold;
-}
-.toast-message {
- -ms-word-wrap: break-word;
- word-wrap: break-word;
-}
-.toast-message a,
-.toast-message label {
- color: #ffffff;
-}
-.toast-message a:hover {
- color: #cccccc;
- text-decoration: none;
-}
-/*
- https://github.com/twitter/bootstrap/blob/master/less/close.less
- https://github.com/twitter/bootstrap/blob/master/less/alerts.less
-*/
-.toast-close-button {
- position: relative;
- right: -0.3em;
- top: -0.3em;
- float: right;
- font-size: 20px;
- font-weight: bold;
- color: #ffffff;
- -webkit-text-shadow: 0 1px 0 #ffffff;
- text-shadow: 0 1px 0 #ffffff;
- opacity: 0.8;
- -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
- filter: alpha(opacity=80);
-}
-.toast-close-button:hover,
-.toast-close-button:focus {
- color: #000000;
- text-decoration: none;
- cursor: pointer;
- opacity: 0.4;
- -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40);
- filter: alpha(opacity=40);
-}
-/*Additional properties for button version
- iOS requires the button element instead of an anchor tag.
- If you want the anchor version, it requires `href="#"`.*/
-button.toast-close-button {
- padding: 0;
- cursor: pointer;
- background: transparent;
- border: 0;
- -webkit-appearance: none;
-}
-.toast-top-full-width {
- top: 0;
- right: 0;
- width: 100%;
-}
-.toast-bottom-full-width {
- bottom: 0;
- right: 0;
- width: 100%;
-}
-.toast-top-left {
- top: 12px;
- left: 12px;
-}
-.toast-top-right {
- top: 12px;
- right: 12px;
-}
-.toast-bottom-right {
- right: 12px;
- bottom: 12px;
-}
-.toast-bottom-left {
- bottom: 12px;
- left: 12px;
-}
-#toast-container {
- position: fixed;
- z-index: 999999;
- /*overrides*/
-
-}
-#toast-container * {
- -moz-box-sizing: border-box;
- -webkit-box-sizing: border-box;
- box-sizing: border-box;
-}
-#toast-container > div {
- margin: 0 0 6px;
- padding: 15px 15px 15px 50px;
- width: 300px;
- -moz-border-radius: 3px 3px 3px 3px;
- -webkit-border-radius: 3px 3px 3px 3px;
- border-radius: 3px 3px 3px 3px;
- background-position: 15px center;
- background-repeat: no-repeat;
- -moz-box-shadow: 0 0 12px #999999;
- -webkit-box-shadow: 0 0 12px #999999;
- box-shadow: 0 0 12px #999999;
- color: #ffffff;
- opacity: 0.8;
- -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
- filter: alpha(opacity=80);
-}
-#toast-container > :hover {
- -moz-box-shadow: 0 0 12px #000000;
- -webkit-box-shadow: 0 0 12px #000000;
- box-shadow: 0 0 12px #000000;
- opacity: 1;
- -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
- filter: alpha(opacity=100);
- cursor: pointer;
-}
-#toast-container > .toast-info {
- background-image: url("") !important;
-}
-#toast-container > .toast-error {
- background-image: url("") !important;
-}
-#toast-container > .toast-success {
- background-image: url("") !important;
-}
-#toast-container > .toast-warning {
- background-image: url("") !important;
-}
-#toast-container.toast-top-full-width > div,
-#toast-container.toast-bottom-full-width > div {
- width: 96%;
- margin: auto;
-}
-.toast {
- background-color: #030303;
-}
-.toast-success {
- background-color: #51a351;
-}
-.toast-error {
- background-color: #bd362f;
-}
-.toast-info {
- background-color: #2f96b4;
-}
-.toast-warning {
- background-color: #f89406;
-}
-/*Responsive Design*/
-@media all and (max-width: 240px) {
- #toast-container > div {
- padding: 8px 8px 8px 50px;
- width: 11em;
- }
- #toast-container .toast-close-button {
- right: -0.2em;
- top: -0.2em;
- }
-}
-@media all and (min-width: 241px) and (max-width: 480px) {
- #toast-container > div {
- padding: 8px 8px 8px 50px;
- width: 18em;
- }
- #toast-container .toast-close-button {
- right: -0.2em;
- top: -0.2em;
- }
-}
-@media all and (min-width: 481px) and (max-width: 768px) {
- #toast-container > div {
- padding: 15px 15px 15px 50px;
- width: 25em;
- }
-}
View
301 tests/toastr.js
@@ -1,301 +0,0 @@
-/*
- * Copyright 2012 John Papa and Hans Fjällemark.
- * All Rights Reserved.
- * Use, reproduction, distribution, and modification of this code is subject to the terms and
- * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php
- *
- * Author: John Papa and Hans Fjällemark
- * Project: https://github.com/CodeSeven/toastr
- */
-; (function (define) {
- define(['jquery'], function ($) {
- return (function () {
- var version = '2.0.0rc1';
- var $container;
- var listener;
- var toastId = 0;
- var toastType = {
- error: 'error',
- info: 'info',
- success: 'success',
- warning: 'warning'
- };
-
- var toastr = {
- clear: clear,
- error: error,
- getContainer: getContainer,
- info: info,
- options: {},
- subscribe: subscribe,
- success: success,
- version: version,
- warning: warning
- };
-
- return toastr;
-
- //#region Accessible Methods
- function error(message, title, optionsOverride) {
- return notify({
- type: toastType.error,
- iconClass: getOptions().iconClasses.error,
- message: message,
- optionsOverride: optionsOverride,
- title: title
- });
- }
-
- function info(message, title, optionsOverride) {
- return notify({
- type: toastType.info,
- iconClass: getOptions().iconClasses.info,
- message: message,
- optionsOverride: optionsOverride,
- title: title
- });
- }
-
- function subscribe(callback) {
- listener = callback;
- }
-
- function success(message, title, optionsOverride) {
- return notify({
- type: toastType.success,
- iconClass: getOptions().iconClasses.success,
- message: message,
- optionsOverride: optionsOverride,
- title: title
- });
- }
-
- function warning(message, title, optionsOverride) {
- return notify({
- type: toastType.warning,
- iconClass: getOptions().iconClasses.warning,
- message: message,
- optionsOverride: optionsOverride,
- title: title
- });
- }
-
- function clear($toastElement) {
- var options = getOptions();
- if (!$container) { getContainer(options); }
- if ($toastElement && $(':focus', $toastElement).length === 0) {
- $toastElement[options.hideMethod]({
- duration: options.hideDuration,
- easing: options.hideEasing,
- complete: function () { removeToast($toastElement); }
- });
- return;
- }
- if ($container.children().length) {
- $container[options.hideMethod]({
- duration: options.hideDuration,
- easing: options.hideEasing,
- complete: function () { $container.remove(); }
- });
- }
- }
- //#endregion
-
- //#region Internal Methods
-
- function getDefaults() {
- return {
- tapToDismiss: true,
- toastClass: 'toast',
- containerId: 'toast-container',
- debug: false,
-
- showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery
- showDuration: 300,
- showEasing: 'swing', //swing and linear are built into jQuery
- onShown: undefined,
- hideMethod: 'fadeOut',
- hideDuration: 1000,
- hideEasing: 'swing',
- onHidden: undefined,
-
- extendedTimeOut: 1000,
- iconClasses: {
- error: 'toast-error',
- info: 'toast-info',
- success: 'toast-success',
- warning: 'toast-warning'
- },
- iconClass: 'toast-info',
- positionClass: 'toast-top-right',
- timeOut: 5000, // Set timeOut and extendedTimeout to 0 to make it sticky
- titleClass: 'toast-title',
- messageClass: 'toast-message',
- target: 'body',
- closeHtml: '<button>&times;</button>',
- newestOnTop: true
- };
- }
-
- function publish(args) {
- if (!listener) {
- return;
- }
- listener(args);
- }
-
- function notify(map) {
- var
- options = getOptions(),
- iconClass = map.iconClass || options.iconClass;
-
- if (typeof (map.optionsOverride) !== 'undefined') {
- options = $.extend(options, map.optionsOverride);
- iconClass = map.optionsOverride.iconClass || iconClass;
- }
-
- toastId++;
-
- $container = getContainer(options);
- var
- intervalId = null,
- $toastElement = $('<div/>'),
- $titleElement = $('<div/>'),
- $messageElement = $('<div/>'),
- $closeElement = $(options.closeHtml),
- response = {
- toastId: toastId,
- state: 'visible',
- startTime: new Date(),
- options: options,
- map: map
- };
-
- if (map.iconClass) {
- $toastElement.addClass(options.toastClass).addClass(iconClass);
- }
-
- if (map.title) {
- $titleElement.append(map.title).addClass(options.titleClass);
- $toastElement.append($titleElement);
- }
-
- if (map.message) {
- $messageElement.append(map.message).addClass(options.messageClass);
- $toastElement.append($messageElement);
- }
-
- if (options.closeButton) {
- $closeElement.addClass('toast-close-button');
- $toastElement.prepend($closeElement);
- }
-
- $toastElement.hide();
- if (options.newestOnTop) {
- $container.prepend($toastElement);
- } else {
- $container.append($toastElement);
- }
-
-
- $toastElement[options.showMethod](
- { duration: options.showDuration, easing: options.showEasing, complete: options.onShown }
- );
- if (options.timeOut > 0) {
- intervalId = setTimeout(hideToast, options.timeOut);
- }
-
- $toastElement.hover(stickAround, delayedhideToast);
- if (!options.onclick && options.tapToDismiss) {
- $toastElement.click(hideToast);
- }
- if(options.closeButton && $closeElement){
- $closeElement.click(function(){ hideToast(true); });
- }
-
- if (options.onclick) {
- $toastElement.click(function () {
- options.onclick();
- hideToast();
- });
- }
-
- publish(response);
-
- if (options.debug && console) {
- console.log(response);
- }
-
- return $toastElement;
-
- function hideToast(override) {
- if ($(':focus', $toastElement).length && !override) {
- return;
- }
- return $toastElement[options.hideMethod]({
- duration: options.hideDuration,
- easing: options.hideEasing,
- complete: function () {
- removeToast($toastElement);
- if (options.onHidden) {
- options.onHidden();
- }
- response.state = 'hidden';
- response.endTime = new Date(),
- publish(response);
- }
- });
- }
-
- function delayedhideToast() {
- if (options.timeOut > 0 || options.extendedTimeOut > 0) {
- intervalId = setTimeout(hideToast, options.extendedTimeOut);
- }
- }
-
- function stickAround() {
- clearTimeout(intervalId);
- $toastElement.stop(true, true)[options.showMethod](
- { duration: options.showDuration, easing: options.showEasing }
- );
- }
- }
- function getContainer(options) {
- if (!options) { options = getOptions(); }
- $container = $('#' + options.containerId);
- if ($container.length) {
- return $container;
- }
- $container = $('<div/>')
- .attr('id', options.containerId)
- .addClass(options.positionClass);
- $container.appendTo($(options.target));
- return $container;
- }
-
- function getOptions() {
- return $.extend({}, getDefaults(), toastr.options);
- }
-
- function removeToast($toastElement) {
- if (!$container) { $container = getContainer(); }
- if ($toastElement.is(':visible')) {
- return;
- }
- $toastElement.remove();
- $toastElement = null;
- if ($container.children().length === 0) {
- $container.remove();
- }
- }
- //#endregion
-
- })();
- });
-}(typeof define === 'function' && define.amd ? define : function (deps, factory) {
- if (typeof module !== 'undefined' && module.exports) { //Node
- module.exports = factory(require(deps[0]));
- } else {
- window['toastr'] = factory(window['jQuery']);
- }
-}));
View
2 tests/unit/toastr-tests.js
@@ -1,4 +1,4 @@
-/// <reference path="../../toastr.js" />
+/// <reference path="../../../toastr.js" />
/// <reference path="../qunit/qunit.js" />
(function () {
var iconClasses = {

0 comments on commit 00f575a

Please sign in to comment.
Something went wrong with that request. Please try again.