mirror of
https://github.com/zhigang1992/react-native.git
synced 2026-04-04 09:27:53 +08:00
Move bridge dependencies into a single ReactTestFactory
Reviewed By: cjhopman Differential Revision: D2816291 fb-gh-sync-id: 0eb654541cac7816922d948cc38a26fab44fad70
This commit is contained in:
committed by
facebook-github-bot-6
parent
b9ceecb31f
commit
5e82094fcb
@@ -8,70 +8,131 @@
|
||||
|
||||
package com.facebook.react.testing;
|
||||
|
||||
import javax.annotation.Nullable;
|
||||
|
||||
import android.app.Instrumentation;
|
||||
import android.content.Context;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
|
||||
import com.facebook.react.ReactInstanceManager;
|
||||
import com.facebook.react.bridge.CatalystInstance;
|
||||
import com.facebook.react.bridge.CatalystInstanceImpl;
|
||||
import com.facebook.react.bridge.JSBundleLoader;
|
||||
import com.facebook.react.bridge.NativeModuleCallExceptionHandler;
|
||||
import com.facebook.react.bridge.JSCJavaScriptExecutor;
|
||||
import com.facebook.react.bridge.NativeModule;
|
||||
import com.facebook.react.bridge.NativeModuleRegistry;
|
||||
import com.facebook.react.bridge.JavaScriptModulesConfig;
|
||||
import com.facebook.react.bridge.NativeModule;
|
||||
import com.facebook.react.bridge.NativeModuleCallExceptionHandler;
|
||||
import com.facebook.react.bridge.NativeModuleRegistry;
|
||||
import com.facebook.react.bridge.queue.ReactQueueConfigurationSpec;
|
||||
|
||||
import android.support.test.InstrumentationRegistry;
|
||||
import com.android.internal.util.Predicate;
|
||||
|
||||
public class ReactTestHelper {
|
||||
private static class DefaultReactTestFactory implements ReactTestFactory {
|
||||
private static class ReactInstanceEasyBuilderImpl implements ReactInstanceEasyBuilder {
|
||||
private @Nullable Context mContext;
|
||||
private final NativeModuleRegistry.Builder mNativeModuleRegistryBuilder =
|
||||
new NativeModuleRegistry.Builder();
|
||||
private final JavaScriptModulesConfig.Builder mJSModulesConfigBuilder =
|
||||
new JavaScriptModulesConfig.Builder();
|
||||
|
||||
public static class ReactInstanceEasyBuilder {
|
||||
@Override
|
||||
public ReactInstanceEasyBuilder setContext(Context context) {
|
||||
mContext = context;
|
||||
return this;
|
||||
}
|
||||
|
||||
private final ReactIntegrationTestCase mTestCase;
|
||||
private final NativeModuleRegistry.Builder mNativeModuleRegistryBuilder;
|
||||
private final JavaScriptModulesConfig.Builder mJSModulesConfigBuilder;
|
||||
@Override
|
||||
public ReactInstanceEasyBuilder addNativeModule(NativeModule module) {
|
||||
mNativeModuleRegistryBuilder.add(module);
|
||||
return this;
|
||||
}
|
||||
|
||||
private ReactInstanceEasyBuilder(ReactIntegrationTestCase testCase) {
|
||||
mTestCase = testCase;
|
||||
mNativeModuleRegistryBuilder = new NativeModuleRegistry.Builder();
|
||||
mJSModulesConfigBuilder = new JavaScriptModulesConfig.Builder();
|
||||
}
|
||||
@Override
|
||||
public ReactInstanceEasyBuilder addJSModule(Class moduleInterfaceClass) {
|
||||
mJSModulesConfigBuilder.add(moduleInterfaceClass);
|
||||
return this;
|
||||
}
|
||||
|
||||
public CatalystInstanceImpl build() {
|
||||
CatalystInstanceImpl instance = mTestCase.new ReactTestInstanceBuilder()
|
||||
@Override
|
||||
public CatalystInstance build() {
|
||||
return new CatalystInstanceImpl.Builder()
|
||||
.setReactQueueConfigurationSpec(ReactQueueConfigurationSpec.createDefault())
|
||||
.setJSExecutor(new JSCJavaScriptExecutor())
|
||||
.setRegistry(mNativeModuleRegistryBuilder.build())
|
||||
.setJSModulesConfig(mJSModulesConfigBuilder.build())
|
||||
.setJSBundleLoader(JSBundleLoader.createFileLoader(
|
||||
mTestCase.getContext(),
|
||||
"assets://AndroidTestBundle.js"))
|
||||
mContext,
|
||||
"assets://AndroidTestBundle.js"))
|
||||
.setNativeModuleCallExceptionHandler(
|
||||
new NativeModuleCallExceptionHandler() {
|
||||
new NativeModuleCallExceptionHandler() {
|
||||
@Override
|
||||
public void handleException(Exception e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
})
|
||||
})
|
||||
.build();
|
||||
instance.runJSBundle();
|
||||
mTestCase.waitForBridgeAndUIIdle();
|
||||
return instance;
|
||||
}
|
||||
}
|
||||
|
||||
public ReactInstanceEasyBuilder addNativeModule(NativeModule module) {
|
||||
mNativeModuleRegistryBuilder.add(module);
|
||||
return this;
|
||||
@Override
|
||||
public ReactInstanceEasyBuilder getCatalystInstanceBuilder() {
|
||||
return new ReactInstanceEasyBuilderImpl();
|
||||
}
|
||||
|
||||
public ReactInstanceEasyBuilder addJSModule(Class moduleInterfaceClass) {
|
||||
mJSModulesConfigBuilder.add(moduleInterfaceClass);
|
||||
return this;
|
||||
@Override
|
||||
public ReactInstanceManager.Builder getReactInstanceManagerBuilder() {
|
||||
return ReactInstanceManager.builder();
|
||||
}
|
||||
}
|
||||
|
||||
public static ReactInstanceEasyBuilder catalystInstanceBuilder(
|
||||
ReactIntegrationTestCase testCase) {
|
||||
return new ReactInstanceEasyBuilder(testCase);
|
||||
public static ReactTestFactory getReactTestFactory() {
|
||||
Instrumentation inst = InstrumentationRegistry.getInstrumentation();
|
||||
if (!(inst instanceof ReactTestFactory)) {
|
||||
return new DefaultReactTestFactory();
|
||||
}
|
||||
|
||||
return (ReactTestFactory) inst;
|
||||
}
|
||||
|
||||
public static ReactTestFactory.ReactInstanceEasyBuilder catalystInstanceBuilder(
|
||||
final ReactIntegrationTestCase testCase) {
|
||||
final ReactTestFactory.ReactInstanceEasyBuilder builder =
|
||||
getReactTestFactory().getCatalystInstanceBuilder();
|
||||
ReactTestFactory.ReactInstanceEasyBuilder postBuilder =
|
||||
new ReactTestFactory.ReactInstanceEasyBuilder() {
|
||||
@Override
|
||||
public ReactTestFactory.ReactInstanceEasyBuilder setContext(Context context) {
|
||||
builder.setContext(context);
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ReactTestFactory.ReactInstanceEasyBuilder addNativeModule(NativeModule module) {
|
||||
builder.addNativeModule(module);
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ReactTestFactory.ReactInstanceEasyBuilder addJSModule(Class moduleInterfaceClass) {
|
||||
builder.addJSModule(moduleInterfaceClass);
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public CatalystInstance build() {
|
||||
CatalystInstance instance = builder.build();
|
||||
testCase.initializeWithInstance(instance);
|
||||
instance.runJSBundle();
|
||||
testCase.waitForBridgeAndUIIdle();
|
||||
return instance;
|
||||
}
|
||||
};
|
||||
|
||||
postBuilder.setContext(testCase.getContext());
|
||||
return postBuilder;
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user