test/DataView.test.js

Summary

Maintainability
A
0 mins
Test Coverage
var assert = require('assert');
var vis = require('../dist/vis');
var moment = vis.moment;
var DataSet = vis.DataSet;
var DataView = vis.DataView;
// TODO: test the source code immediately, but this is ES6

// TODO: improve DataView tests, split up in one test per function
describe('DataView', function () {
  it('should work', function () {
    var groups = new DataSet();

// add items with different groups
    groups.add([
      {id: 1, content: 'Item 1', group: 1},
      {id: 2, content: 'Item 2', group: 2},
      {id: 3, content: 'Item 3', group: 2},
      {id: 4, content: 'Item 4', group: 1},
      {id: 5, content: 'Item 5', group: 3}
    ]);

    var group2 = new DataView(groups, {
      filter: function (item) {
        return item.group == 2;
      }
    });

// test getting the filtered data
    assert.deepEqual(group2.get(), [
      {id: 2, content: 'Item 2', group: 2},
      {id: 3, content: 'Item 3', group: 2}
    ]);
    assert.equal(group2.length, 2);

// test filtering the view contents
    assert.deepEqual(group2.get({
      filter: function (item) {
        return item.id > 2;
      }
    }), [
      {id: 3, content: 'Item 3', group: 2}
    ]);

// test event subscription
    var groupsTriggerCount = 0;
    groups.on('*', function () {
      groupsTriggerCount++;
    });
    var group2TriggerCount = 0;
    group2.on('*', function () {
      group2TriggerCount++;
    });

    groups.update({id:2, content: 'Item 2 (changed)'});
    assert.equal(groupsTriggerCount, 1);
    assert.equal(group2TriggerCount, 1);
    assert.equal(group2.length, 2);

    groups.update({id:5, content: 'Item 5 (changed)'});
    assert.equal(groupsTriggerCount, 2);
    assert.equal(group2TriggerCount, 1);
    assert.equal(group2.length, 2);

// detach the view from groups
    group2.setData(null);
    assert.equal(groupsTriggerCount, 2);
    assert.equal(group2TriggerCount, 2);
    assert.equal(group2.length, 0);

    groups.update({id:2, content: 'Item 2 (changed again)'});
    assert.equal(groupsTriggerCount, 3);
    assert.equal(group2TriggerCount, 2);

    // test updating of .length property
    group2.setData(groups);
    assert.equal(group2.length, 2);

    // add a new item
    groups.add({id: 6, content: 'Item 6', group: 2});
    assert.equal(group2.length, 3);

    // change an items group to 2
    groups.update({id: 4, group: 2});
    assert.equal(group2.length, 4);

    // change an items group to 1
    groups.update({id: 4, group: 1});
    assert.equal(group2.length, 3);

    // remove an item
    groups.remove(2);
    assert.equal(group2.length, 2);

    // remove all items
    groups.clear();
    assert.equal(group2.length, 0);
  });


  it('should refresh a DataView with filter', function () {
    var data = new DataSet([
      {id:1, value:2},
      {id:2, value:4},
      {id:3, value:7}
    ]);

    var threshold = 5;

    // create a view. The view has a filter with a dynamic property `threshold`
    var view = new DataView(data, {
      filter: function (item) {
        return item.value < threshold;
      }
    });

    var added, updated, removed;
    view.on('add', function (event, props) {added = added.concat(props.items)});
    view.on('update', function (event, props) {updated = updated.concat(props.items)});
    view.on('remove', function (event, props) {removed = removed.concat(props.items)});

    assert.deepEqual(view.get(), [
      {id:1, value:2},
      {id:2, value:4}
    ]);

    // change the threshold to 3
    added = [];
    updated = [];
    removed = [];
    threshold = 3;
    view.refresh();
    assert.deepEqual(view.get(), [{id:1, value:2}]);
    assert.deepEqual(added, []);
    assert.deepEqual(updated, []);
    assert.deepEqual(removed, [2]);

    // change threshold to 8
    added = [];
    updated = [];
    removed = [];
    threshold = 8;
    view.refresh();
    assert.deepEqual(view.get(), [
      {id:1, value:2},
      {id:2, value:4},
      {id:3, value:7}
    ]);
    assert.deepEqual(added, [2, 3]);
    assert.deepEqual(updated, []);
    assert.deepEqual(removed, []);
  });

  it('should pass data of changed items when updating a DataSet', function () {
    var data = new DataSet([
      {id: 1, title: 'Item 1', group: 1},
      {id: 2, title: 'Item 2', group: 2},
      {id: 3, title: 'Item 3', group: 2}
    ]);
    var view = new DataView(data, {
      filter: function (item) {
        return item.group === 2;
      }
    });

    var dataUpdates = [];
    var viewUpdates = [];


    data.on('update', function (event, properties, senderId) {
      dataUpdates.push([event, properties]);
    });

    view.on('update', function (event, properties, senderId) {
      viewUpdates.push([event, properties]);
    });

    // make a change not affecting the DataView
    data.update({id: 1, title: 'Item 1 (changed)'});
    assert.deepEqual(dataUpdates, [
      ['update', {
        items: [1],
        data: [{id: 1, title: 'Item 1 (changed)'}],
        oldData: [{"group": 1, "id": 1, "title": "Item 1"}]
  }]
    ]);
    assert.deepEqual(viewUpdates, []);

    // make a change affecting the DataView
    data.update({id: 2, title: 'Item 2 (changed)'});
    assert.deepEqual(dataUpdates, [
      ['update', {
        items: [1],
        data: [{id: 1, title: 'Item 1 (changed)'}],
        oldData: [{"group": 1, "id": 1, "title": "Item 1"}]
      }],
      ['update', {
        items: [2],
        data: [{id: 2, title: 'Item 2 (changed)'}],
        oldData: [{"group": 2, "id": 2, "title": "Item 2"}]
      }]
    ]);
    assert.deepEqual(viewUpdates, [
      ['update', {items: [2], data: [{id: 2, title: 'Item 2 (changed)'}],
      oldData: [{"group": 2, "id": 2, "title": "Item 2"}]}]
    ]);

  });

});