X-Git-Url: https://git.mdrn.pl/fnpeditor.git/blobdiff_plain/b729636a8bfe248aa9890a6f3bef56cbbab885fd..db58e0a751440706b5e0407e5a4a9ebb6cb0f8aa:/src/wlxml/wlxml.test.js
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('');
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');
});