mirror of
https://github.com/status-im/react-native.git
synced 2025-01-21 06:49:39 +00:00
634e7e11e3
Summary: To prevent people from linking file:// or other URLs inside RN WebViews, default <WebView> to not allowing those types of URLs. This adds the originWhitelist to specify other schemes or domains to be allowed. If the url is not allowed, it will be opened in Safari/by the OS instead. Reviewed By: yungsters Differential Revision: D7833203 fbshipit-source-id: 6881acd3b434d17910240e4edd585c0a10b5df8c
42 lines
2.0 KiB
JavaScript
42 lines
2.0 KiB
JavaScript
/**
|
|
* Copyright (c) 2013-present, Facebook, Inc.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @emails oncall+react_native
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
const WebViewShared = require('WebViewShared');
|
|
|
|
describe('WebViewShared', () => {
|
|
it('extracts the origin correctly', () => {
|
|
expect(WebViewShared.extractOrigin('http://facebook.com')).toBe('http://facebook.com');
|
|
expect(WebViewShared.extractOrigin('https://facebook.com')).toBe('https://facebook.com');
|
|
expect(WebViewShared.extractOrigin('http://facebook.com:8081')).toBe('http://facebook.com:8081');
|
|
expect(WebViewShared.extractOrigin('ftp://facebook.com')).toBe('ftp://facebook.com');
|
|
expect(WebViewShared.extractOrigin('myweirdscheme://')).toBe('myweirdscheme://');
|
|
expect(WebViewShared.extractOrigin('http://facebook.com/')).toBe('http://facebook.com');
|
|
expect(WebViewShared.extractOrigin('http://facebook.com/longerurl')).toBe('http://facebook.com');
|
|
expect(WebViewShared.extractOrigin('http://facebook.com/http://facebook.com')).toBe('http://facebook.com');
|
|
expect(WebViewShared.extractOrigin('http://facebook.com//http://facebook.com')).toBe('http://facebook.com');
|
|
expect(WebViewShared.extractOrigin('http://facebook.com//http://facebook.com//')).toBe('http://facebook.com');
|
|
expect(WebViewShared.extractOrigin('about:blank')).toBe('about:blank');
|
|
});
|
|
|
|
it('rejects bad urls', () => {
|
|
expect(WebViewShared.extractOrigin('a/b')).toBeNull();
|
|
expect(WebViewShared.extractOrigin('a//b')).toBeNull();
|
|
});
|
|
|
|
it('creates a whitelist regex correctly', () => {
|
|
expect(WebViewShared.originWhitelistToRegex('http://*')).toBe('http://.*');
|
|
expect(WebViewShared.originWhitelistToRegex('*')).toBe('.*');
|
|
expect(WebViewShared.originWhitelistToRegex('*//test')).toBe('.*//test');
|
|
expect(WebViewShared.originWhitelistToRegex('*/*')).toBe('.*/.*');
|
|
expect(WebViewShared.originWhitelistToRegex('*.com')).toBe('.*\\.com');
|
|
});
|
|
});
|