X-Git-Url: https://git.mdrn.pl/fnpeditor.git/blobdiff_plain/b729636a8bfe248aa9890a6f3bef56cbbab885fd..471681497ab6e3ae9919f4e67f8edfc5e63a0670:/src/wlxml/wlxml.test.js?ds=sidebyside diff --git a/src/wlxml/wlxml.test.js b/src/wlxml/wlxml.test.js index e2c11fa..516b47c 100644 --- a/src/wlxml/wlxml.test.js +++ b/src/wlxml/wlxml.test.js @@ -6,7 +6,7 @@ define([ 'use strict'; /* jshint expr:true */ -/* global it, describe */ +/* global it, describe, beforeEach */ var expect = chai.expect; @@ -27,9 +27,14 @@ describe('WLXMLDocument', function() { expect(node.getClass()).to.equal('class.subclass'); }); - it('returns attributes other than class and meta-* as other attributes', function() { - var node = nodeFromXML(''); - expect(node.getOtherAttributes()).to.eql({attr1: 'val1', attr2: 'val2'}); + it('returns unregistered attributes', function() { + var testClasses = { + 'testClass': { + attrs: {'attr1': {type: 'string'}} + } + }, + doc = getDocumentFromXML('', {wlxmlClasses: testClasses}); + expect(doc.root.getOtherAttributes()).to.eql({attr: {value:'val'}}); }); }); @@ -76,7 +81,7 @@ describe('WLXMLDocument', function() { } }, node = getDocumentFromXML( - '', + '', {wlxmlClasses: testClasses} ).root, attrs = node.getMetaAttributes(); @@ -103,6 +108,8 @@ describe('WLXMLDocument', function() { }); describe('White space handling', function() { + /* globals Node */ + it('ignores white space surrounding block elements', function() { var node = nodeFromXML('
'), contents = node.contents(); @@ -258,67 +265,11 @@ describe('WLXMLDocument', function() { doc = getDocumentFromXML('
Alice
'); elementNode = doc.root; textNode = doc.root.contents()[0]; + testClassNode = doc.root.contents('.test_class'); extension = {}; - console.log('A'); - expect(function() { - elementNode.transform('testTransformation'); - }).to.throw(Error); - console.log('B'); - expect(function() { - textNode.transform('testTransformation'); - }).to.throw(Error); - console.log('C'); - expect(function() { - doc.transform('testTransformation'); - }).to.throw(Error); - expect(doc.testMethod).to.be.undefined; - expect(elementNode.testMethod).to.be.undefined; - expect(textNode.testMethod).to.be.undefined; - }); - - it('allows adding method to a document', function() { - extension = {document: {methods: { - testMethod: function() { return this; } - }}}; - - doc.registerExtension(extension); - expect(doc.testMethod()).to.equal(doc, 'context is set to a document instance'); - }); - - it('allows adding transformation to a document', function() { - extension = {document: {transformations: { - testTransformation: function() { return this; }, - testTransformation2: {impl: function() { return this;}} - }}}; - - doc.registerExtension(extension); - expect(doc.transform('testTransformation')).to.equal(doc, 'context is set to a document instance'); - expect(doc.transform('testTransformation2')).to.equal(doc, 'context is set to a document instance'); - }); - - it('allows adding method to a DocumentNode instance', function() { - extension = {documentNode: {methods: { - testMethod: function() { return this; } - }}}; - - doc.registerExtension(extension); - expect(elementNode.testMethod().sameNode(elementNode)).to.equal(true, 'context is set to a node instance'); - expect(textNode.testMethod().sameNode(textNode)).to.equal(true, 'context is set to a node instance'); - }); - - it('allows adding transformation to a DocumentNode', function() { - extension = {documentNode: {transformations: { - testTransformation: function() { return this; }, - testTransformation2: {impl: function() { return this;}} - }}}; - - doc.registerExtension(extension); + expect(testClassNode.object).to.be.undefined; - expect(elementNode.transform('testTransformation').sameNode(elementNode)).to.equal(true, '1'); - expect(elementNode.transform('testTransformation2').sameNode(elementNode)).to.equal(true, '2'); - expect(textNode.transform('testTransformation').sameNode(textNode)).to.equal(true, '3'); - expect(textNode.transform('testTransformation2').sameNode(textNode)).to.equal(true, '4'); }); it('allows adding method to an ElementNode of specific class', function() { @@ -337,8 +288,8 @@ describe('WLXMLDocument', function() { }}}}; doc.registerExtension(extension); testClassNode = doc.root.contents()[1]; - expect(testClassNode.object.transform('testTransformation').sameNode(testClassNode)).to.equal(true, '1'); - expect(testClassNode.object.transform('testTransformation2').sameNode(testClassNode)).to.equal(true, '1'); + expect(testClassNode.object.testTransformation().sameNode(testClassNode)).to.equal(true, '1'); + expect(testClassNode.object.testTransformation2().sameNode(testClassNode)).to.equal(true, '1'); });