mirror of
				https://github.com/billz/raspap-webgui.git
				synced 2025-03-01 10:31:47 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			212 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			CoffeeScript
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			212 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			CoffeeScript
		
	
	
		
			Executable File
		
	
	
	
	
| describe 'Morris.Line', ->
 | |
| 
 | |
|   it 'should raise an error when the placeholder element is not found', ->
 | |
|     my_data = [{x: 1, y: 1}, {x: 2, y: 2}]
 | |
|     fn = ->
 | |
|       Morris.Line(
 | |
|         element: "thisplacedoesnotexist"
 | |
|         data: my_data
 | |
|         xkey: 'x'
 | |
|         ykeys: ['y']
 | |
|         labels: ['dontcare']
 | |
|       )
 | |
|     fn.should.throw(/Graph container element not found/)
 | |
| 
 | |
|   it 'should make point styles customizable', ->
 | |
|     my_data = [{x: 1, y: 1}, {x: 2, y: 2}]
 | |
|     red = '#ff0000'
 | |
|     blue = '#0000ff'
 | |
|     chart = Morris.Line
 | |
|       element: 'graph'
 | |
|       data: my_data
 | |
|       xkey: 'x'
 | |
|       ykeys: ['y']
 | |
|       labels: ['dontcare']
 | |
|       pointStrokeColors: [red, blue]
 | |
|       pointStrokeWidths: [1, 2]
 | |
|       pointFillColors: [null, red]
 | |
|     chart.pointStrokeWidthForSeries(0).should.equal 1
 | |
|     chart.pointStrokeColorForSeries(0).should.equal red
 | |
|     chart.pointStrokeWidthForSeries(1).should.equal 2
 | |
|     chart.pointStrokeColorForSeries(1).should.equal blue
 | |
|     chart.colorFor(chart.data[0], 0, 'point').should.equal chart.colorFor(chart.data[0], 0, 'line')
 | |
|     chart.colorFor(chart.data[1], 1, 'point').should.equal red
 | |
| 
 | |
|   describe 'generating column labels', ->
 | |
| 
 | |
|     it 'should use user-supplied x value strings by default', ->
 | |
|       chart = Morris.Line
 | |
|         element: 'graph'
 | |
|         data: [{x: '2012 Q1', y: 1}, {x: '2012 Q2', y: 1}]
 | |
|         xkey: 'x'
 | |
|         ykeys: ['y']
 | |
|         labels: ['dontcare']
 | |
|       chart.data.map((x) -> x.label).should == ['2012 Q1', '2012 Q2']
 | |
| 
 | |
|     it 'should use a default format for timestamp x-values', ->
 | |
|       d1 = new Date(2012, 0, 1)
 | |
|       d2 = new Date(2012, 0, 2)
 | |
|       chart = Morris.Line
 | |
|         element: 'graph'
 | |
|         data: [{x: d1.getTime(), y: 1}, {x: d2.getTime(), y: 1}]
 | |
|         xkey: 'x'
 | |
|         ykeys: ['y']
 | |
|         labels: ['dontcare']
 | |
|       chart.data.map((x) -> x.label).should == [d2.toString(), d1.toString()]
 | |
| 
 | |
|     it 'should use user-defined formatters', ->
 | |
|       d = new Date(2012, 0, 1)
 | |
|       chart = Morris.Line
 | |
|         element: 'graph'
 | |
|         data: [{x: d.getTime(), y: 1}, {x: '2012-01-02', y: 1}]
 | |
|         xkey: 'x'
 | |
|         ykeys: ['y']
 | |
|         labels: ['dontcare']
 | |
|         dateFormat: (d) ->
 | |
|           x = new Date(d)
 | |
|           "#{x.getYear()}/#{x.getMonth()+1}/#{x.getDay()}"
 | |
|       chart.data.map((x) -> x.label).should == ['2012/1/1', '2012/1/2']
 | |
| 
 | |
|   describe 'rendering lines', ->
 | |
|     beforeEach ->
 | |
|       @defaults =
 | |
|         element: 'graph'
 | |
|         data: [{x:0, y:1, z:0}, {x:1, y:0, z:1}, {x:2, y:1, z:0}, {x:3, y:0, z:1}, {x:4, y:1, z:0}]
 | |
|         xkey: 'x'
 | |
|         ykeys: ['y', 'z']
 | |
|         labels: ['y', 'z']
 | |
|         lineColors: ['#abcdef', '#fedcba']
 | |
|         smooth: true
 | |
| 
 | |
|     shouldHavePath = (regex, color = '#abcdef') ->
 | |
|       # Matches an SVG path element within the rendered chart.
 | |
|       #
 | |
|       # Sneakily uses line colors to differentiate between paths within
 | |
|       # the chart.
 | |
|       $('#graph').find("path[stroke='#{color}']").attr('d').should.match regex
 | |
| 
 | |
|     it 'should generate smooth lines when options.smooth is true', ->
 | |
|       Morris.Line @defaults
 | |
|       shouldHavePath /M[\d\.]+,[\d\.]+(C[\d\.]+(,[\d\.]+){5}){4}/
 | |
| 
 | |
|     it 'should generate jagged lines when options.smooth is false', ->
 | |
|       Morris.Line $.extend(@defaults, smooth: false)
 | |
|       shouldHavePath /M[\d\.]+,[\d\.]+(L[\d\.]+,[\d\.]+){4}/
 | |
| 
 | |
|     it 'should generate smooth/jagged lines according to the value for each series when options.smooth is an array', ->
 | |
|       Morris.Line $.extend(@defaults, smooth: ['y'])
 | |
|       shouldHavePath /M[\d\.]+,[\d\.]+(C[\d\.]+(,[\d\.]+){5}){4}/, '#abcdef'
 | |
|       shouldHavePath /M[\d\.]+,[\d\.]+(L[\d\.]+,[\d\.]+){4}/, '#fedcba'
 | |
| 
 | |
|     it 'should ignore undefined values', ->
 | |
|       @defaults.data[2].y = undefined
 | |
|       Morris.Line @defaults
 | |
|       shouldHavePath /M[\d\.]+,[\d\.]+(C[\d\.]+(,[\d\.]+){5}){3}/
 | |
| 
 | |
|     it 'should break the line at null values', ->
 | |
|       @defaults.data[2].y = null
 | |
|       Morris.Line @defaults
 | |
|       shouldHavePath /(M[\d\.]+,[\d\.]+C[\d\.]+(,[\d\.]+){5}){2}/
 | |
| 
 | |
|     it 'should make line width customizable', ->
 | |
|       chart = Morris.Line $.extend(@defaults, lineWidth: [1, 2])
 | |
|       chart.lineWidthForSeries(0).should.equal 1
 | |
|       chart.lineWidthForSeries(1).should.equal 2
 | |
| 
 | |
|   describe '#createPath', ->
 | |
| 
 | |
|     it 'should generate a smooth line', ->
 | |
|       testData = [{x: 0, y: 10}, {x: 10, y: 0}, {x: 20, y: 10}]
 | |
|       path = Morris.Line.createPath(testData, true, 20)
 | |
|       path.should.equal 'M0,10C2.5,7.5,7.5,0,10,0C12.5,0,17.5,7.5,20,10'
 | |
| 
 | |
|     it 'should generate a jagged line', ->
 | |
|       testData = [{x: 0, y: 10}, {x: 10, y: 0}, {x: 20, y: 10}]
 | |
|       path = Morris.Line.createPath(testData, false, 20)
 | |
|       path.should.equal 'M0,10L10,0L20,10'
 | |
| 
 | |
|     it 'should prevent paths from descending below the bottom of the chart', ->
 | |
|       testData = [{x: 0, y: 20}, {x: 10, y: 30}, {x: 20, y: 10}]
 | |
|       path = Morris.Line.createPath(testData, true, 30)
 | |
|       path.should.equal 'M0,20C2.5,22.5,7.5,30,10,30C12.5,28.75,17.5,15,20,10'
 | |
| 
 | |
|     it 'should break the line at null values', ->
 | |
|       testData = [{x: 0, y: 10}, {x: 10, y: 0}, {x: 20, y: null}, {x: 30, y: 10}, {x: 40, y: 0}]
 | |
|       path = Morris.Line.createPath(testData, true, 20)
 | |
|       path.should.equal 'M0,10C2.5,7.5,7.5,2.5,10,0M30,10C32.5,7.5,37.5,2.5,40,0'
 | |
| 
 | |
|     it 'should ignore leading and trailing null values', ->
 | |
|       testData = [{x: 0, y: null}, {x: 10, y: 10}, {x: 20, y: 0}, {x: 30, y: 10}, {x: 40, y: null}]
 | |
|       path = Morris.Line.createPath(testData, true, 20)
 | |
|       path.should.equal 'M10,10C12.5,7.5,17.5,0,20,0C22.5,0,27.5,7.5,30,10'
 | |
| 
 | |
|   describe 'svg structure', ->
 | |
|     defaults =
 | |
|       element: 'graph'
 | |
|       data: [{x: '2012 Q1', y: 1}, {x: '2012 Q2', y: 1}]
 | |
|       lineColors: [ '#0b62a4', '#7a92a3']
 | |
|       xkey: 'x'
 | |
|       ykeys: ['y']
 | |
|       labels: ['dontcare']
 | |
| 
 | |
|     it 'should contain a path that represents the line', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("path[stroke='#0b62a4']").size().should.equal 1
 | |
| 
 | |
|     it 'should contain a circle for each data point', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("circle").size().should.equal 2
 | |
| 
 | |
|     it 'should contain 5 grid lines', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("path[stroke='#aaaaaa']").size().should.equal 5
 | |
| 
 | |
|     it 'should contain 9 text elements', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("text").size().should.equal 9
 | |
| 
 | |
|   describe 'svg attributes', ->
 | |
|     defaults =
 | |
|       element: 'graph'
 | |
|       data: [{x: '2012 Q1', y: 1}, {x: '2012 Q2', y: 1}]
 | |
|       xkey: 'x'
 | |
|       ykeys: ['y', 'z']
 | |
|       labels: ['Y', 'Z']
 | |
|       lineColors: [ '#0b62a4', '#7a92a3']
 | |
|       lineWidth: 3
 | |
|       pointStrokeWidths: [5]
 | |
|       pointStrokeColors: ['#ffffff']
 | |
|       gridLineColor: '#aaa'
 | |
|       gridStrokeWidth: 0.5
 | |
|       gridTextColor: '#888'
 | |
|       gridTextSize: 12
 | |
|       pointSize: [5]
 | |
| 
 | |
|     it 'should have circles with configured fill color', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("circle[fill='#0b62a4']").size().should.equal 2
 | |
| 
 | |
|     it 'should have circles with configured stroke width', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("circle[stroke-width='5']").size().should.equal 2
 | |
| 
 | |
|     it 'should have circles with configured stroke color', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("circle[stroke='#ffffff']").size().should.equal 2
 | |
| 
 | |
|     it 'should have line with configured line width', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("path[stroke-width='3']").size().should.equal 1
 | |
| 
 | |
|     it 'should have text with configured font size', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("text[font-size='12px']").size().should.equal 9
 | |
| 
 | |
|     it 'should have text with configured font size', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("text[fill='#888888']").size().should.equal 9
 | |
| 
 | |
|     it 'should have circle with configured size', ->
 | |
|       chart = Morris.Line $.extend {}, defaults
 | |
|       $('#graph').find("circle[r='5']").size().should.equal 2
 |