diff options
author | Mike Greiling <mike@pixelcog.com> | 2018-02-28 15:13:15 -0600 |
---|---|---|
committer | Mike Greiling <mike@pixelcog.com> | 2018-02-28 15:13:15 -0600 |
commit | 2d48e5c45d4666e53d2dd6e99d451f5f8749adf0 (patch) | |
tree | 72162918daac8a67f1c101cf372ba1d2779f6312 | |
parent | db91e88bd13ce53d8fccac49a335ab4ab1d3ef16 (diff) | |
download | gitlab-ce-remove-u2f-bundle.tar.gz |
add tests for u2f browser detectionremove-u2f-bundle
-rw-r--r-- | app/assets/javascripts/u2f/util.js | 28 | ||||
-rw-r--r-- | spec/javascripts/u2f/util_spec.js | 45 |
2 files changed, 64 insertions, 9 deletions
diff --git a/app/assets/javascripts/u2f/util.js b/app/assets/javascripts/u2f/util.js index ec2bc91653e..5778f00332d 100644 --- a/app/assets/javascripts/u2f/util.js +++ b/app/assets/javascripts/u2f/util.js @@ -1,17 +1,24 @@ -export function getChromeVersion(userAgent) { - const match = userAgent.match(/Chrom(?:e|ium)\/([0-9]+)\./); +function isOpera(userAgent) { + return userAgent.indexOf('Opera') >= 0 || userAgent.indexOf('OPR') >= 0; +} + +function getOperaVersion(userAgent) { + const match = userAgent.match(/OPR[^0-9]*([0-9]+)[^0-9]+/); return match ? parseInt(match[1], 10) : false; } -export function getOperaVersion(userAgent) { - const match = userAgent.match(/Opera[^0-9]*([0-9]+)[^0-9]+/); +function isChrome(userAgent) { + return userAgent.indexOf('Chrom') >= 0 && !isOpera(userAgent); +} + +function getChromeVersion(userAgent) { + const match = userAgent.match(/Chrom(?:e|ium)\/([0-9]+)\./); return match ? parseInt(match[1], 10) : false; } -export function canInjectU2fApi() { - const userAgent = typeof navigator !== 'undefined' ? navigator.userAgent : ''; - const isSupportedChrome = userAgent.indexOf('Chrom') >= 0 && getChromeVersion(userAgent) >= 41; - const isSupportedOpera = userAgent.indexOf('Opera') >= 0 && getOperaVersion(userAgent) >= 40; +export function canInjectU2fApi(userAgent) { + const isSupportedChrome = isChrome(userAgent) && getChromeVersion(userAgent) >= 41; + const isSupportedOpera = isOpera(userAgent) && getOperaVersion(userAgent) >= 40; const isMobile = ( userAgent.indexOf('droid') >= 0 || userAgent.indexOf('CriOS') >= 0 || @@ -24,8 +31,11 @@ export default function importU2FLibrary() { if (window.u2f) { return Promise.resolve(window.u2f); } - if (canInjectU2fApi() || (gon && gon.test_env)) { + + const userAgent = typeof navigator !== 'undefined' ? navigator.userAgent : ''; + if (canInjectU2fApi(userAgent) || (gon && gon.test_env)) { return import(/* webpackMode: "eager" */ 'vendor/u2f').then(() => window.u2f); } + return Promise.reject(); } diff --git a/spec/javascripts/u2f/util_spec.js b/spec/javascripts/u2f/util_spec.js new file mode 100644 index 00000000000..4187183236f --- /dev/null +++ b/spec/javascripts/u2f/util_spec.js @@ -0,0 +1,45 @@ +import { canInjectU2fApi } from '~/u2f/util'; + +describe('U2F Utils', () => { + describe('canInjectU2fApi', () => { + it('returns false for Chrome < 41', () => { + const userAgent = 'Mozilla/5.0 (Windows NT 6.3; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/40.0.2214.28 Safari/537.36'; + expect(canInjectU2fApi(userAgent)).toBe(false); + }); + + it('returns true for Chrome >= 41', () => { + const userAgent = 'Mozilla/5.0 (Windows NT 6.3; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36'; + expect(canInjectU2fApi(userAgent)).toBe(true); + }); + + it('returns false for Opera < 40', () => { + const userAgent = 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.85 Safari/537.36 OPR/32.0.1948.25'; + expect(canInjectU2fApi(userAgent)).toBe(false); + }); + + it('returns true for Opera >= 40', () => { + const userAgent = 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36 OPR/43.0.2442.991'; + expect(canInjectU2fApi(userAgent)).toBe(true); + }); + + it('returns false for Safari', () => { + const userAgent = 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_5) AppleWebKit/603.2.4 (KHTML, like Gecko) Version/10.1.1 Safari/603.2.4'; + expect(canInjectU2fApi(userAgent)).toBe(false); + }); + + it('returns false for Chrome on Android', () => { + const userAgent = 'Mozilla/5.0 (Linux; Android 7.0; VS988 Build/NRD90U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3145.0 Mobile Safari/537.36'; + expect(canInjectU2fApi(userAgent)).toBe(false); + }); + + it('returns false for Chrome on iOS', () => { + const userAgent = 'Mozilla/5.0 (iPhone; CPU iPhone OS 10_3 like Mac OS X) AppleWebKit/602.1.50 (KHTML, like Gecko) CriOS/56.0.2924.75 Mobile/14E5239e Safari/602.1'; + expect(canInjectU2fApi(userAgent)).toBe(false); + }); + + it('returns false for Safari on iOS', () => { + const userAgent = 'Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A356 Safari/604.1'; + expect(canInjectU2fApi(userAgent)).toBe(false); + }); + }); +}); |