2017-09-01 20:28:59 +08:00
|
|
|
/**
|
|
|
|
* @file layui - 测试
|
|
|
|
* @author xuexb <fe.xiaowu@gmail.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* global layui */
|
2017-09-02 19:09:08 +08:00
|
|
|
/* eslint-disable max-nested-callbacks, fecs-indent */
|
2017-09-01 20:28:59 +08:00
|
|
|
|
|
|
|
var $ = layui.$;
|
|
|
|
|
|
|
|
describe('layui', function () {
|
|
|
|
it('version', function () {
|
|
|
|
expect(layui.v).to.be.a('string');
|
|
|
|
expect(layui.v).to.not.be.empty;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('layui.config', function () {
|
|
|
|
expect(layui.config()).to.deep.equal(layui);
|
|
|
|
expect(layui.config({
|
|
|
|
testName: 'layui'
|
|
|
|
})).to.deep.equal(layui);
|
|
|
|
expect(layui.cache.testName).to.equal('layui');
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('layui.router', function () {
|
|
|
|
var defaultData = {
|
|
|
|
path: [],
|
|
|
|
search: {},
|
|
|
|
hash: ''
|
|
|
|
};
|
|
|
|
|
|
|
|
it('default params', function () {
|
|
|
|
expect(layui.router).to.be.a('function');
|
|
|
|
expect(layui.router()).to.be.a('object').and.deep.equal(defaultData);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('error router', function () {
|
|
|
|
[
|
|
|
|
null,
|
|
|
|
'',
|
|
|
|
'#123',
|
|
|
|
'123',
|
|
|
|
'##'
|
|
|
|
].forEach(function (key) {
|
|
|
|
expect(layui.router(key)).to.deep.equal(defaultData);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('router querystring', function () {
|
|
|
|
expect(layui.router('#/a=1/b=2/c=')).to.deep.equal($.extend({}, defaultData, {
|
|
|
|
search: {
|
|
|
|
a: '1',
|
|
|
|
b: '2',
|
|
|
|
c: ''
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
|
|
|
|
expect(layui.router('#/a=测试/b=2').search).to.deep.equal({
|
|
|
|
a: '测试',
|
|
|
|
b: '2'
|
|
|
|
});
|
|
|
|
|
|
|
|
// todo
|
|
|
|
// urlencode
|
|
|
|
// urldecode
|
|
|
|
});
|
|
|
|
|
|
|
|
it('router hash', function () {
|
|
|
|
expect(layui.router('#/name#layui')).to.deep.equal($.extend({}, defaultData, {
|
|
|
|
hash: '#layui',
|
|
|
|
path: ['name']
|
|
|
|
}));
|
|
|
|
expect(layui.router('#/name#layui').hash).to.equal('#layui');
|
|
|
|
expect(layui.router('#/name#layui=1').hash).to.equal('#layui=1');
|
|
|
|
expect(layui.router('#/name##layui').hash).to.equal('##layui');
|
|
|
|
expect(layui.router('#/name=1#layui').hash).to.equal('#layui');
|
|
|
|
expect(layui.router('#/name=1/b=2#layui').hash).to.equal('#layui');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('router path', function () {
|
|
|
|
expect(layui.router('#/a/b/c=2#hash')).to.deep.equal({
|
|
|
|
path: ['a', 'b'],
|
|
|
|
search: {
|
|
|
|
c: '2'
|
|
|
|
},
|
|
|
|
hash: '#hash'
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('layui.each', function () {
|
|
|
|
it('check params', function () {
|
|
|
|
expect(layui.each).to.be.a('function');
|
|
|
|
expect(layui.each()).to.deep.equal(layui);
|
|
|
|
expect(layui.each({})).to.deep.equal(layui);
|
|
|
|
expect(layui.each([])).to.deep.equal(layui);
|
|
|
|
expect(layui.each({}, function () {})).to.deep.equal(layui);
|
|
|
|
expect(layui.each([], function () {})).to.deep.equal(layui);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('null params', function (done) {
|
|
|
|
var index = 0;
|
|
|
|
layui.each(null, function (index) {
|
|
|
|
index += 1;
|
|
|
|
});
|
|
|
|
setTimeout(function () {
|
|
|
|
expect(index).to.equal(0);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('object each', function (done) {
|
|
|
|
layui.each({
|
|
|
|
name: 'layui'
|
|
|
|
}, function (key, value) {
|
|
|
|
expect(this + '').to.deep.equal(value).and.equal('layui');
|
|
|
|
expect(key).to.equal('name');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('array each', function (done) {
|
|
|
|
layui.each([
|
|
|
|
'layui'
|
|
|
|
], function (index, value) {
|
2017-09-02 19:09:08 +08:00
|
|
|
expect(this + '').to.deep.equal(value).and.equal('layui');
|
2017-09-01 20:28:59 +08:00
|
|
|
expect(index).to.equal(0);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('break array each', function () {
|
|
|
|
var arr = new Array(100).join(',').split(',');
|
|
|
|
var flag = -1;
|
|
|
|
layui.each(arr, function (index) {
|
|
|
|
flag = index;
|
|
|
|
if (index > 5) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
expect(flag).to.equal(6);
|
|
|
|
|
|
|
|
flag = -1;
|
|
|
|
layui.each(arr, function (index) {
|
|
|
|
flag = index;
|
|
|
|
if (index > 5) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
expect(flag).to.equal(99);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('break object each', function () {
|
|
|
|
var obj = {
|
|
|
|
name: 'layui',
|
|
|
|
version: '2.x'
|
|
|
|
};
|
|
|
|
var flag = null;
|
|
|
|
layui.each(obj, function (key) {
|
|
|
|
flag = key;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
expect(flag).to.equal('name');
|
|
|
|
|
|
|
|
flag = null;
|
|
|
|
layui.each(obj, function (key) {
|
|
|
|
flag = key;
|
|
|
|
return false;
|
|
|
|
});
|
|
|
|
expect(flag).to.equal('version');
|
|
|
|
});
|
|
|
|
});
|
2017-09-02 19:09:08 +08:00
|
|
|
|
|
|
|
describe('layui.img', function () {
|
|
|
|
var base64 = '';
|
|
|
|
it('success callback', function (done) {
|
|
|
|
layui.img(base64, function (img) {
|
|
|
|
expect(img).to.not.undefined;
|
|
|
|
expect(typeof(img)).to.equal('object', '是img对象');
|
|
|
|
expect(img.nodeType).to.equal(1, 'img标签节点');
|
2017-09-02 19:32:53 +08:00
|
|
|
|
|
|
|
// 在ie11中不通过, 原因目前不明
|
|
|
|
// expect(img.width).to.equal(1);
|
|
|
|
// expect(img.height).to.equal(1);
|
2017-09-02 19:09:08 +08:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('error callback', function (done) {
|
2017-09-02 19:32:53 +08:00
|
|
|
layui.img('/404/404.gif', function () {}, function (e) {
|
2017-09-02 19:09:08 +08:00
|
|
|
expect(e).to.not.undefined;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// 先删除, 因为没有哪个图片是决定不变的
|
|
|
|
// it('http 200', function (done) {
|
|
|
|
// layui.img('https://www.baidu.com/img/bd_logo1.png', function (img) {
|
|
|
|
// expect(img).to.not.undefined;
|
|
|
|
// done();
|
|
|
|
// });
|
|
|
|
// });
|
|
|
|
|
|
|
|
it('http 404', function (done) {
|
|
|
|
layui.img('http://www.404.xx/logo.404.gif', function () {}, function (e) {
|
|
|
|
expect(e).to.not.undefined;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('load complete', function (done) {
|
|
|
|
layui.img(base64, function () {
|
|
|
|
layui.img(base64, function (img) {
|
|
|
|
expect(img).to.not.undefined;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('layui.hint', function () {
|
|
|
|
expect(layui.hint).to.be.a('function');
|
|
|
|
expect(layui.hint()).to.be.a('object');
|
|
|
|
expect(layui.hint().error).to.be.a('function');
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('layui.stope', function () {
|
|
|
|
it('stopPropagation', function (done) {
|
|
|
|
layui.stope({
|
|
|
|
stopPropagation: function (e) {
|
|
|
|
expect(e).to.be.undefined;
|
|
|
|
done();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('cancelBubble', function () {
|
|
|
|
var event = {};
|
|
|
|
layui.stope(event);
|
|
|
|
expect(event.cancelBubble).to.be.true;
|
|
|
|
});
|
|
|
|
|
|
|
|
// ie中不支持
|
|
|
|
// it('window.event', function () {
|
|
|
|
// var old = window.event;
|
|
|
|
// var event = window.event = {};
|
|
|
|
// layui.stope();
|
|
|
|
// expect(event.cancelBubble).to.be.true;
|
|
|
|
// window.event = old;
|
|
|
|
// });
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('layui.onevent', function () {
|
|
|
|
it('check params and return value', function () {
|
|
|
|
expect(layui.onevent).to.be.a('function');
|
|
|
|
expect(layui.onevent()).to.deep.equal(layui);
|
|
|
|
expect(layui.onevent([], [], [])).to.deep.equal(layui);
|
|
|
|
expect(layui.onevent({}, {}, {})).to.deep.equal(layui);
|
|
|
|
|
|
|
|
var result = layui.onevent('test-' + Date.now(), 'click', function () {});
|
|
|
|
expect(result).to.deep.equal(layui);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('bind event', function (done) {
|
|
|
|
var id = 'test-bind-event';
|
|
|
|
var data = {
|
|
|
|
name: 'layui'
|
|
|
|
};
|
|
|
|
var result = layui.onevent(id, 'click', function (param) {
|
|
|
|
expect(result).to.deep.equal(this).and.equal(layui);
|
|
|
|
expect(param).to.deep.equal(data);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
layui.event(id, 'click', data);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('coverage of the same name event', function () {
|
|
|
|
var id = 'test-same-event';
|
|
|
|
var index = 0;
|
|
|
|
layui.onevent(id, 'click', function () {
|
|
|
|
index = 1;
|
|
|
|
});
|
|
|
|
layui.onevent(id, 'click', function () {
|
|
|
|
index = 2;
|
|
|
|
});
|
|
|
|
layui.event(id, 'click');
|
|
|
|
expect(index).to.equal(2);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('layui.event', function () {
|
|
|
|
it('trigger event', function (done) {
|
|
|
|
layui.onevent('test-trigger', 'click(*)', function (data) {
|
|
|
|
expect(data).to.be.true;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
layui.event('test-trigger', 'click(*)', true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('trigger multiple', function () {
|
|
|
|
var index = 0;
|
|
|
|
var id = 'test-trigger-multiple';
|
|
|
|
layui.onevent(id, 'nav', function () {
|
|
|
|
index += 1;
|
|
|
|
});
|
|
|
|
layui.event(id, 'nav');
|
|
|
|
layui.event(id, 'nav');
|
|
|
|
layui.event(id, 'nav');
|
|
|
|
expect(index).to.equal(3);
|
|
|
|
});
|
|
|
|
|
|
|
|
// todo多个事件
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('layui.sort', function () {
|
|
|
|
var numberData = [
|
|
|
|
{
|
|
|
|
name: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 3
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 2
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
it('check params and return value', function () {
|
|
|
|
// 由于没有值参数, 导致 JSON.parse 失败
|
|
|
|
expect(function () {
|
|
|
|
layui.sort();
|
|
|
|
}).to.throw();
|
|
|
|
|
|
|
|
expect(layui.sort({})).to.deep.equal({});
|
|
|
|
expect(layui.sort({
|
|
|
|
name: 'layui'
|
|
|
|
})).to.deep.equal({
|
|
|
|
name: 'layui'
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(layui.sort([{
|
|
|
|
name: 'layui'
|
|
|
|
}], 'name')).to.deep.equal([{
|
|
|
|
name: 'layui'
|
|
|
|
}]);
|
|
|
|
|
|
|
|
expect(layui.sort([{
|
|
|
|
name: 'layui'
|
|
|
|
}], 'name', true)).to.deep.equal([{
|
|
|
|
name: 'layui'
|
|
|
|
}]);
|
|
|
|
});
|
|
|
|
|
|
|
|
// 测试是否污染原数据
|
|
|
|
it('clone object', function () {
|
|
|
|
var clone = layui.sort(numberData, 'name');
|
|
|
|
|
|
|
|
// 往clone对象添加
|
|
|
|
clone.push('layui');
|
|
|
|
|
|
|
|
expect(clone).to.have.lengthOf(4);
|
|
|
|
expect(numberData).to.have.lengthOf(3);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('format value number', function () {
|
|
|
|
var result = layui.sort([
|
|
|
|
{
|
|
|
|
key: '1'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: '-1'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 2
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 3
|
|
|
|
}
|
|
|
|
], 'key');
|
|
|
|
expect(result).to.deep.equal([
|
|
|
|
{
|
|
|
|
key: '-1'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: '1'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 2
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 3
|
|
|
|
}
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('asc order', function () {
|
|
|
|
var result = layui.sort(numberData, 'name');
|
|
|
|
expect(result).to.deep.equal([
|
|
|
|
{
|
|
|
|
name: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 2
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 3
|
|
|
|
}
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('desc order', function () {
|
|
|
|
var result = layui.sort(numberData, 'name', true);
|
|
|
|
expect(result).to.deep.equal([
|
|
|
|
{
|
|
|
|
name: 3
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 2
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 1
|
|
|
|
}
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('error data', function () {
|
|
|
|
var data = [
|
|
|
|
// null,
|
|
|
|
{
|
|
|
|
name: 5
|
|
|
|
},
|
|
|
|
{},
|
|
|
|
[],
|
|
|
|
'test',
|
|
|
|
{
|
|
|
|
name: '3'
|
|
|
|
}
|
|
|
|
];
|
|
|
|
expect(layui.sort(data, 'name')).to.deep.equal([
|
|
|
|
{},
|
|
|
|
[],
|
|
|
|
'test',
|
|
|
|
{
|
|
|
|
name: '3'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 5
|
|
|
|
}
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('layui.device', function () {
|
|
|
|
expect(layui.device).to.be.a('function');
|
|
|
|
expect(layui.device()).to.be.a('object');
|
|
|
|
expect(layui.device().ie).to.be.not.undefined;
|
|
|
|
expect(layui.device().ios).to.be.not.undefined;
|
|
|
|
expect(layui.device().android).to.be.not.undefined;
|
|
|
|
expect(layui.device().weixin).to.be.a('boolean');
|
|
|
|
expect(layui.device('weixin').weixin).to.be.false;
|
|
|
|
expect(layui.device('.*')['.*']).to.be.not.empty;
|
|
|
|
expect(layui.device('layui.com')['layui.com']).to.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('layui.getStyle', function () {
|
|
|
|
it('real test', function () {
|
|
|
|
var elem = $('<div />').css({
|
|
|
|
position: 'fixed',
|
|
|
|
zIndex: 10
|
|
|
|
}).appendTo('body').get(0);
|
|
|
|
|
|
|
|
expect(layui.getStyle(elem, 'position')).to.equal('fixed');
|
|
|
|
expect(layui.getStyle(elem, 'z-index')).to.equal('10');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('mock currentStyle', function (done) {
|
|
|
|
var node = {
|
|
|
|
currentStyle: {
|
|
|
|
getPropertyValue: function (name) {
|
|
|
|
expect(name).to.equal('layui');
|
|
|
|
done();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
layui.getStyle(node, 'layui');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('layui.extend', function () {
|
|
|
|
expect(layui.extend).to.be.a('function');
|
|
|
|
expect(layui.extend()).to.deep.equal(layui);
|
|
|
|
expect(layui.extend({
|
|
|
|
v: 'v',
|
|
|
|
util: 'util'
|
|
|
|
})).to.deep.equal(layui);
|
|
|
|
|
|
|
|
var id = 'test-extend-' + Date.now();
|
|
|
|
var data = {};
|
|
|
|
data[id] = id;
|
|
|
|
expect(layui.modules[id]).to.be.undefined;
|
|
|
|
layui.extend(data);
|
|
|
|
expect(layui.modules[id]).to.be.not.undefined;
|
|
|
|
expect(layui.modules[id]).to.equal(id);
|
|
|
|
delete layui.modules[id];
|
|
|
|
});
|
2017-09-01 20:28:59 +08:00
|
|
|
});
|
2017-09-02 19:09:08 +08:00
|
|
|
/* eslint-enable max-nested-callbacks, fecs-indent */
|