openmct/platform/exporters/ExportServiceSpec.js
2018-05-14 15:46:17 -07:00

143 lines
5.4 KiB
JavaScript

/*****************************************************************************
* Open MCT, Copyright (c) 2014-2018, United States Government
* as represented by the Administrator of the National Aeronautics and Space
* Administration. All rights reserved.
*
* Open MCT is licensed under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0.
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
* Open MCT includes source code licensed under additional open source
* licenses. See the Open Source Licenses file (LICENSES.md) included with
* this source code distribution or the Licensing information page available
* at runtime from the About dialog for additional information.
*****************************************************************************/
define(
["./ExportService", "csv"],
function (ExportService, CSV) {
describe("ExportService", function () {
var mockSaveAs,
testRows,
csvContents,
exportService;
function finishedReadingCSV() {
return !!csvContents;
}
beforeEach(function () {
csvContents = undefined;
testRows = [
{ a: 1, b: 2, c: 3 },
{ a: 4, b: 5, c: 6 },
{ a: 7, b: 8, c: 9 }
];
mockSaveAs = jasmine.createSpy('saveAs');
mockSaveAs.andCallFake(function (blob) {
var reader = new FileReader();
reader.onloadend = function () {
csvContents = new CSV(reader.result).parse();
};
reader.readAsText(blob);
});
exportService = new ExportService(mockSaveAs);
});
describe("#exportCSV(rows)", function () {
beforeEach(function () {
exportService.exportCSV(testRows);
waitsFor(finishedReadingCSV);
});
it("triggers saving of a file", function () {
expect(mockSaveAs).toHaveBeenCalledWith(
jasmine.any(Blob),
jasmine.any(String)
);
});
it("includes headers from the data set", function () {
expect(csvContents[0])
.toEqual(Object.keys(testRows[0]).sort());
});
it("includes data from the data set", function () {
var headers = csvContents[0],
expectedData = testRows.map(function (row) {
return headers.map(function (key) {
return String(row[key]);
});
});
// Everything after header should be data
expect(csvContents.slice(1)).toEqual(expectedData);
});
});
describe("#exportCSV(rows, options.headers)", function () {
var testHeaders;
beforeEach(function () {
testHeaders = ['a', 'b'];
exportService
.exportCSV(testRows, { headers: testHeaders });
waitsFor(finishedReadingCSV);
});
it("triggers saving of a file", function () {
expect(mockSaveAs).toHaveBeenCalledWith(
jasmine.any(Blob),
jasmine.any(String)
);
});
it("includes only the specified headers", function () {
expect(csvContents[0])
.toEqual(testHeaders);
expect(csvContents[0])
.not.toEqual(Object.keys(testRows[0]).sort());
});
it("includes a subset data from the data set", function () {
var headers = testHeaders,
expectedData = testRows.map(function (row) {
return headers.map(function (key) {
return String(row[key]);
});
});
expect(csvContents.slice(1)).toEqual(expectedData);
});
});
describe("#exportCSV(rows, options.filename)", function () {
var testFilename;
beforeEach(function () {
testFilename = "some-test-filename.csv";
exportService
.exportCSV(testRows, { filename: testFilename });
waitsFor(finishedReadingCSV);
});
it("saves a file with the specified name", function () {
expect(mockSaveAs).toHaveBeenCalledWith(
jasmine.any(Blob),
testFilename
);
});
});
});
}
);