~bac/juju-gui/trunkcopy

« back to all changes in this revision

Viewing changes to lib/d3/test/core/selection-append-test.js

  • Committer: kapil.foss at gmail
  • Date: 2012-07-13 18:45:59 UTC
  • Revision ID: kapil.foss@gmail.com-20120713184559-2xl7be17egsrz0c9
reshape

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
require("../env");
2
 
 
3
 
var vows = require("vows"),
4
 
    assert = require("assert");
5
 
 
6
 
var suite = vows.describe("selection.append");
7
 
 
8
 
suite.addBatch({
9
 
  "select(body)": {
10
 
    topic: function() {
11
 
      return d3.select("body").html("");
12
 
    },
13
 
    "appends an HTML element": function(body) {
14
 
      var div = body.append("div");
15
 
      assert.equal(div[0][0].tagName, "DIV");
16
 
      assert.isNull(div[0][0].namespaceURI);
17
 
      assert.isTrue(div[0][0].parentNode === document.body);
18
 
      assert.isTrue(div[0][0] === document.body.lastChild);
19
 
    },
20
 
    "appends an SVG element": function(body) {
21
 
      var svg = body.append("svg:svg");
22
 
      assert.equal(svg[0][0].tagName, "SVG");
23
 
      assert.equal(svg[0][0].namespaceURI, "http://www.w3.org/2000/svg");
24
 
      assert.isTrue(svg[0][0].parentNode === document.body);
25
 
      assert.isTrue(svg[0][0] === document.body.lastChild);
26
 
    },
27
 
    "propagates data to new element": function(body) {
28
 
      var data = new Object(), div = body.data([data]).append("div");
29
 
      assert.strictEqual(div[0][0].__data__, data);
30
 
    },
31
 
    "returns a new selection": function(body) {
32
 
      assert.isFalse(body.append("div") === body);
33
 
    },
34
 
    "inherits namespace from parent node": function(body) {
35
 
      var g = body.append("svg:svg").append("g");
36
 
      assert.equal(g[0][0].namespaceURI, "http://www.w3.org/2000/svg");
37
 
    }
38
 
  }
39
 
});
40
 
 
41
 
suite.addBatch({
42
 
  "selectAll(div)": {
43
 
    topic: function() {
44
 
      return d3.select("body").html("").selectAll("div").data(d3.range(2)).enter().append("div");
45
 
    },
46
 
    "appends an HTML element": function(div) {
47
 
      var span = div.append("span");
48
 
      assert.equal(span[0].length, 2);
49
 
      assert.equal(span[0][0].tagName, "SPAN");
50
 
      assert.equal(span[0][1].tagName, "SPAN");
51
 
      assert.isNull(span[0][0].namespaceURI);
52
 
      assert.isNull(span[0][1].namespaceURI);
53
 
      assert.isTrue(span[0][0].parentNode === div[0][0]);
54
 
      assert.isTrue(span[0][1].parentNode === div[0][1]);
55
 
      assert.isTrue(div[0][0].lastChild === span[0][0]);
56
 
      assert.isTrue(div[0][1].lastChild === span[0][1]);
57
 
    },
58
 
    "appends an SVG element": function(div) {
59
 
      var svg = div.append("svg:svg");
60
 
      assert.equal(svg[0].length, 2);
61
 
      assert.equal(svg[0][0].tagName, "SVG");
62
 
      assert.equal(svg[0][1].tagName, "SVG");
63
 
      assert.equal(svg[0][0].namespaceURI, "http://www.w3.org/2000/svg");
64
 
      assert.equal(svg[0][1].namespaceURI, "http://www.w3.org/2000/svg");
65
 
      assert.isTrue(svg[0][0].parentNode === div[0][0]);
66
 
      assert.isTrue(svg[0][1].parentNode === div[0][1]);
67
 
      assert.isTrue(div[0][0].lastChild === svg[0][0]);
68
 
      assert.isTrue(div[0][1].lastChild === svg[0][1]);
69
 
    },
70
 
    "ignores null nodes": function(div) {
71
 
      div.html("");
72
 
      var some = d3.selectAll("div");
73
 
      some[0][1] = null;
74
 
      var span = some.append("span");
75
 
      assert.equal(span[0].length, 2);
76
 
      assert.equal(span[0][0].tagName, "SPAN");
77
 
      assert.isNull(span[0][1]);
78
 
      assert.isTrue(span[0][0].parentNode === div[0][0]);
79
 
      assert.isTrue(div[0][0].lastChild === span[0][0]);
80
 
      assert.isNull(div[0][1].lastChild);
81
 
    },
82
 
    "propagates data to new elements": function(div) {
83
 
      var a = new Object(), b = new Object(), span = div.data([a, b]).append("span");
84
 
      assert.strictEqual(span[0][0].__data__, a);
85
 
      assert.strictEqual(span[0][1].__data__, b);
86
 
    },
87
 
    "returns a new selection": function(div) {
88
 
      assert.isFalse(div.append("div") === div);
89
 
    }
90
 
  }
91
 
});
92
 
 
93
 
suite.addBatch({
94
 
  "selectAll(div).data(…).enter()": {
95
 
    topic: function() {
96
 
      return d3.select("body");
97
 
    },
98
 
    "appends to the parent node": function(body) {
99
 
      var div = body.html("").selectAll("div").data(d3.range(2)).enter().append("div");
100
 
      assert.equal(div.length, 1);
101
 
      assert.equal(div[0].length, 2);
102
 
      assert.domEqual(div[0][0].parentNode, document.body);
103
 
      assert.domEqual(div[0][1].parentNode, document.body);
104
 
    },
105
 
    "propagates data to new elements": function(body) {
106
 
      var a = new Object(), b = new Object(), div = body.html("").selectAll("div").data([a, b]).enter().append("div");
107
 
      assert.strictEqual(div[0][0].__data__, a);
108
 
      assert.strictEqual(div[0][1].__data__, b);
109
 
    },
110
 
    "ignores null nodes": function(body) {
111
 
      body.html("").append("div");
112
 
      var div = body.selectAll("div").data(d3.range(3)).enter().append("div");
113
 
      assert.equal(div.length, 1);
114
 
      assert.equal(div[0].length, 3);
115
 
      assert.domNull(div[0][0]);
116
 
      assert.domEqual(div[0][1].parentNode, document.body);
117
 
      assert.domEqual(div[0][2].parentNode, document.body);
118
 
    }
119
 
  }
120
 
});
121
 
 
122
 
suite.export(module);