SymphonyElectron/tests/Search.test.js

530 lines
21 KiB
JavaScript
Raw Normal View History

const childProcess = require('child_process');
const path = require('path');
const fs = require('fs');
2018-02-16 02:14:52 -06:00
const { isWindowsOS } = require('../js/utils/misc.js');
let executionPath = null;
let userConfigDir = null;
let searchConfig;
let SearchApi;
jest.mock('electron', function() {
return {
app: {
getPath: mockedGetPath
}
}
});
function mockedGetPath(type) {
if (type === 'exe') {
return executionPath;
}
if (type === 'userData') {
return userConfigDir
}
return '';
}
describe('Tests for Search', function() {
let userId;
let key;
2017-12-27 00:27:49 -06:00
let dataFolderPath;
2017-12-26 06:04:18 -06:00
let realTimeIndexPath;
let tempBatchPath;
2017-12-27 00:27:49 -06:00
let currentDate = new Date().getTime();
2017-12-27 00:27:49 -06:00
jasmine.DEFAULT_TIMEOUT_INTERVAL = 90000;
beforeAll(function (done) {
2017-12-29 00:36:19 -06:00
childProcess.exec(`npm rebuild --target=${process.version} --build-from-source`, function(err) {
userId = 12345678910112;
2017-12-27 00:27:49 -06:00
key = 'jjjehdnctsjyieoalskcjdhsnahsadndfnusdfsdfsd=';
executionPath = path.join(__dirname, 'library');
2018-02-16 02:14:52 -06:00
if (isWindowsOS) {
2018-01-12 00:53:34 -06:00
executionPath = path.join(__dirname, '..', 'library');
}
userConfigDir = path.join(__dirname, '..');
searchConfig = require('../js/search/searchConfig.js');
const { Search } = require('../js/search/search.js');
SearchApi = new Search(userId, key);
2017-12-26 06:04:18 -06:00
realTimeIndexPath = path.join(userConfigDir, 'data', 'temp_realtime_index');
tempBatchPath = path.join(userConfigDir, 'data', 'temp_batch_indexes');
2018-01-12 05:02:18 -06:00
dataFolderPath = path.join(userConfigDir, 'data');
2018-01-09 02:50:29 -06:00
if (fs.existsSync(dataFolderPath)) {
2018-02-15 00:50:52 -06:00
deleteIndexFolders(dataFolderPath)
2018-01-09 02:50:29 -06:00
}
done();
2017-12-29 00:36:19 -06:00
});
2017-12-26 06:04:18 -06:00
});
afterAll(function (done) {
setTimeout(function () {
2017-12-27 00:27:49 -06:00
deleteIndexFolders(dataFolderPath);
2018-01-12 06:01:59 -06:00
let root = path.join(userConfigDir, `${searchConfig.FOLDERS_CONSTANTS.PREFIX_NAME}_${userId}.enc`);
2017-12-26 06:04:18 -06:00
if (fs.existsSync(root)) {
2017-12-27 00:27:49 -06:00
fs.unlinkSync(root);
2017-12-26 06:04:18 -06:00
}
2017-12-26 06:04:18 -06:00
done();
}, 3000);
});
2017-12-26 06:04:18 -06:00
function deleteIndexFolders(location) {
if (fs.existsSync(location)) {
fs.readdirSync(location).forEach(function(file) {
2018-01-12 00:53:34 -06:00
let curPath = path.join(location, file);
2017-12-26 06:04:18 -06:00
if (fs.lstatSync(curPath).isDirectory()) {
deleteIndexFolders(curPath);
} else {
fs.unlinkSync(curPath);
}
});
fs.rmdirSync(location);
}
}
describe('Search Initial checks', function() {
2017-12-27 00:27:49 -06:00
it('should be initialized', function (done) {
setTimeout(function () {
2017-12-27 00:27:49 -06:00
expect(SearchApi.isInitialized).toBe(true);
expect(SearchApi.messageData).toEqual([]);
expect(SearchApi.isRealTimeIndexing).toBe(false);
2017-12-27 00:27:49 -06:00
done();
}, 3000)
});
2017-12-26 06:04:18 -06:00
it('should isLibInit to true', function () {
let init = SearchApi.isLibInit();
expect(init).toEqual(true);
});
it('should isLibInit to false', function () {
2017-12-26 06:04:18 -06:00
SearchApi.isInitialized = false;
let init = SearchApi.isLibInit();
expect(init).toEqual(false);
SearchApi.isInitialized = true;
});
it('should exist index folder', function() {
2018-01-09 22:45:03 -06:00
expect(fs.existsSync(path.join(userConfigDir, 'data', 'search_index_12345678910112'))).toBe(true);
2017-12-26 06:04:18 -06:00
expect(fs.existsSync(realTimeIndexPath)).toBe(true);
});
2017-12-26 06:04:18 -06:00
it('should not exist index folder', function() {
expect(fs.existsSync(tempBatchPath)).toBe(false);
});
2017-12-26 06:04:18 -06:00
});
describe('Batch indexing process tests', function () {
it('should index in a batch', function (done) {
2017-12-29 00:34:40 -06:00
let messages = [{
messageId: "Jc+4K8RtPxHJfyuDQU9atX///qN3KHYXdA==",
threadId: "Au8O2xKHyX1LtE6zW019GX///rZYegAtdA==",
ingestionDate: currentDate.toString(),
senderId: "71811853189212",
chatType: "CHATROOM",
isPublic: "false",
sendingApp: "lc",
text: "it works"
}, {
messageId: "Jc+4K8RtPxHJfyuDQU9atX///qN3KHYXdA==",
threadId: "Au8O2xKHyX1LtE6zW019GX///rZYegAtdA==",
ingestionDate: currentDate.toString(),
senderId: "71811853189212",
chatType: "CHATROOM",
isPublic: "false",
sendingApp: "lc",
text: "it works"
}, {
messageId: "Jc+4K8RtPxHJfyuDQU9atX///qN3KHYXdA==",
threadId: "Au8O2xKHyX1LtE6zW019GX///rZYegAtdA==",
ingestionDate: currentDate.toString(),
senderId: "71811853189212",
chatType: "CHATROOM",
isPublic: "false",
sendingApp: "lc",
text: "it works"
}];
const indexBatch = jest.spyOn(SearchApi, 'indexBatch');
SearchApi.indexBatch(JSON.stringify(messages)).then(function () {
2017-12-26 06:04:18 -06:00
expect(fs.existsSync(tempBatchPath)).toBe(true);
expect(indexBatch).toHaveBeenCalledWith(JSON.stringify(messages));
2017-12-26 06:04:18 -06:00
done();
});
});
2017-12-26 06:04:18 -06:00
it('should not batch index', function (done) {
const indexBatch = jest.spyOn(SearchApi, 'indexBatch');
SearchApi.indexBatch().catch(function (err) {
expect(indexBatch).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
expect(err).toBeTruthy();
done();
});
2017-12-26 06:04:18 -06:00
});
it('should not batch index invalid object', function (done) {
const indexBatch = jest.spyOn(SearchApi, 'indexBatch');
2017-12-26 06:04:18 -06:00
SearchApi.indexBatch('message').catch(function (err) {
expect(err).toBeTruthy();
expect(indexBatch).toHaveBeenCalledWith('message');
2017-12-26 06:04:18 -06:00
done();
});
});
2017-12-26 06:04:18 -06:00
it('should not batch index parse error', function (done) {
let message = {
messageId: "Jc+4K8RtPxHJfyuDQU9atX///qN3KHYXdA==",
threadId: "Au8O2xKHyX1LtE6zW019GX///rZYegAtdA==",
2017-12-27 00:27:49 -06:00
ingestionDate: currentDate.toString(),
senderId: "71811853189212",
chatType: "CHATROOM",
isPublic: "false",
sendingApp: "lc",
2017-12-26 06:04:18 -06:00
text: "it works"
};
const indexBatch = jest.spyOn(SearchApi, 'indexBatch');
SearchApi.indexBatch(JSON.stringify(message)).catch(function (err) {
2017-12-26 06:04:18 -06:00
expect(err).toBeTruthy();
expect(indexBatch).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
done();
});
2017-12-26 06:04:18 -06:00
});
it('should not batch index isInitialized is false', function (done) {
SearchApi.isInitialized = false;
let message = [ {
2017-12-26 06:04:18 -06:00
messageId: "Jc+4K8RtPxHJfyuDQU9atX///qN3KHYXdA==",
threadId: "Au8O2xKHyX1LtE6zW019GX///rZYegAtdA==",
2017-12-27 00:27:49 -06:00
ingestionDate: currentDate.toString(),
2017-12-26 06:04:18 -06:00
senderId: "71811853189212",
chatType: "CHATROOM",
isPublic: "false",
sendingApp: "lc",
text: "it fails"
} ];
const indexBatch = jest.spyOn(SearchApi, 'indexBatch');
SearchApi.indexBatch(JSON.stringify(message)).catch(function (err) {
2017-12-26 06:04:18 -06:00
expect(err).toBeTruthy();
expect(indexBatch).toHaveBeenCalledWith(JSON.stringify(message));
2017-12-26 06:04:18 -06:00
SearchApi.isInitialized = true;
done();
});
});
2017-12-26 06:04:18 -06:00
it('should match messages length after batch indexing', function (done) {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
2017-12-26 06:04:18 -06:00
SearchApi.searchQuery('it works', [], [], '', undefined, undefined, 25, 0, 0).then(function (res) {
expect(res.messages.length).toEqual(0);
expect(searchQuery).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
done()
});
});
2017-12-26 06:04:18 -06:00
it('should merge batch index to user index', function (done) {
const mergeIndexBatches = jest.spyOn(SearchApi, 'mergeIndexBatches');
SearchApi.mergeIndexBatches().then(function () {
2017-12-26 06:04:18 -06:00
expect(fs.existsSync(tempBatchPath)).toBe(false);
expect(mergeIndexBatches).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
done();
});
});
it('should match messages length after batch indexing', function (done) {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
2017-12-26 06:04:18 -06:00
SearchApi.searchQuery('it works', [], [], '', undefined, undefined, 25, 0, 0).then(function (res) {
2017-12-29 00:34:40 -06:00
expect(res.messages.length).toEqual(3);
expect(searchQuery).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
done();
});
});
});
describe('RealTime indexing process', function () {
it('should index realTime message', function () {
let message = [{
messageId: "Jc+4K8RtPxHJfyuDQU9atX///qN3KHYXdA==",
threadId: "Au8O2xKHyX1LtE6zW019GX///rZYegAtdA==",
2017-12-27 00:27:49 -06:00
ingestionDate: currentDate.toString(),
2017-12-26 06:04:18 -06:00
senderId: "71811853189212",
chatType: "CHATROOM",
isPublic: "false",
sendingApp: "lc",
text: "realtime working"
}];
2017-12-26 06:04:18 -06:00
const batchRealTimeIndexing = jest.spyOn(SearchApi, 'batchRealTimeIndexing');
SearchApi.batchRealTimeIndexing(message);
expect(batchRealTimeIndexing).toHaveBeenCalled();
});
it('should match message length', function (done) {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
2017-12-26 06:04:18 -06:00
SearchApi.searchQuery('realtime working', ["71811853189212"], ["Au8O2xKHyX1LtE6zW019GX///rZYegAtdA=="], '', undefined, undefined, 25, 0, 0).then(function (res) {
2017-12-29 00:34:40 -06:00
expect(res.messages.length).toEqual(3);
2017-12-26 06:04:18 -06:00
expect(fs.existsSync(realTimeIndexPath)).toBe(true);
expect(searchQuery).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
done();
})
});
it('should not index realTime message', function (done) {
let message = [{
messageId: "Jc+4K8RtPxHJfyuDQU9atX///qN3KHYXdA==",
threadId: "Au8O2xKHyX1LtE6zW019GX///rZYegAtdA==",
2017-12-27 00:27:49 -06:00
ingestionDate: currentDate.toString(),
2017-12-26 06:04:18 -06:00
senderId: "71811853189212",
chatType: "CHATROOM",
isPublic: "false",
sendingApp: "lc",
text: "isRealTimeIndexing"
}];
2017-12-26 06:04:18 -06:00
const batchRealTimeIndexing = jest.spyOn(SearchApi, 'batchRealTimeIndexing');
2017-12-28 03:59:37 -06:00
const realTimeIndexing = jest.spyOn(SearchApi, 'realTimeIndexing');
2017-12-27 00:27:49 -06:00
SearchApi.isRealTimeIndexing = true;
2017-12-28 03:59:37 -06:00
expect(SearchApi.checkIsRealTimeIndexing()).toBe(true);
2017-12-26 06:04:18 -06:00
SearchApi.batchRealTimeIndexing(message);
expect(batchRealTimeIndexing).toHaveBeenCalled();
2017-12-28 03:59:37 -06:00
expect(realTimeIndexing).not.toBeCalled();
2017-12-27 00:27:49 -06:00
setTimeout(function () {
2017-12-27 00:27:49 -06:00
SearchApi.searchQuery('isRealTimeIndexing', [], [], '', undefined, undefined, 25, 0, 0).then(function (res) {
expect(res.messages.length).toEqual(0);
expect(fs.existsSync(realTimeIndexPath)).toBe(true);
2017-12-27 00:27:49 -06:00
done();
});
}, 6000)
2017-12-26 06:04:18 -06:00
});
it('should not call the real-time index', function () {
2017-12-26 06:04:18 -06:00
let message = [{
messageId: "Jc+4K8RtPxHJfyuDQU9atX///qN3KHYXdA==",
threadId: "Au8O2xKHyX1LtE6zW019GX///rZYegAtdA==",
2017-12-27 00:27:49 -06:00
ingestionDate: currentDate.toString(),
2017-12-26 06:04:18 -06:00
senderId: "71811853189212",
chatType: "CHATROOM",
isPublic: "false",
sendingApp: "lc",
text: "isRealTimeIndexing"
}];
const batchRealTimeIndexing = jest.spyOn(SearchApi, 'batchRealTimeIndexing');
const realTimeIndexing = jest.spyOn(SearchApi, 'realTimeIndexing');
SearchApi.isRealTimeIndexing = true;
SearchApi.batchRealTimeIndexing(message);
expect(batchRealTimeIndexing).toHaveBeenCalled();
expect(realTimeIndexing).not.toBeCalled();
});
it('should not realTime index invalid object', function () {
let message = [{
messageId: "Jc+4K8RtPxHJfyuDQU9atX///qN3KHYXdA==",
threadId: "Au8O2xKHyX1LtE6zW019GX///rZYegAtdA==",
ingestionDate: currentDate.toString(),
senderId: "71811853189212",
chatType: "CHATROOM",
isPublic: "false",
sendingApp: "lc",
text: "isRealTimeIndexing"
}];
const realTimeIndexing = jest.spyOn(SearchApi, 'realTimeIndexing');
2017-12-26 06:04:18 -06:00
expect(function () {
SearchApi.realTimeIndexing('message')
}).toThrow();
expect(function () {
SearchApi.realTimeIndexing()
2018-01-09 02:50:29 -06:00
}).toThrow();
2017-12-26 06:04:18 -06:00
SearchApi.isInitialized = false;
expect(function () {
SearchApi.realTimeIndexing(JSON.stringify(message))
}).toThrow(new Error('Library not initialized'));
SearchApi.isInitialized = true;
expect(realTimeIndexing).toHaveBeenCalled();
expect(realTimeIndexing).toHaveBeenCalledTimes(3);
2017-12-26 06:04:18 -06:00
});
it('should return realTime bool', function () {
const checkIsRealTimeIndexing = jest.spyOn(SearchApi, 'checkIsRealTimeIndexing');
2017-12-26 06:04:18 -06:00
SearchApi.isRealTimeIndexing = true;
expect(SearchApi.checkIsRealTimeIndexing()).toBe(true);
SearchApi.isRealTimeIndexing = false;
expect(SearchApi.checkIsRealTimeIndexing()).toBe(false);
expect(checkIsRealTimeIndexing).toHaveBeenCalled();
expect(checkIsRealTimeIndexing).toHaveBeenCalledTimes(2);
2017-12-26 06:04:18 -06:00
});
it('should delete realtime index', function () {
const deleteRealTimeFolder = jest.spyOn(SearchApi, 'deleteRealTimeFolder');
2017-12-26 06:04:18 -06:00
SearchApi.deleteRealTimeFolder();
expect(fs.existsSync(realTimeIndexPath)).toBe(true);
expect(deleteRealTimeFolder).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
});
});
describe('Test for encryption of the index', function () {
it('should encrypt user index', function (done) {
const encryptIndex = jest.spyOn(SearchApi, 'encryptIndex');
2017-12-26 06:04:18 -06:00
SearchApi.encryptIndex(key);
expect(encryptIndex).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
done();
});
it('should exist encrypted file', function (done) {
setTimeout(function () {
2018-01-09 22:45:03 -06:00
expect(fs.existsSync(path.join(userConfigDir, 'search_index_12345678910112.enc'))).toBe(true);
expect(fs.existsSync(path.join(userConfigDir, 'search_index_12345678910112.tar.lz4'))).toBe(false);
2017-12-26 06:04:18 -06:00
done();
2017-12-27 00:27:49 -06:00
}, 3000);
2017-12-26 06:04:18 -06:00
});
});
describe('Test for latest timestamp', function () {
it('should get the latest timestamp', function (done) {
const getLatestMessageTimestamp = jest.spyOn(SearchApi, 'getLatestMessageTimestamp');
2017-12-26 06:04:18 -06:00
SearchApi.getLatestMessageTimestamp().then(function (res) {
2017-12-27 00:27:49 -06:00
expect(res).toEqual(currentDate.toString());
expect(getLatestMessageTimestamp).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
done();
});
});
2017-12-26 06:04:18 -06:00
it('should not get the latest timestamp', function (done) {
const getLatestMessageTimestamp = jest.spyOn(SearchApi, 'getLatestMessageTimestamp');
2017-12-26 06:04:18 -06:00
SearchApi.isInitialized = false;
SearchApi.getLatestMessageTimestamp().catch(function (err) {
2017-12-27 00:27:49 -06:00
expect(err).toEqual(new Error('Not initialized'));
expect(getLatestMessageTimestamp).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
SearchApi.isInitialized = true;
done();
});
});
2017-12-27 00:27:49 -06:00
it('should not get the latest timestamp', function (done) {
const getLatestMessageTimestamp = jest.spyOn(SearchApi, 'getLatestMessageTimestamp');
2018-01-12 02:39:19 -06:00
deleteIndexFolders(dataFolderPath);
2017-12-27 00:27:49 -06:00
SearchApi.getLatestMessageTimestamp().catch(function (err) {
expect(err).toEqual(new Error('Index folder does not exist.'));
expect(getLatestMessageTimestamp).toHaveBeenCalled();
expect(getLatestMessageTimestamp).toHaveBeenCalledTimes(3);
2017-12-27 00:27:49 -06:00
done();
});
});
2017-12-26 06:04:18 -06:00
});
describe('Test to decrypt the index', function () {
2018-01-12 02:39:19 -06:00
it('should decrypt the index', function (done) {
setTimeout(function () {
const decryptAndInit = jest.spyOn(SearchApi, 'decryptAndInit');
SearchApi.decryptAndInit();
expect(decryptAndInit).toHaveBeenCalled();
done();
}, 3000);
2017-12-26 06:04:18 -06:00
});
2017-12-26 06:04:18 -06:00
it('should get message from the decrypted index', function (done) {
setTimeout(function () {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
2017-12-27 00:27:49 -06:00
let endTime = new Date().getTime();
let startTime = new Date().getTime() - (4 * 31 * 24 * 60 * 60 * 1000);
SearchApi.searchQuery('it works', [], [], '', startTime.toString(), endTime.toString(), '0', 0.2, 0.1).then(function (res) {
2017-12-29 00:34:40 -06:00
expect(res.messages.length).toEqual(3);
expect(searchQuery).toHaveBeenCalled();
2017-12-26 06:04:18 -06:00
done()
});
}, 3000)
});
});
2017-12-26 06:04:18 -06:00
describe('Test for search functions', function () {
it('should search fail isInitialized is false', function (done) {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
2017-12-27 00:27:49 -06:00
SearchApi.isInitialized = false;
SearchApi.searchQuery('it works', [], [], '', '', '', 25, 0, 0).catch(function (err) {
expect(err).toEqual(new Error('Library not initialized'));
expect(searchQuery).toHaveBeenCalled();
2017-12-27 00:27:49 -06:00
SearchApi.isInitialized = true;
done();
});
});
2017-12-29 00:34:40 -06:00
it('should filter search limit ', function (done) {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
SearchApi.searchQuery('works', [], [], '', '', '', 2, 0, 0).then(function (res) {
expect(res.messages.length).toBe(2);
expect(searchQuery).toHaveBeenCalledTimes(7);
expect(searchQuery).toHaveBeenCalled();
done();
});
});
2017-12-27 00:27:49 -06:00
it('should search fails index folder not fund', function (done) {
deleteIndexFolders(dataFolderPath);
2018-01-12 05:02:18 -06:00
setTimeout(function () {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
SearchApi.searchQuery('it works', [], [], '', '', '', 25, 0, 0).catch(function (err) {
expect(err).toEqual(new Error('Index folder does not exist.'));
expect(searchQuery).toHaveBeenCalledTimes(8);
expect(searchQuery).toHaveBeenCalled();
SearchApi = undefined;
const { Search } = require('../js/search/search.js');
SearchApi = new Search(userId, key);
done();
})
}, 3000);
2017-12-27 00:27:49 -06:00
});
it('should search fails query is undefined', function (done) {
setTimeout(function () {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
2017-12-27 00:27:49 -06:00
expect(SearchApi.isInitialized).toBe(true);
SearchApi.searchQuery(undefined, [], [], '', '', '', 25, 0, 0).catch(function (err) {
expect(err).toEqual(new Error('Search query error'));
expect(searchQuery).toHaveBeenCalled();
2017-12-27 00:27:49 -06:00
done();
});
}, 3000);
});
it('should search for hashtag', function (done) {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
2017-12-27 00:27:49 -06:00
SearchApi.searchQuery('#123 "testing"', [], [], 'attachment', '', '', 25, 0, 0).then(function (res) {
expect(res.messages.length).toEqual(0);
expect(searchQuery).toHaveBeenCalled();
2017-12-27 00:27:49 -06:00
done();
});
});
it('should search for pdf', function (done) {
const searchQuery = jest.spyOn(SearchApi, 'searchQuery');
2017-12-27 00:27:49 -06:00
SearchApi.searchQuery('', [], [], 'pdf', '', '', 25, 0, 0).then(function (res) {
expect(res.messages.length).toEqual(0);
expect(searchQuery).toHaveBeenCalled();
expect(searchQuery).toHaveBeenCalledTimes(3);
2017-12-27 00:27:49 -06:00
done();
});
});
});
});