aboutsummaryrefslogtreecommitdiffstats
path: root/test/caldav/template_test.js
diff options
context:
space:
mode:
authorJames Lal <james@lightsofapollo.com>2012-07-06 08:13:15 -0700
committerJames Lal <james@lightsofapollo.com>2012-07-06 08:13:15 -0700
commit20711f003e97a4a57d1e2838ba78a994c5faf6c0 (patch)
treeb060e5de05a9ffefc2ec836469c087fffa99dcef /test/caldav/template_test.js
parentc8e85fe1e0a1d2e15df580068244324ff536a23a (diff)
downloadjsCalDAV-20711f003e97a4a57d1e2838ba78a994c5faf6c0.tar.gz
webcals -> caldav rename (yes, back again)
Diffstat (limited to 'test/caldav/template_test.js')
-rw-r--r--test/caldav/template_test.js149
1 files changed, 149 insertions, 0 deletions
diff --git a/test/caldav/template_test.js b/test/caldav/template_test.js
new file mode 100644
index 0000000..3853c6e
--- /dev/null
+++ b/test/caldav/template_test.js
@@ -0,0 +1,149 @@
+testSupport.lib('template');
+
+suite('templates', function() {
+
+ var Template,
+ subject;
+
+ suiteSetup(function() {
+ Template = Caldav.require('template');
+ });
+
+ setup(function() {
+ subject = new Template('propget', { prop: 'val' });
+ });
+
+ test('initializer', function() {
+ assert.equal(subject.rootTag, 'propget');
+ assert.deepEqual(subject.activeNamespaces, {});
+ assert.deepEqual(subject.rootAttrs, {
+ prop: 'val'
+ });
+ });
+
+ suite('#_registerTag', function() {
+ var tag = 'foo';
+ var prefix = 'dav';
+ var firstOut;
+
+ setup(function() {
+ firstOut = subject._registerTag(prefix, tag);
+ });
+
+ test('same tag', function() {
+ assert.deepEqual(
+ subject.activeNamespaces['DAV:'],
+ 'N0',
+ 'should register namespace'
+ );
+
+ assert.equal(
+ subject.rootAttrs['xmlns:N0'],
+ 'DAV:',
+ 'should add xmlns to root attrs'
+ );
+
+ assert.equal(
+ firstOut,
+ subject._registerTag(prefix, tag),
+ 'tag should render the same each time'
+ );
+ });
+
+ test('second tag', function() {
+ var result = subject._registerTag('ical', 'baz');
+
+ assert.equal(
+ result,
+ 'N1:baz'
+ );
+ });
+ });
+
+ suite('#tag', function() {
+
+ test('when given a non-existant namespace', function() {
+ var out = subject.tag(['foo', 'bar'], 'content');
+
+ assert.deepEqual(
+ subject.activeNamespaces['foo'],
+ 'N0'
+ );
+
+ assert.equal(out, '<N0:bar>content</N0:bar>');
+ });
+
+ test('self closing', function() {
+ var out = subject.tag('baz', { type: 'text' });
+ assert.equal(
+ out,
+ '<N0:baz type="text" />'
+ );
+ });
+
+ test('when given a an object /w .render in content', function() {
+ var obj = {
+ render: function(template) {
+ return template.tag('baz');
+ }
+ };
+
+ var out = subject.tag('foo', obj);
+
+ assert.equal(
+ out,
+ '<N0:foo><N0:baz /></N0:foo>'
+ );
+ });
+
+ test('with attrs', function() {
+ var out = subject.tag('bar', {
+ value: 'val'
+ }, 'foo');
+
+ assert.deepEqual(
+ subject.activeNamespaces['DAV:'],
+ 'N0'
+ );
+
+ assert.equal(
+ out,
+ '<N0:bar value="val">foo</N0:bar>'
+ );
+ });
+
+ test('given an array', function() {
+ var out = subject.tag(
+ ['bar', 'baz'],
+ 'foo'
+ );
+
+ assert.equal(
+ out,
+ '<N0:baz>foo</N0:baz>'
+ );
+ });
+
+ test('given a string', function() {
+ var out = subject.tag('baz', 'foo');
+ assert.equal(
+ out,
+ '<N0:baz>foo</N0:baz>'
+ );
+ });
+ });
+
+ test('#render', function() {
+ var tag = subject.tag('href', 'value');
+ var out = subject.render(tag);
+ var output = '';
+
+ output += subject.doctype;
+ output += '<N0:propget prop="val" xmlns:N0="DAV:">';
+ output += tag;
+ output += '</N0:propget>';
+
+ assert.equal(subject.render(tag), output);
+ });
+
+});