mirror of
https://github.com/mdbootstrap/mdb-ui-kit.git
synced 2024-11-29 04:54:12 +03:00
Wait for page load during test
This commit is contained in:
parent
b76a53a1af
commit
058cd82df0
101
meteor/test.js
101
meteor/test.js
|
@ -44,60 +44,63 @@ var packageName; // there seems to be no official way of finding out the name o
|
||||||
|
|
||||||
var plugins = ['affix', 'alert', 'button', 'carousel', 'collapse', 'dropdown', 'modal', 'popover', 'scrollspy', 'tab', 'tooltip'];
|
var plugins = ['affix', 'alert', 'button', 'carousel', 'collapse', 'dropdown', 'modal', 'popover', 'scrollspy', 'tab', 'tooltip'];
|
||||||
|
|
||||||
// test plugins
|
document.addEventListener('DOMContentLoaded', function() {
|
||||||
plugins.forEach(function (plugin) {
|
// test plugins
|
||||||
Tinytest.add('Plugin - ' + plugin, function (test) {
|
plugins.forEach(function (plugin) {
|
||||||
test.instanceOf($(document.body)[plugin], Function, 'instantiated correctly');
|
Tinytest.add('Plugin - ' + plugin, function (test) {
|
||||||
});
|
test.instanceOf($(document.body)[plugin], Function, 'instantiated correctly');
|
||||||
});
|
});
|
||||||
|
|
||||||
// visual check
|
|
||||||
plugins.forEach(function (plugin) {
|
|
||||||
|
|
||||||
Tinytest.addAsync('Visual check - ' + plugin, function (test, done) {
|
|
||||||
var bootstrapDropZone = document.createElement('div');
|
|
||||||
document.body.appendChild(bootstrapDropZone);
|
|
||||||
|
|
||||||
|
|
||||||
HTTP.get('http://rawgit.com/twbs/bootstrap/master/js/tests/visual/' + plugin + '.html', function callback(error, result) {
|
|
||||||
if (error) {
|
|
||||||
test.fail('Error getting the test file. Do we have an Internet connection to rawgit.com?');
|
|
||||||
} else {
|
|
||||||
// [^] matches across newlines. Stay within the container div, or else the fragment will attempt to load resources on its own.
|
|
||||||
bootstrapDropZone.innerHTML = result.content.match(/<div[^]+<\/div>/);
|
|
||||||
test.ok({message: 'Test passed if the display looks OK *and* clicking dropdowns/popovers/tooltips works.'});
|
|
||||||
}
|
|
||||||
|
|
||||||
done();
|
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
// visual check
|
||||||
|
plugins.forEach(function (plugin) {
|
||||||
|
|
||||||
});
|
Tinytest.addAsync('Visual check - ' + plugin, function (test, done) {
|
||||||
|
var bootstrapDropZone = document.createElement('div');
|
||||||
|
document.body.appendChild(bootstrapDropZone);
|
||||||
|
|
||||||
|
|
||||||
Tinytest.addAsync('Visual check - Material Design', function (test, done) {
|
HTTP.get('http://rawgit.com/twbs/bootstrap/master/js/tests/visual/' + plugin + '.html', function callback(error, result) {
|
||||||
var bootstrapDropZone = document.createElement('div');
|
if (error) {
|
||||||
document.body.appendChild(bootstrapDropZone);
|
test.fail('Error getting the test file. Do we have an Internet connection to rawgit.com?');
|
||||||
|
} else {
|
||||||
|
// [^] matches across newlines. Stay within the container div, or else the fragment will attempt to load resources on its own.
|
||||||
|
bootstrapDropZone.innerHTML = result.content.match(/<div[^]+<\/div>/);
|
||||||
|
test.ok({message: 'Test passed if the display looks OK *and* clicking dropdowns/popovers/tooltips works.'});
|
||||||
|
}
|
||||||
|
|
||||||
HTTP.get('http://rawgit.com/FezVrasta/bootstrap-material-design/master/bootstrap-elements.html', function callback(error, result) {
|
done();
|
||||||
if (error) {
|
});
|
||||||
test.fail('Error getting the FezVrasta test file. Do we have an Internet connection to rawgit.com?');
|
|
||||||
} else {
|
|
||||||
// [^] matches across newlines. Stay within the container div, or else the fragment will attempt to load resources on its own.
|
|
||||||
bootstrapDropZone.innerHTML = result.content.match(/<meta name="viewport"[^]+<script src=/);
|
|
||||||
test.ok({message: 'Test passed if the display looks OK *and* clicking dropdowns/popovers/tooltips works.'});
|
|
||||||
// only does anything after loading the 'dropdown' plugin test
|
|
||||||
$('[data-toggle="dropdown"]').dropdown();
|
|
||||||
// only does anything after loading the 'popover' plugin test
|
|
||||||
$('[data-toggle="popover"]').popover();
|
|
||||||
// only does anything after loading the 'tooltip' plugin test
|
|
||||||
$('[data-toggle="tooltip"]').tooltip();
|
|
||||||
// don't initialize the modals because that messes up the Tinytest runner HTML
|
|
||||||
$.material.init();
|
|
||||||
}
|
|
||||||
|
|
||||||
done();
|
});
|
||||||
});
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
Tinytest.addAsync('Visual check - Material Design', function (test, done) {
|
||||||
|
var bootstrapDropZone = document.createElement('div');
|
||||||
|
document.body.appendChild(bootstrapDropZone);
|
||||||
|
|
||||||
|
HTTP.get('http://rawgit.com/FezVrasta/bootstrap-material-design/master/bootstrap-elements.html', function callback(error, result) {
|
||||||
|
if (error) {
|
||||||
|
test.fail('Error getting the FezVrasta test file. Do we have an Internet connection to rawgit.com?');
|
||||||
|
} else {
|
||||||
|
// [^] matches across newlines. Stay within the container div, or else the fragment will attempt to load resources on its own.
|
||||||
|
bootstrapDropZone.innerHTML = result.content.match(/<meta name="viewport"[^]+<script src=/);
|
||||||
|
test.ok({message: 'Test passed if the display looks OK *and* clicking dropdowns/popovers/tooltips works.'});
|
||||||
|
// only does anything after loading the 'dropdown' plugin test
|
||||||
|
$('[data-toggle="dropdown"]').dropdown();
|
||||||
|
// only does anything after loading the 'popover' plugin test
|
||||||
|
$('[data-toggle="popover"]').popover();
|
||||||
|
// only does anything after loading the 'tooltip' plugin test
|
||||||
|
$('[data-toggle="tooltip"]').tooltip();
|
||||||
|
// don't initialize the modals because that messes up the Tinytest runner HTML
|
||||||
|
$.material.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
Loading…
Reference in New Issue
Block a user