2017-07-28 11:32:00 -07:00
|
|
|
/**
|
2018-09-11 15:27:47 -07:00
|
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
2017-07-28 11:32:00 -07:00
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2017-08-11 09:23:10 -07:00
|
|
|
*
|
2018-05-10 15:44:55 -07:00
|
|
|
* @format
|
2017-07-28 11:32:00 -07:00
|
|
|
*/
|
2018-05-10 15:44:55 -07:00
|
|
|
|
2017-07-28 11:32:00 -07:00
|
|
|
'use strict';
|
|
|
|
|
2018-05-14 00:09:36 -07:00
|
|
|
const React = require('react');
|
|
|
|
const ReactNative = require('react-native');
|
|
|
|
const {WebView} = ReactNative;
|
2017-07-28 11:32:00 -07:00
|
|
|
|
2018-05-14 00:09:36 -07:00
|
|
|
const {TestModule} = ReactNative.NativeModules;
|
2017-07-28 11:32:00 -07:00
|
|
|
|
|
|
|
class WebViewTest extends React.Component {
|
|
|
|
render() {
|
2018-05-14 00:09:36 -07:00
|
|
|
let firstMessageReceived = false;
|
|
|
|
let secondMessageReceived = false;
|
2017-07-28 11:32:00 -07:00
|
|
|
function processMessage(e) {
|
2018-05-14 00:09:36 -07:00
|
|
|
const message = e.nativeEvent.data;
|
2018-05-10 15:44:55 -07:00
|
|
|
if (message === 'First') {
|
|
|
|
firstMessageReceived = true;
|
|
|
|
}
|
|
|
|
if (message === 'Second') {
|
|
|
|
secondMessageReceived = true;
|
|
|
|
}
|
2017-07-28 11:32:00 -07:00
|
|
|
|
|
|
|
// got both messages
|
2018-05-10 15:44:55 -07:00
|
|
|
if (firstMessageReceived && secondMessageReceived) {
|
|
|
|
TestModule.markTestPassed(true);
|
|
|
|
}
|
2017-07-28 11:32:00 -07:00
|
|
|
// wait for next message
|
2018-05-10 15:44:55 -07:00
|
|
|
else if (firstMessageReceived && !secondMessageReceived) {
|
|
|
|
return;
|
|
|
|
}
|
2017-07-28 11:32:00 -07:00
|
|
|
// first message got lost
|
2018-05-10 15:44:55 -07:00
|
|
|
else if (!firstMessageReceived && secondMessageReceived) {
|
|
|
|
throw new Error('First message got lost');
|
|
|
|
}
|
2017-07-28 11:32:00 -07:00
|
|
|
}
|
2018-05-14 00:09:36 -07:00
|
|
|
const html =
|
2018-05-10 15:44:55 -07:00
|
|
|
'Hello world' +
|
|
|
|
'<script>' +
|
|
|
|
"window.setTimeout(function(){window.postMessage('First'); window.postMessage('Second')}, 0)" +
|
|
|
|
'</script>';
|
2017-07-28 11:32:00 -07:00
|
|
|
|
|
|
|
// fail if messages didn't get through;
|
2018-05-10 15:44:55 -07:00
|
|
|
window.setTimeout(function() {
|
|
|
|
throw new Error(
|
|
|
|
firstMessageReceived
|
|
|
|
? 'Both messages got lost'
|
|
|
|
: 'Second message got lost',
|
|
|
|
);
|
|
|
|
}, 10000);
|
2017-07-28 11:32:00 -07:00
|
|
|
|
2018-05-14 00:09:36 -07:00
|
|
|
const source = {
|
2017-07-28 11:32:00 -07:00
|
|
|
html: html,
|
2018-05-10 15:44:55 -07:00
|
|
|
};
|
2017-07-28 11:32:00 -07:00
|
|
|
|
|
|
|
return (
|
|
|
|
<WebView
|
|
|
|
source={source}
|
2018-05-10 15:44:55 -07:00
|
|
|
onMessage={processMessage}
|
2018-05-04 13:47:42 -07:00
|
|
|
originWhitelist={['about:blank']}
|
2018-05-10 15:44:55 -07:00
|
|
|
/>
|
2017-07-28 11:32:00 -07:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
WebViewTest.displayName = 'WebViewTest';
|
|
|
|
|
|
|
|
module.exports = WebViewTest;
|