Commit 40e2be25 authored by Luke "Jared" Bennett's avatar Luke "Jared" Bennett

Added unit tests

parent 75d3ed9a
/* global Flash */
import Spinner from '../../spinner';
import sqljs from 'sql.js';
import Spinner from '../../spinner';
class BalsamiqViewer {
constructor(viewer) {
......@@ -32,7 +32,7 @@ class BalsamiqViewer {
this.initDatabase(loadEvent.target.response);
const previews = this.getPreviews();
const renderedPreviews = previews.map(preview => this.renderPreview(preview, container));
const renderedPreviews = previews.map(preview => this.renderPreview(preview));
container.innerHTML = renderedPreviews.join('');
container.classList.add('list-inline', 'previews');
......@@ -68,7 +68,7 @@ class BalsamiqViewer {
const name = JSON.parse(title[0].values[0][2]).name;
const image = preview.image;
template = template.replace(/{{name}}/, name).replace(/{{image}}/, image);
template = template.replace(/{{name}}/g, name).replace(/{{image}}/g, image);
return template;
}
......
import sqljs from 'sql.js';
import BalsamiqViewer from '~/blob/balsamiq/balsamiq_viewer';
import * as spinnerSrc from '~/spinner';
import ClassSpecHelper from '../../helpers/class_spec_helper';
describe('BalsamiqViewer', () => {
let balsamiqViewer;
let endpoint;
let viewer;
describe('class constructor', () => {
beforeEach(() => {
endpoint = 'endpoint';
viewer = {
dataset: {
endpoint,
},
};
spyOn(spinnerSrc, 'default');
balsamiqViewer = new BalsamiqViewer(viewer);
});
it('should set .viewer', () => {
expect(balsamiqViewer.viewer).toBe(viewer);
});
it('should set .endpoint', () => {
expect(balsamiqViewer.endpoint).toBe(endpoint);
});
it('should instantiate Spinner', () => {
expect(spinnerSrc.default).toHaveBeenCalledWith(viewer);
});
it('should set .spinner', () => {
expect(balsamiqViewer.spinner).toEqual(jasmine.any(spinnerSrc.default));
});
});
describe('loadFile', () => {
let xhr;
let spinner;
beforeEach(() => {
endpoint = 'endpoint';
xhr = jasmine.createSpyObj('xhr', ['open', 'send']);
spinner = jasmine.createSpyObj('spinner', ['start']);
balsamiqViewer = jasmine.createSpyObj('balsamiqViewer', ['renderFile']);
balsamiqViewer.endpoint = endpoint;
balsamiqViewer.spinner = spinner;
spyOn(window, 'XMLHttpRequest').and.returnValue(xhr);
BalsamiqViewer.prototype.loadFile.call(balsamiqViewer);
});
it('should instantiate XMLHttpRequest', () => {
expect(window.XMLHttpRequest).toHaveBeenCalled();
});
it('should call .open', () => {
expect(xhr.open).toHaveBeenCalledWith('GET', endpoint, true);
});
it('should set .responseType', () => {
expect(xhr.responseType).toBe('arraybuffer');
});
it('should set .onload', () => {
expect(xhr.onload).toEqual(jasmine.any(Function));
});
it('should set .onerror', () => {
expect(xhr.onerror).toBe(BalsamiqViewer.onError);
});
it('should call spinner.start', () => {
expect(spinner.start).toHaveBeenCalled();
});
it('should call .send', () => {
expect(xhr.send).toHaveBeenCalled();
});
});
describe('renderFile', () => {
let spinner;
let container;
let loadEvent;
let previews;
beforeEach(() => {
loadEvent = { target: { response: {} } };
viewer = jasmine.createSpyObj('viewer', ['appendChild']);
spinner = jasmine.createSpyObj('spinner', ['stop']);
previews = [0, 1, 2];
balsamiqViewer = jasmine.createSpyObj('balsamiqViewer', ['initDatabase', 'getPreviews', 'renderPreview']);
balsamiqViewer.viewer = viewer;
balsamiqViewer.spinner = spinner;
balsamiqViewer.getPreviews.and.returnValue(previews);
balsamiqViewer.renderPreview.and.callFake(preview => preview);
viewer.appendChild.and.callFake((containerElement) => {
container = containerElement;
});
BalsamiqViewer.prototype.renderFile.call(balsamiqViewer, loadEvent);
});
it('should call spinner.stop', () => {
expect(spinner.stop).toHaveBeenCalled();
});
it('should call .initDatabase', () => {
expect(balsamiqViewer.initDatabase).toHaveBeenCalledWith(loadEvent.target.response);
});
it('should call .getPreviews', () => {
expect(balsamiqViewer.getPreviews).toHaveBeenCalled();
});
it('should call .renderPreview for each preview', () => {
const allArgs = balsamiqViewer.renderPreview.calls.allArgs();
expect(allArgs.length).toBe(3);
previews.forEach((preview, i) => {
expect(allArgs[i][0]).toBe(preview);
});
});
it('should set .innerHTML', () => {
expect(container.innerHTML).toBe('012');
});
it('should add inline preview classes', () => {
expect(container.classList[0]).toBe('list-inline');
expect(container.classList[1]).toBe('previews');
});
it('should call viewer.appendChild', () => {
expect(viewer.appendChild).toHaveBeenCalledWith(container);
});
});
describe('initDatabase', () => {
let database;
let uint8Array;
let data;
beforeEach(() => {
uint8Array = {};
database = {};
data = 'data';
balsamiqViewer = {};
spyOn(window, 'Uint8Array').and.returnValue(uint8Array);
spyOn(sqljs, 'Database').and.returnValue(database);
BalsamiqViewer.prototype.initDatabase.call(balsamiqViewer, data);
});
it('should instantiate Uint8Array', () => {
expect(window.Uint8Array).toHaveBeenCalledWith(data);
});
it('should call sqljs.Database', () => {
expect(sqljs.Database).toHaveBeenCalledWith(uint8Array);
});
it('should set .database', () => {
expect(balsamiqViewer.database).toBe(database);
});
});
describe('getPreviews', () => {
let database;
let thumbnails;
let getPreviews;
beforeEach(() => {
database = jasmine.createSpyObj('database', ['exec']);
thumbnails = [{ values: [0, 1, 2] }];
balsamiqViewer = {
database,
};
spyOn(BalsamiqViewer, 'parsePreview').and.callFake(preview => preview.toString());
database.exec.and.returnValue(thumbnails);
getPreviews = BalsamiqViewer.prototype.getPreviews.call(balsamiqViewer);
});
it('should call database.exec', () => {
expect(database.exec).toHaveBeenCalledWith('SELECT * FROM thumbnails');
});
it('should call .parsePreview for each value', () => {
const allArgs = BalsamiqViewer.parsePreview.calls.allArgs();
expect(allArgs.length).toBe(3);
thumbnails[0].values.forEach((value, i) => {
expect(allArgs[i][0]).toBe(value);
});
});
it('should return an array of parsed values', () => {
expect(getPreviews).toEqual(['0', '1', '2']);
});
});
describe('renderPreview', () => {
let previewElement;
let innerHTML;
let preview;
let renderPreview;
beforeEach(() => {
innerHTML = '<a>innerHTML</a>';
previewElement = {
outerHTML: '<p>outerHTML</p>',
classList: jasmine.createSpyObj('classList', ['add']),
};
preview = {};
balsamiqViewer = jasmine.createSpyObj('balsamiqViewer', ['renderTemplate']);
spyOn(document, 'createElement').and.returnValue(previewElement);
balsamiqViewer.renderTemplate.and.returnValue(innerHTML);
renderPreview = BalsamiqViewer.prototype.renderPreview.call(balsamiqViewer, preview);
});
it('should call document.createElement', () => {
expect(document.createElement).toHaveBeenCalledWith('li');
});
it('should call classList.add', () => {
expect(previewElement.classList.add).toHaveBeenCalledWith('preview');
});
it('should call .renderTemplate', () => {
expect(balsamiqViewer.renderTemplate).toHaveBeenCalledWith(preview);
});
it('should set .innerHTML', () => {
expect(previewElement.innerHTML).toBe(innerHTML);
});
it('should return .outerHTML', () => {
expect(renderPreview).toBe(previewElement.outerHTML);
});
});
describe('renderTemplate', () => {
let preview;
let database;
let title;
let renderTemplate;
beforeEach(() => {
preview = { reosourceID: 1, image: 'image' };
title = [{ values: [['{}', '{}', '{ "name": "name" }']] }];
database = jasmine.createSpyObj('database', ['exec']);
database.exec.and.returnValue(title);
balsamiqViewer = {
database,
};
spyOn(JSON, 'parse').and.callThrough();
spyOn(String.prototype, 'replace').and.callThrough();
renderTemplate = BalsamiqViewer.prototype.renderTemplate.call(balsamiqViewer, preview);
});
it('should call database.exec', () => {
expect(database.exec).toHaveBeenCalledWith(`SELECT * FROM resources WHERE id = '${preview.resourceID}'`);
});
it('should call JSON.parse', () => {
expect(JSON.parse).toHaveBeenCalledWith(title[0].values[0][2]);
});
it('should call String.prototype.replace', () => {
const allArgs = String.prototype.replace.calls.allArgs();
expect(allArgs.length).toBe(2);
expect(allArgs[0]).toEqual([/{{name}}/g, 'name']);
expect(allArgs[1]).toEqual([/{{image}}/g, 'image']);
});
it('should return the template string', function () {
const template = `
<div class="panel panel-default">
<div class="panel-heading">name</div>
<div class="panel-body">
<img class="img-thumbnail" src=""/>
</div>
</div>
`;
expect(renderTemplate.replace(/\s/g, '')).toEqual(template.replace(/\s/g, ''));
});
});
describe('parsePreview', () => {
let preview;
let parsePreview;
beforeEach(() => {
preview = ['{}', '{ "id": 1 }'];
spyOn(JSON, 'parse').and.callThrough();
parsePreview = BalsamiqViewer.parsePreview(preview);
});
ClassSpecHelper.itShouldBeAStaticMethod(BalsamiqViewer, 'parsePreview');
it('should call JSON.parse', () => {
expect(JSON.parse).toHaveBeenCalledWith(preview[1]);
});
it('should return the parsed JSON', () => {
expect(parsePreview).toEqual(JSON.parse('{ "id": 1 }'));
});
});
describe('onError', () => {
let onError;
beforeEach(() => {
spyOn(window, 'Flash');
onError = BalsamiqViewer.onError();
});
ClassSpecHelper.itShouldBeAStaticMethod(BalsamiqViewer, 'onError');
it('should instantiate Flash', () => {
expect(window.Flash).toHaveBeenCalledWith('Balsamiq file could not be loaded.');
});
it('should return Flash', () => {
expect(onError).toEqual(jasmine.any(window.Flash));
});
});
});
import Spinner from '~/spinner';
import ClassSpecHelper from './helpers/class_spec_helper';
describe('Spinner', () => {
let renderable;
let container;
let spinner;
describe('class constructor', () => {
beforeEach(() => {
renderable = {};
container = {};
spyOn(Spinner, 'createContainer').and.returnValue(container);
spinner = new Spinner(renderable);
});
it('should set .renderable', () => {
expect(spinner.renderable).toBe(renderable);
});
it('should call Spinner.createContainer', () => {
expect(Spinner.createContainer).toHaveBeenCalled();
});
it('should set .container', () => {
expect(spinner.container).toBe(container);
});
});
describe('start', () => {
beforeEach(() => {
renderable = jasmine.createSpyObj('renderable', ['prepend']);
container = {};
spinner = {
renderable,
container,
};
Spinner.prototype.start.call(spinner);
});
it('should call .prepend', () => {
expect(renderable.prepend).toHaveBeenCalledWith(container);
});
});
describe('stop', () => {
beforeEach(() => {
container = jasmine.createSpyObj('container', ['remove']);
spinner = {
container,
};
Spinner.prototype.stop.call(spinner);
});
it('should call .remove', () => {
expect(container.remove).toHaveBeenCalled();
});
});
describe('createContainer', () => {
let createContainer;
beforeEach(() => {
container = {
classList: jasmine.createSpyObj('classList', ['add']),
};
spyOn(document, 'createElement').and.returnValue(container);
createContainer = Spinner.createContainer();
});
ClassSpecHelper.itShouldBeAStaticMethod(Spinner, 'createContainer');
it('should call document.createElement', () => {
expect(document.createElement).toHaveBeenCalledWith('div');
});
it('should call classList.add', () => {
expect(container.classList.add).toHaveBeenCalledWith('loading');
});
it('should return the container element', () => {
expect(createContainer).toBe(container);
});
it('should set the container .innerHTML to Spinner.TEMPLATE', () => {
expect(container.innerHTML).toBe(Spinner.TEMPLATE);
});
});
});
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment