mirror of
https://github.com/status-im/react-native.git
synced 2025-01-10 01:25:39 +00:00
baf5b7b4d5
Summary: @public Take a step back and de-batch the bridge calls so we can have better profiling data and a better starting point to work on future optimisations. Also gave a 10~15% win on first render. Reviewed By: @javache Differential Revision: D2493674 fb-gh-sync-id: 05165fdd00645bdf43e844bb0c4300a2f63e7038
119 lines
3.2 KiB
JavaScript
119 lines
3.2 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*/
|
|
'use strict';
|
|
|
|
jest.setMock('ReactUpdates', {
|
|
batchedUpdates: fn => fn()
|
|
});
|
|
|
|
jest.dontMock('MessageQueue');
|
|
jest.dontMock('keyMirror');
|
|
var MessageQueue = require('MessageQueue');
|
|
|
|
let MODULE_IDS = 0;
|
|
let METHOD_IDS = 1;
|
|
let PARAMS = 2;
|
|
|
|
let TestModule = {
|
|
testHook1(){}, testHook2(){},
|
|
};
|
|
|
|
let customRequire = (moduleName) => TestModule;
|
|
|
|
let assertQueue = (flushedQueue, index, moduleID, methodID, params) => {
|
|
expect(flushedQueue[MODULE_IDS][index]).toEqual(moduleID);
|
|
expect(flushedQueue[METHOD_IDS][index]).toEqual(methodID);
|
|
expect(flushedQueue[PARAMS][index]).toEqual(params);
|
|
};
|
|
|
|
var queue;
|
|
|
|
describe('MessageQueue', () => {
|
|
|
|
beforeEach(() => {
|
|
queue = new MessageQueue(
|
|
remoteModulesConfig,
|
|
localModulesConfig,
|
|
customRequire,
|
|
);
|
|
|
|
TestModule.testHook1 = jasmine.createSpy();
|
|
TestModule.testHook2 = jasmine.createSpy();
|
|
});
|
|
|
|
it('should enqueue native calls', () => {
|
|
queue.__nativeCall(0, 1, [2]);
|
|
let flushedQueue = queue.flushedQueue();
|
|
assertQueue(flushedQueue, 0, 0, 1, [2]);
|
|
});
|
|
|
|
it('should call a local function with id', () => {
|
|
expect(TestModule.testHook1.callCount).toEqual(0);
|
|
queue.__callFunction(0, 0, [1]);
|
|
expect(TestModule.testHook1.callCount).toEqual(1);
|
|
});
|
|
|
|
it('should call a local function with the function name', () => {
|
|
expect(TestModule.testHook2.callCount).toEqual(0);
|
|
queue.__callFunction('one', 'testHook2', [2]);
|
|
expect(TestModule.testHook2.callCount).toEqual(1);
|
|
});
|
|
|
|
it('should generate native modules', () => {
|
|
queue.RemoteModules.one.remoteMethod1('foo');
|
|
let flushedQueue = queue.flushedQueue();
|
|
assertQueue(flushedQueue, 0, 0, 0, ['foo']);
|
|
});
|
|
|
|
it('should store callbacks', () => {
|
|
queue.RemoteModules.one.remoteMethod2('foo', () => {}, () => {});
|
|
let flushedQueue = queue.flushedQueue();
|
|
assertQueue(flushedQueue, 0, 0, 1, ['foo', 0, 1]);
|
|
});
|
|
|
|
it('should call the stored callback', (done) => {
|
|
var done = false;
|
|
queue.RemoteModules.one.remoteMethod1(() => { done = true; });
|
|
queue.__invokeCallback(1);
|
|
expect(done).toEqual(true);
|
|
});
|
|
|
|
it('should throw when calling the same callback twice', () => {
|
|
queue.RemoteModules.one.remoteMethod1(() => {});
|
|
queue.__invokeCallback(1);
|
|
expect(() => queue.__invokeCallback(1)).toThrow();
|
|
});
|
|
|
|
it('should throw when calling both success and failure callback', () => {
|
|
queue.RemoteModules.one.remoteMethod1(() => {}, () => {});
|
|
queue.__invokeCallback(1);
|
|
expect(() => queue.__invokeCallback(0)).toThrow();
|
|
});
|
|
});
|
|
|
|
var remoteModulesConfig = {
|
|
'one': {
|
|
'moduleID':0,
|
|
'methods': {
|
|
'remoteMethod1':{ 'type': 'remote', 'methodID': 0 },
|
|
'remoteMethod2':{ 'type': 'remote', 'methodID': 1 },
|
|
}
|
|
},
|
|
};
|
|
|
|
var localModulesConfig = {
|
|
'one': {
|
|
'moduleID': 0,
|
|
'methods': {
|
|
'testHook1':{ 'type': 'local', 'methodID': 0 },
|
|
'testHook2':{ 'type': 'local', 'methodID': 1 },
|
|
}
|
|
},
|
|
};
|