mirror of https://github.com/artf/grapesjs.git
nocodeframeworkdrag-and-dropsite-buildersite-generatortemplate-builderui-builderweb-builderweb-builder-frameworkwebsite-builderno-codepage-builder
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
229 lines
7.3 KiB
229 lines
7.3 KiB
var path = 'Parser/';
|
|
define([path + 'model/ParserHtml',],
|
|
function(ParserHtml) {
|
|
|
|
return {
|
|
run : function(){
|
|
|
|
describe('ParserHtml', function() {
|
|
var obj;
|
|
|
|
beforeEach(function () {
|
|
obj = new ParserHtml({
|
|
textTags: ['br', 'b', 'i', 'u'],
|
|
});
|
|
});
|
|
|
|
afterEach(function () {
|
|
delete obj;
|
|
});
|
|
|
|
it('Simple div node', function() {
|
|
var str = '<div></div>';
|
|
var result = { tagName: 'div'};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Simple article node', function() {
|
|
var str = '<article></article>';
|
|
var result = { tagName: 'article'};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Node with attributes', function() {
|
|
var str = '<div id="test1" class="test2 test3" data-one="test4" strange="test5"></div>';
|
|
var result = {
|
|
tagName: 'div',
|
|
classes: ['test2', 'test3'],
|
|
attributes: {
|
|
'data-one': 'test4',
|
|
id: 'test1',
|
|
'strange': 'test5'
|
|
}
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse style string to object', function() {
|
|
var str = 'color:black; width:100px; test:value;';
|
|
var result = {
|
|
color: 'black',
|
|
width: '100px',
|
|
test: 'value',
|
|
};
|
|
obj.parseStyle(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse class string to array', function() {
|
|
var str = 'test1 test2 test3 test-4';
|
|
var result = ['test1', 'test2', 'test3', 'test-4'];
|
|
obj.parseClass(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Style attribute is isolated', function() {
|
|
var str = '<div id="test1" style="color:black; width:100px; test:value;"></div>';
|
|
var result = {
|
|
tagName: 'div',
|
|
attributes: { id: 'test1'},
|
|
style: {
|
|
color: 'black',
|
|
width: '100px',
|
|
test: 'value',
|
|
}
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Class attribute is isolated', function() {
|
|
var str = '<div id="test1" class="test2 test3 test4"></div>';
|
|
var result = {
|
|
tagName: 'div',
|
|
attributes: { id: 'test1'},
|
|
classes: ['test2', 'test3', 'test4']
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse images nodes', function() {
|
|
var str = '<img id="test1" src="./index.html"/>';
|
|
var result = {
|
|
tagName: 'img',
|
|
type: 'image',
|
|
src: './index.html',
|
|
attributes: { id: 'test1'},
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse text nodes', function() {
|
|
var str = '<div id="test1">test2 </div>';
|
|
var result = {
|
|
tagName: 'div',
|
|
attributes: { id: 'test1'},
|
|
type: 'text',
|
|
content: 'test2 ',
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse text with few text tags', function() {
|
|
var str = '<div id="test1"><br/> test2 <br/> a b <b>b</b> <i>i</i> <u>u</u> test </div>';
|
|
var result = {
|
|
tagName: 'div',
|
|
attributes: { id: 'test1'},
|
|
type: 'text',
|
|
content: '<br> test2 <br> a b <b>b</b> <i>i</i> <u>u</u> test ',
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse text with few text tags and nested node', function() {
|
|
var str = '<div id="test1">a b <b>b</b> <i>i</i>c <div>ABC</div> <i>i</i> <u>u</u> test </div>';
|
|
var result = {
|
|
tagName: 'div',
|
|
attributes: { id: 'test1'},
|
|
components: [{
|
|
tagName: 'span',
|
|
type: 'text',
|
|
content: 'a b <b>b</b> <i>i</i>c ',
|
|
},{
|
|
tagName: 'div',
|
|
type: 'text',
|
|
content: 'ABC',
|
|
},{
|
|
tagName: 'span',
|
|
type: 'text',
|
|
content: '<i>i</i> <u>u</u> test ',
|
|
}],
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse nested nodes', function() {
|
|
var str = '<article id="test1"> <div></div> <footer id="test2"></footer> Text mid <div id="last"></div></article>';
|
|
var result = {
|
|
tagName: 'article',
|
|
attributes: {id: 'test1'},
|
|
components: [
|
|
{
|
|
tagName: 'div'
|
|
},{
|
|
tagName: 'footer',
|
|
attributes: { id: 'test2'},
|
|
},{
|
|
tagName: 'span',
|
|
type: 'text',
|
|
content: ' Text mid ',
|
|
},{
|
|
tagName: 'div',
|
|
attributes: { id: 'last'},
|
|
},
|
|
]
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse nested text nodes', function() {
|
|
var str = '<div>content1 <div>nested</div> content2</div>';
|
|
var result = {
|
|
tagName: 'div',
|
|
components: [{
|
|
tagName: 'span',
|
|
type: 'text',
|
|
content: 'content1 ',
|
|
},{
|
|
tagName: 'div',
|
|
type: 'text',
|
|
content: 'nested',
|
|
},{
|
|
tagName: 'span',
|
|
type: 'text',
|
|
content: ' content2',
|
|
}],
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse nested span text nodes', function() {
|
|
var str = '<div>content1 <div><span>nested</span></div> content2</div>';
|
|
var result = {
|
|
tagName: 'div',
|
|
components: [{
|
|
tagName: 'span',
|
|
type: 'text',
|
|
content: 'content1 ',
|
|
},{
|
|
tagName: 'div',
|
|
components: [{
|
|
tagName: 'span',
|
|
type: 'text',
|
|
content: 'nested',
|
|
}]
|
|
},{
|
|
tagName: 'span',
|
|
type: 'text',
|
|
content: ' content2',
|
|
}],
|
|
};
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Parse multiple nodes', function() {
|
|
var str = '<div></div><div></div>';
|
|
var result = [{ tagName: 'div'},{ tagName: 'div'}];
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
it('Remove script tags', function() {
|
|
var str = '<div><script>var test;</script></div><div></div><script>var test2;</script>';
|
|
var result = [{ tagName: 'div'},{ tagName: 'div'}];
|
|
console.log(obj.parse(str));
|
|
obj.parse(str).should.deep.equal(result);
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
};
|
|
|
|
});
|