/** * Created by knut on 14-11-23. */ var utils = require('./utils') // var log = require('./logger').create(); describe('when detecting chart type ', function () { var str beforeEach(function () { }) it('should handle a graph defintion', function () { str = 'graph TB\nbfs1:queue' var type = utils.detectType(str) expect(type).toBe('graph') }) it('should handle a graph defintion with leading spaces', function () { str = ' graph TB\nbfs1:queue' var type = utils.detectType(str) expect(type).toBe('graph') }) it('should handle a graph defintion with leading spaces and newline', function () { str = ' \n graph TB\nbfs1:queue' var type = utils.detectType(str) expect(type).toBe('graph') }) it('should handle a graph defintion for gitGraph', function () { str = ' \n gitGraph TB:\nbfs1:queue' var type = utils.detectType(str) expect(type).toBe('gitGraph') }) }) describe('when cloning CSS ', function () { beforeEach(function () { // var MockBrowser = require('mock-browser').mocks.MockBrowser; // var mock = new MockBrowser(); // and in the run-code inside some object // global.document = mock.getDocument(); document.body.innerHTML = '' }) function stylesToArray (svg) { var styleSheets = svg.getElementsByTagName('style') expect(styleSheets.length).toBe(1) var styleSheet = styleSheets[0] var innerStyle = styleSheet.innerHTML var styleArr = innerStyle.split('\n') // Remove first and last two lines to remove the CDATA expect(styleArr.length).toBeGreaterThan(2) var styleArrTrim = styleArr.slice(1, -2) // Remove all empty lines for (var i = 0; i < styleArrTrim.length; i++) { if (styleArrTrim[i].trim() === '') { styleArrTrim.splice(i, 1) i-- } styleArrTrim[i] = styleArrTrim[i].trim() } return styleArrTrim } function addStyleToDocument () { var s = document.createElement('style') s.innerHTML = '.node { stroke:#eeeeee; }\n.node-square { stroke:#bbbbbb; }\n' document.body.appendChild(s) } function addSecondStyleToDocument () { var s = document.createElement('style') s.innerHTML = '.node2 { stroke:#eeeeee; }\n.node-square { stroke:#beb; }\n' document.body.appendChild(s) } function generateSVG () { var svg = document.createElement('svg') svg.setAttribute('id', 'mermaid-01') var g1 = document.createElement('g') g1.setAttribute('class', 'node') svg.appendChild(g1) var g2 = document.createElement('g') g2.setAttribute('class', 'node-square') svg.appendChild(g2) return svg } function addMermaidSVGwithStyleToDocument () { var styleSheetCount = document.styleSheets.length var svg = document.createElement('svg') svg.setAttribute('id', 'mermaid-03') var s = document.createElement('style') s.setAttribute('type', 'text/css') s.setAttribute('title', 'mermaid-svg-internal-css') s.innerHTML = '#mermaid-05 .node2 { stroke:#eee; }\n.node-square { stroke:#bfe; }\n' svg.appendChild(s) document.body.appendChild(svg) document.styleSheets[styleSheetCount].title = 'mermaid-svg-internal-css' } it('should handle errors thrown when accessing CSS rules', function () { var svg = document.createElement('svg') svg.setAttribute('id', 'mermaid-01') // Firefox throws a SecurityError when trying to access cssRules document.styleSheets[document.styleSheets.length++] = { get cssRules () { throw new Error('SecurityError') } } expect(function () { utils.cloneCssStyles(svg, {}) }).not.toThrow() }) it('should handle an empty set of classes', function () { var svg = document.createElement('svg') svg.setAttribute('id', 'mermaid-01') utils.cloneCssStyles(svg, {}) // Should not create style element if not needed expect(svg.innerHTML).toBe('') }) it('should handle a default class', function () { var svg = document.createElement('svg') svg.setAttribute('id', 'mermaid-01') utils.cloneCssStyles(svg, {'default': {'styles': ['stroke:#fff', 'stroke-width:1.5px']}}) expect(stylesToArray(svg)).toEqual(['#mermaid-01 .node>rect { stroke:#fff; stroke-width:1.5px; }']) // Also verify the elements around the styling expect(svg.innerHTML).toBe('') }) it('should handle stylesheet in document with no classes in SVG', function () { var svg = document.createElement('svg') svg.setAttribute('id', 'mermaid-01') addStyleToDocument('mermaid') utils.cloneCssStyles(svg, {}) // Should not create style element if not needed expect(svg.innerHTML).toBe('') }) it('should handle stylesheet in document with classes in SVG', function () { var svg = generateSVG() addStyleToDocument() utils.cloneCssStyles(svg, {}) expect(stylesToArray(svg)).toEqual(['.node { stroke: #eeeeee;}', '.node-square { stroke: #bbbbbb;}']) }) it('should handle multiple stylesheets in document with classes in SVG', function () { var svg = generateSVG() addStyleToDocument() addSecondStyleToDocument() utils.cloneCssStyles(svg, {}) expect(stylesToArray(svg)).toEqual(['.node { stroke: #eeeeee;}', '.node-square { stroke: #bbbbbb;}', '.node-square { stroke: #bbeebb;}']) }) it('should handle multiple stylesheets + ignore styles in other mermaid SVG', function () { var svg = generateSVG() addStyleToDocument() addSecondStyleToDocument() addMermaidSVGwithStyleToDocument() utils.cloneCssStyles(svg, {}) expect(stylesToArray(svg)).toEqual(['.node { stroke: #eeeeee;}', '.node-square { stroke: #bbbbbb;}', '.node-square { stroke: #bbeebb;}']) }) it('should handle a default class together with stylesheet in document with classes in SVG', function () { var svg = generateSVG() addStyleToDocument() utils.cloneCssStyles(svg, {'default': {'styles': ['stroke:#ffffff', 'stroke-width:1.5px']}}) expect(stylesToArray(svg)).toEqual(['#mermaid-01 .node>rect { stroke:#ffffff; stroke-width:1.5px; }', '.node { stroke: #eeeeee;}', '.node-square { stroke: #bbbbbb;}']) }) it('should handle a default class together with stylesheet in document and classDefs', function () { var svg = generateSVG() addStyleToDocument() utils.cloneCssStyles(svg, { 'default': {'styles': ['stroke:#ffffff', 'stroke-width:1.5px']}, 'node-square': {'styles': ['fill:#eeeeee', 'stroke:#aaaaaa']}, 'node-circle': {'styles': ['fill:#444444', 'stroke:#111111']} }) expect(stylesToArray(svg)).toEqual(['#mermaid-01 .node>rect { stroke:#ffffff; stroke-width:1.5px; }', '.node { stroke: #eeeeee;}', '.node-square { stroke: #bbbbbb;}', '#mermaid-01 .node-square>rect, .node-square>polygon, .node-square>circle, .node-square>ellipse { fill:#eeeeee; stroke:#aaaaaa; }', '#mermaid-01 .node-circle>rect, .node-circle>polygon, .node-circle>circle, .node-circle>ellipse { fill:#444444; stroke:#111111; }' ]) }) }) describe('when finding substring in array ', function () { it('should return the array index that contains the substring', function () { var arr = ['stroke:val1', 'fill:val2'] var result = utils.isSubstringInArray('fill', arr) expect(result).toEqual(1) }) it('should return -1 if the substring is not found in the array', function () { var arr = ['stroke:val1', 'stroke-width:val2'] var result = utils.isSubstringInArray('fill', arr) expect(result).toEqual(-1) }) })