blob: bcc34e1fad5825965fe06ac769f2ec85cecb31de [file] [log] [blame]
/**
* © OpenCORD
*
* Created by teone on 3/24/16.
*/
(function () {
'use strict';
const mockData = [
{
id: 1,
first_name: 'Jon',
last_name: 'Snow',
hidden_field: 'hidden'
}
];
describe('The xos.helper module', function(){
describe('The xos-smart-table component', () => {
var spy, emptySpy, scope, isolatedScope, element;
beforeEach(module('xos.helpers'));
// mock the service
beforeEach(function(){
module(function($provide){
$provide.service('MockResource', function(){
this.query = jasmine.createSpy('query').and.callFake(() => {
return {$promise: {then: (cb) => cb(mockData)}};
});
this.delete = jasmine.createSpy('delete').and.callFake(() => {
return {$promise: {then: (cb) => cb({})}};
});
});
$provide.service('EmptyResource', function(){
this.query = jasmine.createSpy('emptyQuery').and.callFake(() => {
return {$promise: {then: (cb) => cb([])}};
});
});
});
})
beforeEach(inject(function ($compile, $rootScope, MockResource) {
scope = $rootScope.$new();
scope.config = {
resource: 'MockResource',
hiddenFields: ['hidden_field']
};
spy = MockResource;
element = angular.element('<xos-smart-table config="config"></xos-smart-table>');
$compile(element)(scope);
scope.$digest();
isolatedScope = element.isolateScope().vm;
}));
it('should query elements', () => {
expect(spy.query).toHaveBeenCalled();
expect($(element).find('.alert').parent().parent()).toHaveClass('ng-hide');
});
it('should hide hidden fields', () => {
// the 4th field is the mocked save method
expect($(element).find('thead th').length).toEqual(3);
expect($(element).find('thead th')[0]).toContainText('First name:');
expect($(element).find('thead th')[1]).toContainText('Last name:');
expect($(element).find('thead th')[2]).toContainText('Actions:');
});
it('should delete a model', () => {
$(element).find('a[title="delete"]')[0].click();
expect(spy.delete).toHaveBeenCalledWith({id: mockData[0].id});
expect($(element).find('.alert')).toContainText(`MockResource with id ${mockData[0].id} successfully deleted`);
});
it('should show the form', () => {
expect($(element).find('.panel')[0]).toHaveClass('ng-hide');
$(element).find('a[title="details"]')[0].click();
expect($(element).find('.panel')).not.toHaveClass('ng-hide');
});
it('should save an item', () => {
const saveMethod = jasmine.createSpy('$save').and.callFake(() => {
return {then: (cb) => cb(mockData[0])};
});
let model = {
id: 1,
first_name: 'Jon',
last_name: 'Snow',
hidden_field: 'hidden',
$save: saveMethod
};
isolatedScope.detailedItem = model;
scope.$apply();
$(element).find('xos-form .btn.btn-success').click();
expect(saveMethod).toHaveBeenCalled();
});
describe('when fetching an empty collection', () => {
beforeEach(inject(function ($compile, $rootScope, EmptyResource) {
scope = $rootScope.$new();
scope.config = {
resource: 'EmptyResource'
};
emptySpy = EmptyResource;
element = angular.element('<xos-smart-table config="config"></xos-smart-table>');
$compile(element)(scope);
scope.$digest();
isolatedScope = element.isolateScope().vm;
}));
it('should display an alert', () => {
expect(emptySpy.query).toHaveBeenCalled();
expect($(element).find('.alert').parent().parent()).not.toHaveClass('ng-hide');
expect($(element).find('.alert')).toContainText('No data to show');
});
});
});
});
})();