From ee4c779bb0a22bf03d6ed76e1d36ac330dc33fb8 Mon Sep 17 00:00:00 2001 From: Gung Mahendra Date: Sun, 15 Jan 2017 15:31:37 +0800 Subject: [PATCH] Added test component and directive --- dist/test/angular2-nvd3.component.spec.js | 37 +- dist/test/sample-data.d.ts | 320 +++++++++++++ dist/test/sample-data.js | 441 +++++++++++++++++ karma.conf.js | 6 +- src/test/angular2-nvd3.component.spec.ts | 56 ++- src/test/angular2-nvd3.directive.spec.ts | 48 ++ polyfills.browser.ts => src/test/polyfills.ts | 14 - src/test/sample-data.ts | 447 ++++++++++++++++++ src/test/test.component.ts | 8 + src/test/test.ts | 32 ++ 10 files changed, 1361 insertions(+), 48 deletions(-) create mode 100644 dist/test/sample-data.d.ts create mode 100644 dist/test/sample-data.js create mode 100644 src/test/angular2-nvd3.directive.spec.ts rename polyfills.browser.ts => src/test/polyfills.ts (53%) create mode 100644 src/test/sample-data.ts create mode 100644 src/test/test.component.ts create mode 100644 src/test/test.ts diff --git a/dist/test/angular2-nvd3.component.spec.js b/dist/test/angular2-nvd3.component.spec.js index e76dc6b..56daa11 100644 --- a/dist/test/angular2-nvd3.component.spec.js +++ b/dist/test/angular2-nvd3.component.spec.js @@ -1,16 +1,33 @@ "use strict"; var testing_1 = require("@angular/core/testing"); var angular2_nvd3_component_1 = require("../angular2-nvd3/angular2-nvd3.component"); -describe('tasks:NvD3Component', function () { - var comp; - var fixture; - beforeEach(function () { - testing_1.TestBed.configureTestingModule({ - declarations: [angular2_nvd3_component_1.NvD3Component], +var sample_data_1 = require("./sample-data"); +sample_data_1.SampleData.chartTypes.forEach(function (type) { + describe("tasks:NvD3Component " + type, function () { + var component; + var fixture; + var componentElement; + beforeEach(function () { + testing_1.TestBed.configureTestingModule({ + declarations: [angular2_nvd3_component_1.NvD3Component], + }); + fixture = testing_1.TestBed.createComponent(angular2_nvd3_component_1.NvD3Component); + component = fixture.componentInstance; + component.options = sample_data_1.SampleData.allOptions[type]; + component.data = sample_data_1.SampleData.allData[type]; + fixture.detectChanges(); + componentElement = fixture.nativeElement; + }); + it("should have svg", function () { + expect(componentElement.querySelectorAll('svg').length).toBe(1); + }); + it('should svg have class nvd3-svg', function () { + var gElement = componentElement.querySelector('svg'); + expect(gElement.classList).toContain('nvd3-svg'); + }); + it("should g have class nv-" + type, function () { + var gElement = componentElement.querySelector('g'); + expect(gElement.className.baseVal).toContain(sample_data_1.SampleData.chartClassExpected[type]); }); - }); - it('should call ngOnChanges', function () { - }); - it('should call ngOnInit', function () { }); }); diff --git a/dist/test/sample-data.d.ts b/dist/test/sample-data.d.ts new file mode 100644 index 0000000..88b0d2a --- /dev/null +++ b/dist/test/sample-data.d.ts @@ -0,0 +1,320 @@ +export declare namespace SampleData { + const chartTypes: string[]; + const allOptions: { + lineChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + y: (d: any) => any; + }; + }; + discreteBarChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + y: (d: any) => any; + }; + }; + pieChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + y: (d: any) => any; + }; + }; + scatterChart: { + chart: { + type: string; + height: number; + }; + }; + multiBarChart: { + chart: { + type: string; + height: number; + stacked: boolean; + }; + }; + candlestickBarChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + y: (d: any) => any; + }; + }; + ohlcBarChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + y: (d: any) => any; + }; + }; + boxPlotChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + }; + }; + multiChart: { + chart: { + type: string; + height: number; + }; + }; + sunburstChart: { + chart: { + type: string; + height: number; + }; + }; + stackedAreaChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + y: (d: any) => any; + }; + }; + multiBarHorizontalChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + y: (d: any) => any; + }; + }; + cumulativeLineChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + y: (d: any) => number; + average: (d: any) => number; + }; + }; + historicalBarChart: { + chart: { + type: string; + height: number; + x: (d: any) => any; + y: (d: any) => number; + }; + }; + parallelCoordinates: { + chart: { + type: string; + height: number; + dimensionData: string[]; + }; + }; + sparklinePlus: { + chart: { + type: string; + height: number; + x: (d: any, i: any) => any; + }; + }; + bulletChart: { + chart: { + type: string; + height: number; + }; + }; + linePlusBarWithFocusChart: { + chart: { + type: string; + height: number; + color: string[]; + x: (d: any, i: any) => any; + }; + }; + forceDirectedGraph: { + chart: { + type: string; + }; + }; + }; + const allData: { + lineChart: { + key: string; + values: { + x: number; + y: number; + }[]; + }[]; + discreteBarChart: { + key: string; + values: { + 'label': string; + 'value': number; + }[]; + }[]; + pieChart: { + key: string; + y: number; + }[]; + scatterChart: { + key: string; + values: { + x: number; + y: number; + }[]; + }[]; + multiBarChart: { + key: string; + values: { + x: number; + y: number; + }[]; + }[]; + candlestickBarChart: { + values: { + 'date': number; + 'open': number; + 'high': number; + 'low': number; + 'close': number; + 'volume': number; + 'adjusted': number; + }[]; + }[]; + ohlcBarChart: { + values: { + 'date': number; + 'open': number; + 'high': number; + 'low': number; + 'close': number; + 'volume': number; + 'adjusted': number; + }[]; + }[]; + boxPlotChart: { + label: string; + values: { + Q1: number; + Q2: number; + Q3: number; + whisker_low: number; + whisker_high: number; + outliers: number[]; + }; + }[]; + multiChart: { + key: string; + type: string; + yAxis: number; + values: { + x: number; + y: number; + }[]; + }[]; + sunburstChart: { + 'name': string; + 'children': { + 'name': string; + 'children': { + 'name': string; + 'children': { + 'name': string; + 'size': number; + }[]; + }[]; + }[]; + }[]; + stackedAreaChart: { + 'key': string; + 'values': number[][]; + }[]; + multiBarHorizontalChart: { + 'key': string; + 'values': { + 'label': string; + 'value': number; + }[]; + }[]; + cumulativeLineChart: { + key: string; + values: number[][]; + mean: number; + }[]; + historicalBarChart: { + 'key': string; + 'bar': boolean; + 'values': number[][]; + }[]; + parallelCoordinates: { + 'name': string; + 'economy (mpg)': string; + 'cylinders': string; + 'displacement (cc)': string; + 'power (hp)': string; + 'weight (lb)': string; + '0-60 mph (s)': string; + 'year': string; + }[]; + sparklinePlus: { + x: number; + y: number; + }[]; + bulletChart: { + 'title': string; + 'subtitle': string; + 'ranges': number[]; + 'measures': number[]; + 'markers': number[]; + }; + linePlusBarWithFocusChart: ({ + 'key': string; + 'bar': boolean; + 'values': { + x: number; + y: number; + }[]; + } | { + 'key': string; + 'values': { + x: number; + y: number; + }[]; + })[]; + forceDirectedGraph: { + 'nodes': { + 'name': string; + 'group': number; + }[]; + 'links': { + 'source': number; + 'target': number; + 'value': number; + }[]; + }; + }; + const chartClassExpected: { + lineChart: string; + discreteBarChart: string; + pieChart: string; + scatterChart: string; + multiBarChart: string; + multiBarHorizontalChart: string; + candlestickBarChart: string; + ohlcBarChart: string; + boxPlotChart: string; + multiChart: string; + sunburstChart: string; + stackedAreaChart: string; + cumulativeLineChart: string; + historicalBarChart: string; + parallelCoordinates: string; + sparklinePlus: string; + bulletChart: string; + linePlusBarWithFocusChart: string; + forceDirectedGraph: string; + }; +} diff --git a/dist/test/sample-data.js b/dist/test/sample-data.js new file mode 100644 index 0000000..8b8a329 --- /dev/null +++ b/dist/test/sample-data.js @@ -0,0 +1,441 @@ +"use strict"; +var SampleData; +(function (SampleData) { + SampleData.chartTypes = [ + 'lineChart', + 'discreteBarChart', + 'pieChart', + 'scatterChart', + 'multiBarChart', + 'multiBarHorizontalChart', + 'candlestickBarChart', + 'ohlcBarChart', + 'boxPlotChart', + 'multiChart', + 'sunburstChart', + 'stackedAreaChart', + 'cumulativeLineChart', + 'historicalBarChart', + 'parallelCoordinates', + 'sparklinePlus', + 'bulletChart', + 'linePlusBarWithFocusChart', + 'forceDirectedGraph' + ]; + SampleData.allOptions = { + lineChart: { + chart: { + type: 'lineChart', + height: 450, + x: function (d) { return d.x; }, + y: function (d) { return d.y; } + } + }, + discreteBarChart: { + chart: { + type: 'discreteBarChart', + height: 450, + x: function (d) { return d.label; }, + y: function (d) { return d.value; } + } + }, + pieChart: { + chart: { + type: 'pieChart', + height: 500, + x: function (d) { return d.key; }, + y: function (d) { return d.y; } + } + }, + scatterChart: { + chart: { + type: 'scatterChart', + height: 450 + } + }, + multiBarChart: { + chart: { + type: 'multiBarChart', + height: 450, + stacked: true + } + }, + candlestickBarChart: { + chart: { + type: 'candlestickBarChart', + height: 450, + x: function (d) { return d['date']; }, + y: function (d) { return d['close']; } + } + }, + ohlcBarChart: { + chart: { + type: 'ohlcBarChart', + height: 450, + x: function (d) { return d['date']; }, + y: function (d) { return d['close']; } + } + }, + boxPlotChart: { + chart: { + type: 'boxPlotChart', + height: 450, + x: function (d) { return d.label; } + } + }, + multiChart: { + chart: { + type: 'multiChart', + height: 450 + } + }, + sunburstChart: { + chart: { + type: 'sunburstChart', + height: 450 + } + }, + stackedAreaChart: { + chart: { + type: 'stackedAreaChart', + height: 450, + x: function (d) { return d[0]; }, + y: function (d) { return d[1]; } + } + }, + multiBarHorizontalChart: { + chart: { + type: 'multiBarHorizontalChart', + height: 450, + x: function (d) { return d.label; }, + y: function (d) { return d.value; } + } + }, + cumulativeLineChart: { + chart: { + type: 'cumulativeLineChart', + height: 450, + x: function (d) { return d[0]; }, + y: function (d) { return d[1] / 100; }, + average: function (d) { return d.mean / 100; } + } + }, + historicalBarChart: { + chart: { + type: 'historicalBarChart', + height: 450, + x: function (d) { return d[0]; }, + y: function (d) { return d[1] / 100000; } + } + }, + parallelCoordinates: { + chart: { + type: 'parallelCoordinates', + height: 450, + dimensionData: [ + 'economy (mpg)', + 'cylinders', + 'displacement (cc)', + 'power (hp)', + 'weight (lb)', + '0-60 mph (s)', + 'year' + ] + } + }, + sparklinePlus: { + chart: { + type: 'sparklinePlus', + height: 450, + x: function (d, i) { return i; } + } + }, + bulletChart: { + chart: { + type: 'bulletChart', + height: 450 + } + }, + linePlusBarWithFocusChart: { + chart: { + type: 'linePlusBarChart', + height: 500, + color: ['#2ca02c', 'darkred'], + x: function (d, i) { return i; } + } + }, + forceDirectedGraph: { + chart: { + type: 'forceDirectedGraph' + } + } + }; + SampleData.allData = { + lineChart: [ + { key: 'key1', values: [{ x: 0, y: 0 }, { x: 1, y: 1 }] }, + { key: 'key2', values: [{ x: 1, y: 1 }, { x: 0, y: 0 }] } + ], + discreteBarChart: [ + { + key: 'Cumulative Return', + values: [ + { 'label': 'A', 'value': 10 }, + { 'label': 'B', 'value': 20 } + ] + } + ], + pieChart: [ + { key: 'One', y: 5 }, + { key: 'Two', y: 2 } + ], + scatterChart: [ + { key: 'key1', values: [{ x: 0, y: 0 }, { x: 1, y: 1 }] }, + { key: 'key2', values: [{ x: 1, y: 1 }, { x: 0, y: 0 }] } + ], + multiBarChart: [ + { + key: 'Sent', + values: [{ x: 0, y: 1 }, { x: 1, y: 2 }] + }, + { + key: 'Received', + values: [{ x: 0, y: 2 }, { x: 1, y: 3 }] + }, + { + key: 'Spam', + values: [{ x: 0, y: 3 }, { x: 1, y: 5 }] + } + ], + candlestickBarChart: [{ + values: [ + { 'date': 15854, 'open': 165.42, 'high': 165.8, 'low': 164.34, 'close': 165.22, 'volume': 160363400, 'adjusted': 164.35 }, + { 'date': 15855, 'open': 165.35, 'high': 166.59, 'low': 165.22, 'close': 165.83, 'volume': 107793800, 'adjusted': 164.96 } + ] + } + ], + ohlcBarChart: [{ + values: [ + { 'date': 15707, 'open': 145.11, 'high': 146.15, 'low': 144.73, 'close': 146.06, 'volume': 192059000, 'adjusted': 144.65 }, + { 'date': 15708, 'open': 145.99, 'high': 146.37, 'low': 145.34, 'close': 145.73, 'volume': 144761800, 'adjusted': 144.32 }, + ] + } + ], + boxPlotChart: [ + { + label: 'Sample A', + values: { + Q1: 180, + Q2: 200, + Q3: 250, + whisker_low: 115, + whisker_high: 400, + outliers: [50, 100, 425] + } + } + ], + multiChart: [ + { + key: 'Stream1', + type: 'area', + yAxis: 1, + values: [{ x: 0, y: 1 }, { x: 1, y: 2 }] + }, + { + key: 'Stream2', + type: 'area', + yAxis: 1, + values: [{ x: 0, y: 2 }, { x: 1, y: 3 }] + }, + { + key: 'Stream3', + type: 'line', + yAxis: 1, + values: [{ x: 0, y: 3 }, { x: 1, y: 5 }] + }, + { + key: 'Stream4', + type: 'line', + yAxis: 2, + values: [{ x: 0, y: 3 }, { x: 1, y: 5 }] + }, + { + key: 'Stream4', + type: 'bar', + yAxis: 2, + values: [{ x: 0, y: 3 }, { x: 1, y: 5 }] + } + ], + sunburstChart: [{ + 'name': 'flare', + 'children': [ + { + 'name': 'analytics', + 'children': [ + { + 'name': 'cluster', + 'children': [ + { 'name': 'AgglomerativeCluster', 'size': 3938 }, + { 'name': 'CommunityStructure', 'size': 3812 }, + { 'name': 'HierarchicalCluster', 'size': 6714 }, + { 'name': 'MergeEdge', 'size': 743 } + ] + }, + { + 'name': 'graph', + 'children': [ + { 'name': 'BetweennessCentrality', 'size': 3534 }, + { 'name': 'LinkDistance', 'size': 5731 }, + { 'name': 'MaxFlowMinCut', 'size': 7840 }, + { 'name': 'ShortestPaths', 'size': 5914 }, + { 'name': 'SpanningTree', 'size': 3416 } + ] + }, + { + 'name': 'optimization', + 'children': [ + { 'name': 'AspectRatioBanker', 'size': 7074 } + ] + } + ] + } + ] + }], + stackedAreaChart: [ + { + 'key': 'North America', + 'values': [[1025409600000, 23.041422681023], [1028088000000, 19.854291255832]] + }, + { + 'key': 'Africa', + 'values': [[1025409600000, 7.9356392949025], [1028088000000, 7.4514668527298]] + } + ], + multiBarHorizontalChart: [ + { + 'key': 'Series1', + 'values': [ + { + 'label': 'Group A', + 'value': -1.8746444827653 + }, + { + 'label': 'Group B', + 'value': -8.0961543492239 + } + ] + }, + { + 'key': 'Series2', + 'values': [ + { + 'label': 'Group A', + 'value': 25.307646510375 + }, + { + 'label': 'Group B', + 'value': 16.756779544553 + } + ] + } + ], + cumulativeLineChart: [ + { + key: 'Long', + values: [[1083297600000, -2.974623048543], [1085976000000, -1.7740300785979]], + mean: 250 + }, + { + key: 'Short', + values: [[1083297600000, -0.77078283705125], [1085976000000, -1.8356366650335]], + mean: -60 + } + ], + historicalBarChart: [ + { + 'key': 'Quantity', + 'bar': true, + 'values': [[1136005200000, 1271000.0], [1138683600000, 1271000.0], [1141102800000, 1271000.0]] + } + ], + parallelCoordinates: [ + { + 'name': 'AMC Ambassador Brougham', + 'economy (mpg)': '13', + 'cylinders': '8', + 'displacement (cc)': '360', + 'power (hp)': '175', + 'weight (lb)': '3821', + '0-60 mph (s)': '11', + 'year': '73' + }, + { + 'name': 'AMC Ambassador DPL', + 'economy (mpg)': '15', + 'cylinders': '8', + 'displacement (cc)': '390', + 'power (hp)': '190', + 'weight (lb)': '3850', + '0-60 mph (s)': '8.5', + 'year': '70' + } + ], + sparklinePlus: [{ x: 1083297600000, y: 2.974623048543 }, { x: 1085976000000, y: 1.7740300785979 }], + bulletChart: { + 'title': 'Revenue', + 'subtitle': 'US$, in thousands', + 'ranges': [150, 225, 300], + 'measures': [220], + 'markers': [250] + }, + linePlusBarWithFocusChart: [ + { + 'key': 'Quantity', + 'bar': true, + 'values': [{ x: 1083297600000, y: 2.974623048543 }, { x: 1085976000000, y: 1.7740300785979 }] + }, + { + 'key': 'Price', + 'values': [{ x: 1083297600000, y: 2.974623048543 }, { x: 1085976000000, y: 1.7740300785979 }] + } + ], + forceDirectedGraph: { + 'nodes': [ + { 'name': 'Myriel', 'group': 1 }, + { 'name': 'Napoleon', 'group': 1 }, + { 'name': 'Labarre', 'group': 2 }, + { 'name': 'Valjean', 'group': 2 }, + { 'name': 'Marguerite', 'group': 3 }, + { 'name': 'Mme.deR', 'group': 3 } + ], + 'links': [ + { 'source': 1, 'target': 0, 'value': 1 }, + { 'source': 2, 'target': 0, 'value': 8 }, + { 'source': 3, 'target': 1, 'value': 10 }, + { 'source': 3, 'target': 2, 'value': 6 }, + { 'source': 4, 'target': 0, 'value': 1 }, + { 'source': 5, 'target': 3, 'value': 1 } + ] + } + }; + SampleData.chartClassExpected = { + lineChart: 'nv-lineChart', + discreteBarChart: 'nv-discreteBarWithAxes', + pieChart: 'nv-pieChart', + scatterChart: 'nv-scatterChart', + multiBarChart: 'nv-multiBarWithLegend', + multiBarHorizontalChart: 'nv-multiBarHorizontalChart', + candlestickBarChart: 'nv-historicalBarChart', + ohlcBarChart: 'nv-historicalBarChar', + boxPlotChart: 'nv-boxPlotWithAxes', + multiChart: 'multiChart', + sunburstChart: 'nv-sunburst', + stackedAreaChart: 'nv-stackedAreaChart', + cumulativeLineChart: 'nv-cumulativeLine', + historicalBarChart: 'nv-historicalBarChart', + parallelCoordinates: 'nv-parallelCoordinates', + sparklinePlus: 'nv-sparklineplus', + bulletChart: 'nv-bulletChart', + linePlusBarWithFocusChart: 'nv-linePlusBar', + forceDirectedGraph: 'nv-force-node' + }; +})(SampleData = exports.SampleData || (exports.SampleData = {})); diff --git a/karma.conf.js b/karma.conf.js index 50ad0ce..5819ffc 100644 --- a/karma.conf.js +++ b/karma.conf.js @@ -12,13 +12,11 @@ module.exports = function (config) { require('karma-phantomjs-launcher') ], files: [ - 'polyfills.browser.ts', - 'src/**/*.spec.ts' + 'src/test/test.ts' ], exclude: [], preprocessors: { - 'polyfills.browser.ts': ['webpack'], - 'src/test/*.spec.ts': ['webpack'] + 'src/test/test.ts': ['webpack'] }, webpack: { module: webpackConfig.module, diff --git a/src/test/angular2-nvd3.component.spec.ts b/src/test/angular2-nvd3.component.spec.ts index 77fe0ed..e2a8e40 100644 --- a/src/test/angular2-nvd3.component.spec.ts +++ b/src/test/angular2-nvd3.component.spec.ts @@ -1,31 +1,47 @@ import { ComponentFixture, TestBed } from '@angular/core/testing'; -import { By } from '@angular/platform-browser'; -import { DebugElement } from '@angular/core'; -import { NvD3Component } from '../angular2-nvd3/angular2-nvd3.component'; +import { NvD3Component } from '../angular2-nvd3/angular2-nvd3.component'; +import { By } from '@angular/platform-browser'; +import { DebugElement } from '@angular/core'; +import { SampleData } from './sample-data'; -describe('tasks:NvD3Component', () => { +SampleData.chartTypes.forEach((type) => { - let comp: NvD3Component; - let fixture: ComponentFixture; + describe(`tasks:NvD3Component ${type}`, () => { - beforeEach(() => { - TestBed.configureTestingModule({ - declarations: [ NvD3Component ], // declare the test component - }); + let component: NvD3Component; + let fixture: ComponentFixture; + let componentElement: Element; - // fixture = TestBed.createComponent(NvD3Component); + beforeEach(() => { + TestBed.configureTestingModule({ + declarations: [NvD3Component], // declare the test component + }); - // comp = fixture.componentInstance; // NvD3Component test instance - }); + fixture = TestBed.createComponent(NvD3Component); + component = fixture.componentInstance; // NvD3Component test instance - it('should call ngOnChanges', () => { - // fixture.detectChanges(); - // expect(comp.ngOnChanges).toHaveBeenCalled(); - }); + // pretend that it was wired to something + component.options = SampleData.allOptions[type]; + component.data = SampleData.allData[type]; + // trigger initial data binding + fixture.detectChanges(); + + componentElement = fixture.nativeElement; + }); - it('should call ngOnInit', () => { - // fixture.detectChanges(); - // expect(comp.ngOnInit).toHaveBeenCalled(); + it(`should have svg`, () => { + expect(componentElement.querySelectorAll('svg').length).toBe(1); + }); + + it('should svg have class nvd3-svg', () => { + let gElement = componentElement.querySelector('svg'); + expect(gElement.classList).toContain('nvd3-svg'); + }); + + it(`should g have class nv-${type}`, () => { + let gElement = componentElement.querySelector('g'); + expect(gElement.className.baseVal).toContain(SampleData.chartClassExpected[type]); + }); }); }); \ No newline at end of file diff --git a/src/test/angular2-nvd3.directive.spec.ts b/src/test/angular2-nvd3.directive.spec.ts new file mode 100644 index 0000000..664bb42 --- /dev/null +++ b/src/test/angular2-nvd3.directive.spec.ts @@ -0,0 +1,48 @@ +import { NO_ERRORS_SCHEMA } from '@angular/core'; +import { ComponentFixture, TestBed } from '@angular/core/testing'; +import { NvD3Directive } from '../angular2-nvd3/angular2-nvd3.directive'; +import { TestComponent } from './test.component'; +import { By } from '@angular/platform-browser'; +import { DebugElement } from '@angular/core'; +import { SampleData } from './sample-data'; + +SampleData.chartTypes.forEach((type) => { + describe(`tasks:NvD3Directive ${type}`, () => { + let component: TestComponent; + let fixture: ComponentFixture; + let componentElement: Element; + + beforeEach(() => { + TestBed.configureTestingModule({ + declarations: [ TestComponent, NvD3Directive ], // declare the test component + schemas: [ NO_ERRORS_SCHEMA ] + }); + + fixture = TestBed.createComponent(TestComponent); + component = fixture.componentInstance; // NvD3Directive test instance + + // pretend that it was wired to something + component.options = SampleData.allOptions[type]; + component.data = SampleData.allData[type]; + // trigger initial data binding + fixture.detectChanges(); + + componentElement = fixture.nativeElement; + }); + + it(`should have svg`, () => { + expect(componentElement.querySelectorAll('svg').length).toBe(1); + }); + + it('should svg have class nvd3-svg', () => { + let gElement = componentElement.querySelector('svg'); + expect(gElement.classList).toContain('nvd3-svg'); + }); + + it(`should g have class nv-${type}`, () => { + let gElement = componentElement.querySelector('g'); + expect(gElement.className.baseVal).toContain(SampleData.chartClassExpected[type]); + }); + }); + +}); \ No newline at end of file diff --git a/polyfills.browser.ts b/src/test/polyfills.ts similarity index 53% rename from polyfills.browser.ts rename to src/test/polyfills.ts index c1794f3..864e319 100644 --- a/polyfills.browser.ts +++ b/src/test/polyfills.ts @@ -1,10 +1,5 @@ // Polyfills -// import 'ie-shim'; // Internet Explorer 9 support - - -// import 'core-js/es6'; -// Added parts of es6 which are necessary for your project or your browser support requirements. import 'core-js/es6/symbol'; import 'core-js/es6/object'; import 'core-js/es6/function'; @@ -18,16 +13,7 @@ import 'core-js/es6/array'; import 'core-js/es6/regexp'; import 'core-js/es6/map'; import 'core-js/es6/set'; -import 'core-js/es6/weak-map'; -import 'core-js/es6/weak-set'; -import 'core-js/es6/typed'; import 'core-js/es6/reflect'; -// import 'core-js/es6/promise'; import 'core-js/es7/reflect'; import 'zone.js/dist/zone'; - -// test further -import 'zone.js/dist/sync-test'; -import 'zone.js/dist/proxy'; -import 'zone.js/dist/jasmine-patch'; \ No newline at end of file diff --git a/src/test/sample-data.ts b/src/test/sample-data.ts new file mode 100644 index 0000000..87dede5 --- /dev/null +++ b/src/test/sample-data.ts @@ -0,0 +1,447 @@ +import * as d3 from 'd3'; + +export namespace SampleData { + export const chartTypes = [ + 'lineChart', + 'discreteBarChart', + 'pieChart', + 'scatterChart', + 'multiBarChart', + 'multiBarHorizontalChart', + 'candlestickBarChart', + 'ohlcBarChart', + 'boxPlotChart', + 'multiChart', + 'sunburstChart', + 'stackedAreaChart', + 'cumulativeLineChart', + 'historicalBarChart', + 'parallelCoordinates', + 'sparklinePlus', + 'bulletChart', + 'linePlusBarWithFocusChart', + 'forceDirectedGraph' + ]; + export const allOptions = { + lineChart: { + chart: { + type: 'lineChart', + height: 450, + x: function (d) { return d.x; }, + y: function (d) { return d.y; } + } + }, + discreteBarChart: { + chart: { + type: 'discreteBarChart', + height: 450, + x: function (d) { return d.label; }, + y: function (d) { return d.value; } + } + }, + pieChart: { + chart: { + type: 'pieChart', + height: 500, + x: function (d) { return d.key; }, + y: function (d) { return d.y; } + } + }, + scatterChart: { + chart: { + type: 'scatterChart', + height: 450 + } + }, + multiBarChart: { + chart: { + type: 'multiBarChart', + height: 450, + stacked: true + } + }, + candlestickBarChart: { + chart: { + type: 'candlestickBarChart', + height: 450, + x: function (d) { return d['date']; }, + y: function (d) { return d['close']; } + } + }, + ohlcBarChart: { + chart: { + type: 'ohlcBarChart', + height: 450, + x: function (d) { return d['date']; }, + y: function (d) { return d['close']; } + } + }, + boxPlotChart: { + chart: { + type: 'boxPlotChart', + height: 450, + x: function (d) { return d.label; } + } + }, + multiChart: { + chart: { + type: 'multiChart', + height: 450 + } + }, + sunburstChart: { + chart: { + type: 'sunburstChart', + height: 450 + } + }, + stackedAreaChart: { + chart: { + type: 'stackedAreaChart', + height: 450, + x: function (d) { return d[0]; }, + y: function (d) { return d[1]; } + } + }, + multiBarHorizontalChart: { + chart: { + type: 'multiBarHorizontalChart', + height: 450, + x: function (d) { return d.label; }, + y: function (d) { return d.value; } + } + }, + + cumulativeLineChart: { + chart: { + type: 'cumulativeLineChart', + height: 450, + x: function (d) { return d[0]; }, + y: function (d) { return d[1] / 100; }, + average: function (d) { return d.mean / 100; } + } + }, + historicalBarChart: { + chart: { + type: 'historicalBarChart', + height: 450, + x: function (d) { return d[0]; }, + y: function (d) { return d[1] / 100000; } + } + }, + parallelCoordinates: { + chart: { + type: 'parallelCoordinates', + height: 450, + dimensionData: [ + 'economy (mpg)', + 'cylinders', + 'displacement (cc)', + 'power (hp)', + 'weight (lb)', + '0-60 mph (s)', + 'year' + ] + } + }, + sparklinePlus: { + chart: { + type: 'sparklinePlus', + height: 450, + x: function (d, i) { return i; } + } + }, + bulletChart: { + chart: { + type: 'bulletChart', + height: 450 + } + }, + linePlusBarWithFocusChart: { + chart: { + type: 'linePlusBarChart', + height: 500, + color: ['#2ca02c', 'darkred'], + x: function (d, i) { return i; } + } + }, + forceDirectedGraph: { + chart: { + type: 'forceDirectedGraph' + } + } + }; + + export const allData = { + lineChart: [ + { key: 'key1', values: [{ x: 0, y: 0 }, { x: 1, y: 1 }] }, + { key: 'key2', values: [{ x: 1, y: 1 }, { x: 0, y: 0 }] } + ], + discreteBarChart: [ + { + key: 'Cumulative Return', + values: [ + { 'label': 'A', 'value': 10 }, + { 'label': 'B', 'value': 20 } + ] + } + ], + pieChart: [ + { key: 'One', y: 5 }, + { key: 'Two', y: 2 } + ], + scatterChart: [ + { key: 'key1', values: [{ x: 0, y: 0 }, { x: 1, y: 1 }] }, + { key: 'key2', values: [{ x: 1, y: 1 }, { x: 0, y: 0 }] } + ], + multiBarChart: [ + { + key: 'Sent', + values: [{ x: 0, y: 1 }, { x: 1, y: 2 }] + }, + { + key: 'Received', + values: [{ x: 0, y: 2 }, { x: 1, y: 3 }] + }, + { + key: 'Spam', + values: [{ x: 0, y: 3 }, { x: 1, y: 5 }] + } + ], + candlestickBarChart: [{ + values: [ + { 'date': 15854, 'open': 165.42, 'high': 165.8, 'low': 164.34, 'close': 165.22, 'volume': 160363400, 'adjusted': 164.35 }, + { 'date': 15855, 'open': 165.35, 'high': 166.59, 'low': 165.22, 'close': 165.83, 'volume': 107793800, 'adjusted': 164.96 } + ] + } + ], + ohlcBarChart: [{ + values: [ + { 'date': 15707, 'open': 145.11, 'high': 146.15, 'low': 144.73, 'close': 146.06, 'volume': 192059000, 'adjusted': 144.65 }, + { 'date': 15708, 'open': 145.99, 'high': 146.37, 'low': 145.34, 'close': 145.73, 'volume': 144761800, 'adjusted': 144.32 }, + ] + } + ], + boxPlotChart: [ + { + label: 'Sample A', + values: { + Q1: 180, + Q2: 200, + Q3: 250, + whisker_low: 115, + whisker_high: 400, + outliers: [50, 100, 425] + } + } + ], + multiChart: [ + { + key: 'Stream1', + type: 'area', + yAxis: 1, + values: [{ x: 0, y: 1 }, { x: 1, y: 2 }] + }, + { + key: 'Stream2', + type: 'area', + yAxis: 1, + values: [{ x: 0, y: 2 }, { x: 1, y: 3 }] + }, + { + key: 'Stream3', + type: 'line', + yAxis: 1, + values: [{ x: 0, y: 3 }, { x: 1, y: 5 }] + }, + { + key: 'Stream4', + type: 'line', + yAxis: 2, + values: [{ x: 0, y: 3 }, { x: 1, y: 5 }] + }, + { + key: 'Stream4', + type: 'bar', + yAxis: 2, + values: [{ x: 0, y: 3 }, { x: 1, y: 5 }] + } + ], + sunburstChart: [{ + 'name': 'flare', + 'children': [ + { + 'name': 'analytics', + 'children': [ + { + 'name': 'cluster', + 'children': [ + { 'name': 'AgglomerativeCluster', 'size': 3938 }, + { 'name': 'CommunityStructure', 'size': 3812 }, + { 'name': 'HierarchicalCluster', 'size': 6714 }, + { 'name': 'MergeEdge', 'size': 743 } + ] + }, + { + 'name': 'graph', + 'children': [ + { 'name': 'BetweennessCentrality', 'size': 3534 }, + { 'name': 'LinkDistance', 'size': 5731 }, + { 'name': 'MaxFlowMinCut', 'size': 7840 }, + { 'name': 'ShortestPaths', 'size': 5914 }, + { 'name': 'SpanningTree', 'size': 3416 } + ] + }, + { + 'name': 'optimization', + 'children': [ + { 'name': 'AspectRatioBanker', 'size': 7074 } + ] + } + ] + } + ] + }], + stackedAreaChart: [ + { + 'key': 'North America', + 'values': [[1025409600000, 23.041422681023], [1028088000000, 19.854291255832]] + }, + { + 'key': 'Africa', + 'values': [[1025409600000, 7.9356392949025], [1028088000000, 7.4514668527298]] + } + ], + multiBarHorizontalChart: [ + { + 'key': 'Series1', + 'values': [ + { + 'label': 'Group A', + 'value': -1.8746444827653 + }, + { + 'label': 'Group B', + 'value': -8.0961543492239 + } + ] + }, + { + 'key': 'Series2', + 'values': [ + { + 'label': 'Group A', + 'value': 25.307646510375 + }, + { + 'label': 'Group B', + 'value': 16.756779544553 + } + ] + } + ], + + cumulativeLineChart: [ + { + key: 'Long', + values: [[1083297600000, -2.974623048543], [1085976000000, -1.7740300785979]] + , + mean: 250 + }, + { + key: 'Short', + values: [[1083297600000, -0.77078283705125], [1085976000000, -1.8356366650335]] + , + mean: -60 + } + ], + historicalBarChart: [ + { + 'key': 'Quantity', + 'bar': true, + 'values': [[1136005200000, 1271000.0], [1138683600000, 1271000.0], [1141102800000, 1271000.0]] + } + ], + parallelCoordinates: [ + { + 'name': 'AMC Ambassador Brougham', + 'economy (mpg)': '13', + 'cylinders': '8', + 'displacement (cc)': '360', + 'power (hp)': '175', + 'weight (lb)': '3821', + '0-60 mph (s)': '11', + 'year': '73' + }, + { + 'name': 'AMC Ambassador DPL', + 'economy (mpg)': '15', + 'cylinders': '8', + 'displacement (cc)': '390', + 'power (hp)': '190', + 'weight (lb)': '3850', + '0-60 mph (s)': '8.5', + 'year': '70' + } + ], + sparklinePlus: [{ x: 1083297600000, y: 2.974623048543 }, { x: 1085976000000, y: 1.7740300785979 }], + bulletChart: { + 'title': 'Revenue', + 'subtitle': 'US$, in thousands', + 'ranges': [150, 225, 300], + 'measures': [220], + 'markers': [250] + }, + linePlusBarWithFocusChart: [ + { + 'key': 'Quantity', + 'bar': true, + 'values': [{ x: 1083297600000, y: 2.974623048543 }, { x: 1085976000000, y: 1.7740300785979 }] + }, + { + 'key': 'Price', + 'values': [{ x: 1083297600000, y: 2.974623048543 }, { x: 1085976000000, y: 1.7740300785979 }] + } + ], + forceDirectedGraph: { + 'nodes': [ + { 'name': 'Myriel', 'group': 1 }, + { 'name': 'Napoleon', 'group': 1 }, + { 'name': 'Labarre', 'group': 2 }, + { 'name': 'Valjean', 'group': 2 }, + { 'name': 'Marguerite', 'group': 3 }, + { 'name': 'Mme.deR', 'group': 3 } + ], + 'links': [ + { 'source': 1, 'target': 0, 'value': 1 }, + { 'source': 2, 'target': 0, 'value': 8 }, + { 'source': 3, 'target': 1, 'value': 10 }, + { 'source': 3, 'target': 2, 'value': 6 }, + { 'source': 4, 'target': 0, 'value': 1 }, + { 'source': 5, 'target': 3, 'value': 1 } + ] + } + }; + + export const chartClassExpected = { + lineChart: 'nv-lineChart', + discreteBarChart: 'nv-discreteBarWithAxes', + pieChart: 'nv-pieChart', + scatterChart: 'nv-scatterChart', + multiBarChart: 'nv-multiBarWithLegend', + multiBarHorizontalChart: 'nv-multiBarHorizontalChart', + candlestickBarChart: 'nv-historicalBarChart', + ohlcBarChart: 'nv-historicalBarChar', + boxPlotChart: 'nv-boxPlotWithAxes', + multiChart: 'multiChart', + sunburstChart: 'nv-sunburst', + stackedAreaChart: 'nv-stackedAreaChart', + cumulativeLineChart: 'nv-cumulativeLine', + historicalBarChart: 'nv-historicalBarChart', + parallelCoordinates: 'nv-parallelCoordinates', + sparklinePlus: 'nv-sparklineplus', + bulletChart: 'nv-bulletChart', + linePlusBarWithFocusChart: 'nv-linePlusBar', + forceDirectedGraph: 'nv-force-node' + }; +} diff --git a/src/test/test.component.ts b/src/test/test.component.ts new file mode 100644 index 0000000..e7d086e --- /dev/null +++ b/src/test/test.component.ts @@ -0,0 +1,8 @@ +import { Component, DebugElement } from '@angular/core'; + +@Component({ template: `
` }) +/** experimanetalDecorator */ +export class TestComponent { + public options: any; + public data: any; +} diff --git a/src/test/test.ts b/src/test/test.ts new file mode 100644 index 0000000..0c1e929 --- /dev/null +++ b/src/test/test.ts @@ -0,0 +1,32 @@ +import './polyfills.ts'; + +import 'zone.js/dist/long-stack-trace-zone'; +import 'zone.js/dist/proxy.js'; +import 'zone.js/dist/sync-test'; +import 'zone.js/dist/jasmine-patch'; +import 'zone.js/dist/async-test'; +import 'zone.js/dist/fake-async-test'; +import { getTestBed } from '@angular/core/testing'; +import { + BrowserDynamicTestingModule, + platformBrowserDynamicTesting +} from '@angular/platform-browser-dynamic/testing'; + +// Unfortunately there's no typing for the `__karma__` variable. Just declare it as any. +declare var __karma__: any; +declare var require: any; + +// Prevent Karma from running prematurely. +__karma__.loaded = function () {}; + +// First, initialize the Angular testing environment. +getTestBed().initTestEnvironment( + BrowserDynamicTestingModule, + platformBrowserDynamicTesting() +); +// Then we find all the tests. +let context = require.context('./', true, /\.spec\.ts$/); +// And load the modules. +context.keys().map(context); +// Finally, start Karma to run the tests. +__karma__.start(); \ No newline at end of file