ethers.js/misc/ReactNativeTestApp/App.js

99 lines
2.0 KiB
JavaScript

/**
* Sample React Native App
* https://github.com/facebook/react-native
*
* @format
* @flow strict-local
*/
import React from 'react';
import {
SafeAreaView,
StyleSheet,
ScrollView,
View,
Text,
StatusBar
} from 'react-native';
import {
Colors
} from 'react-native/Libraries/NewAppScreen';
// Inject the crpyot shims (BEFORE the ethers shims)
import "./crypto-shims.js";
// Inject the missing features with the ethers shims
import "./libs/shims.js";
// Import ethers
import { ethers } from "./libs/ethers.js";
// Import the test framework
import "./libs/mocha.js";
// Setup up a testing context (injects primitives like `describe` and `it`)
mocha.setup({ ui: "bdd" });
setTimeout(async function() {
// Mock location (Mocha checks this?)
if (window.location == null) {
window.location = {
search: ""
};
}
// Load the test cases
const testing = await import("./libs/tests.js");
// Serialize all writes to the logging server
let inflight = Promise.resolve();
testing.setLogFunc(function(message) {
console.log(message);
inflight = inflight.then(() => {
return ethers.utils._fetchData("http:/\/localhost:8042/", ethers.utils.toUtf8Bytes(message)).then((result) => {
return true;
}, (error) => {
return false;
});
});
});
mocha.reporter(testing.Reporter);
//mocha.grep(new RegExp("Test nameprep")).run()
mocha.run();
}, 1000);
const App: () => React$Node = () => {
return (
<>
<StatusBar barStyle="dark-content" />
<SafeAreaView>
<ScrollView
contentInsetAdjustmentBehavior="automatic"
style={styles.scrollView}>
<View>
<Text>Running Tests</Text>
</View>
</ScrollView>
</SafeAreaView>
</>
);
};
const styles = StyleSheet.create({
scrollView: {
backgroundColor: Colors.lighter,
},
body: {
backgroundColor: Colors.white,
},
});
export default App;