Page MenuHomePhabricator

Raise Grade A JavaScript requirement from ES5 (2009) to ES6 (2015)
Closed, ResolvedPublic

Assigned To
Authored By
Nirmos
Oct 17 2017, 9:06 AM
Referenced Files
F41678710: obraz.png
Jan 14 2024, 12:48 PM
F36946073: Screenshot 2023-04-10 at 8.45.32 AM.png
Apr 10 2023, 3:49 PM
Restricted File
Apr 10 2023, 3:49 PM
F36932731: IMG_4950.jpg
Mar 30 2023, 2:40 AM
F36932730: IMG_4949.jpg
Mar 30 2023, 2:40 AM
F36932693: IMG_4948.jpg
Mar 30 2023, 1:14 AM
F36932694: IMG_4947.jpg
Mar 30 2023, 1:14 AM
Tokens
"Dislike" token, awarded by AlbanGeller."Love" token, awarded by Nux."Love" token, awarded by stjn."Love" token, awarded by SD0001."Love" token, awarded by Rexogamer."Like" token, awarded by Daimona."Like" token, awarded by Jayprakash12345."Like" token, awarded by Sunpriat2."Like" token, awarded by MusikAnimal."Like" token, awarded by Volker_E."Like" token, awarded by xSavitar."Like" token, awarded by Michael."Like" token, awarded by Ladsgroup."Like" token, awarded by SlickKilmister."Like" token, awarded by DannyS712."Like" token, awarded by Liuxinyu970226."Like" token, awarded by gabriel-wmde.

Description

T96901: ResourceLoader JavaScript parser should allow ES5 syntax features | T381537: Raise Grade A JavaScript requirement from ES2015 (ES6) to ES2017

Goal

Following T128115 which was resolved in April 2017, the next logical step would be to drop support for ES5 when the proportion of browsers in use that don't support ES6+ is low enough.

Note, for IE11 as biggest affected browser by user share, we've already set out to have special treatment for new features in March 2021.

Resources

Related Objects

Event Timeline

There are a very large number of changes, so older changes are hidden. Show Older Changes

Change 902706 merged by jenkins-bot:

[mediawiki/core@master] ResourceLoader: Raise MW JavaScript startup requirement to ES6

https://gerrit.wikimedia.org/r/902706

Change 904389 merged by jenkins-bot:

[mediawiki/core@master] es6-polyfills: Remove scripts, replace with deprecated stub

https://gerrit.wikimedia.org/r/904389

Can we drop the web2017-polyfills as well? It looks like at least the URL ones are unneeded now from us dropping IE11...

Can we drop the web2017-polyfills as well? It looks like at least the URL ones are unneeded now from us dropping IE11...

The feature check in skip-web2017-polyfills.js for URL cuts at "Firefox 54, Safari 11, and Chrome 71".

The ES6 check in startup.js cuts at "Firefox 58+, Safari 11.1+, and Chrome 63+" (as of change 904851).

The leaves a gap in the form of Chrome releases from Dec 2017 to Jan 2019. Those are considered "Grade X" today, so we could cut them through an extra startup check, otherwise, they'll likely fall of the next time we raise the general level (~ in 1 year's time).

For now I'd say keep using web2017-polyfills in the knowledge that it safely no-ops and downloads no extra code for the majority of browsers.

Change 904851 had a related patch set uploaded (by Krinkle; author: Krinkle):

[mediawiki/core@master] ResourceLoader: Tweak startup.js known browsers explanation

https://gerrit.wikimedia.org/r/904851

Just noting because there were some user complaints on project:Support_desk, and it doesn't seem to be mentioned here explicitly - Firefox 52 is the last supported version on windows vista, which is no longer supported.

After the updates on April 6, 2023, most of the JavaScript-based functions required to work in the Wikipedia project stopped working.
Operating system Windows XP Professional Service Pack 3.
Browser Google Chrome 49.0.2623.112.
Please, bring back Java Script support for older browsers.

@Jim_Hokins: No, see reasons above. Please upgrade your insecure old browsers instead.

Windows XP has been unsupported for 9 years, Chrome 49 for 7 years. JavaScript engines are infamous for containing tons of security bugs, so it is your own best interest not to use JavaScript either on Wikimedia sites or on any other sites (go to chrome://settings/content to entirely disable JS in Chrome). And of course to upgrade to a supported operating system and browser ASAP (Windows 10/11 being the most natural choice, but you may try Lubuntu (64-bit only) or Debian (both 32-bit and 64-bit, but requires a bit more setup) if you’re tight on resources – which is probably the case if you’re still using XP).

Ребята, мне не нужны советы вида "Обновите браузер/обновите операционную систему/обновите оборудование". Я тупо хочу продолжать редактировать Википедию, ничего не меняя. Если вы не хотите, чтобы я редактировла Википедию, то скажите об этом прямо. Мне не трудно будет перестать этим заниматься.

And we don’t need people crying and protesting when we say them that their systems are insanely outdated. You don’t have to upgrade. You don’t even have to upgrade to continue to be able to edit Wikipedia. But you have to accept that the web went on and some extra features no longer work on insanely outdated systems. Supporting these systems takes extra time for developers. Extra time that could be spent on fixing bugs or developing new features. It also means a lot of extra code that every user, and not just those who cling to use these ancient browsers, need to download, causing extra bandwidth usage and download time. Bandwidth usage that could be spent on downloading more articles and time that could be spent on actually reading the articles instead of just waiting for them to load.

Tacsipacsi, сынок, я не плачусь, ты попутал. Плачешься ты. А я просто ухожу. Успехов.

Note: Windows XP with IE or Chrome has not been able to connect to Wikipedia to read (much less, utilize JavaScript) for several years due to newer TLS ciphers required by our HTTPS stack.

Firefox 52 ESR however will continue to be available on Windows XP for a basic experience. The basic experience includes search, login, and most importantly: Editing (albeit through wikitext rather than the visual editor). Nothing about this task is removing the ability to edit for any browser, in accordance with our robust frontend strategy and compatibility guidelines.

Refer to https://wikitech.wikimedia.org/wiki/HTTPS/Browser_Recommendations for instructions on what browsers are recommended on older operating systems.

Note: Windows XP with IE or Chrome has not been able to connect to Wikipedia to read (much less, utilize JavaScript) for several years due to newer TLS ciphers required by our HTTPS stack.

Actually, I just tried Chrome 49 on a Windows XP SP3 virtual machine, and Wikipedia loaded fine. IE6 indeed didn’t load any HTTPS site (not even Wikitech).

Recording here, so this is not lost - this fixed quite a few JS errors in our code:

  • SyntaxError: Block-scoped declarations (let, const, function, class) not yet supported outside strict mode - there were 7,655 instances of this error in wmf2, 0 so far in wmf3

{F36946069}

  • All SyntaxErrors

104,726 instances of this error in wmf2, and only 17,685 so far in wmf3

Screenshot 2023-04-10 at 8.45.32 AM.png (276×2 px, 56 KB)

xs

{F36946069}

This image is not visible, could you please attach to the task? Thanks in advance!

xs

What does this mean?

I assume it is this change which has removed a swathe of functionality for users of Puffin Browser, a remote browser. Until now this has been a great choice for speed and UI on iPad. However, now I have lost editing toolbar (formatting, cite and advanced tools), Wiki markup beneath the editing window, collapsed sections of pages, XFDCloser, triangles to look in subcats on category pages...

This adds up to a significant hindrance to me as one of the lead admins on enwiki Categories for Discussion.

@Fayenatic_london: I'd recommend to contact Puffin developers to improve support for ECMAScript 2015 (ES6) in Puffin Browser.
Please refer to https://wikitech.wikimedia.org/wiki/HTTPS/Browser_Recommendations for instructions on what browsers are recommended on certain systems.

@Aklapper note that it is not just ES6 what we require. We dropped ES5 browsers and made ES6 a requirement, but there are additional requirements !

We target ES6 + Promise finally (ES 2018, but was implemented pretty early by most browsers) + Array includes (ES 2016, but present in most ES6 browsers) + Arrow function support + Regexp flags support.

This is clear in iOS Safari 10 vs iOS Safari 11 support. While 10 does implement ES6, and even ES 2016 in 10.1, it doesn't have 2018 promise finally (which arrived in 11.3). The last version of Safari 10 was made in 2016, and the last release of Safari 11 was in 2018. So while we do not require full ES2017/2018 support, we do require some parts of it.

@Krinkle I'm looking at the numbers and I'm wondering if maybe we made a mistake in the analysis? I notice that everywhere we indicate that promise.finally is ES6, but Promise.finally is ES2018. The feature check was gating the promise polyfill because the polyfill was implementing es6 AND es2018 features. This also reflects why originally we were stating Safari 10 instead of Safari 11.

I doubt the usage numbers are very significant, but perhaps we should double check if we should move the promise polyfill back in ? It could be more users than all of IE11.....

Note that all browsers on iOS use WebKit engine (Chrome, Opera and even Firefox). So I doubt Puffin Browser can do anything about what they support. This is due to Apple policy which bans browser engines on their store. I guess most devs know that, but every browser on iOS is a skin over Safari (mostly).

So if you require Safari 11 then iPhones/iPads roughly from <del>2017</del> 2014 should be fine (and older then that won't get JS).
In contrast Android version 4.4 received browser updates last time I checked so Android devices from about October 2013 should be fine (at least with Chrome and possibly Firefox). Don't have Android 4.4 handy to confirm, but VE works fine on Android 5.0 in Chrome 75. FF 111 also works on Android 5.0.

Note that all browsers on iOS use WebKit engine (Chrome, Opera and even Firefox). So I doubt Puffin Browser can do anything about what they support. This is due to Apple policy which bans browser engines on their store. I guess most devs know that, but every browser on iOS is a skin over Safari (mostly).

Puffin browser allegedly gets arround that by streaming a video of chromium running somewhere in the cloud.

Firefox 68 ESR was the last version to support Android 4.4. So KitKat users still get JS, but their Firefox is no longer graded A (which means the last two ESR versions on Android as well, even though 68 was AFAIK the only version that was really released as ESR on Android?).

This is the current status of JavaScript feature support beyond ES5 in mainstream browsers passing current check:

Conclusion: We can now use all JavaScript features up to ES2017, plus non-regex features in ES2018.

I propose the next step after this task is to remove JavaScript from browser without globalThis support (which is one of ES2020 features, but supports somewhat earlier in browsers).

Currently https://phabricator.wikimedia.org/source/mediawiki/browse/master/resources/src/startup/startup.js contains more than 10 lines (and more than 30 if comments are counted) inside isCompatible and this doing so will simplify the entire check to one line: 'globalThis' in window.

Currently the check in startup.js cuts at: Firefox 58+, Safari 11.1+, Chrome 63+, Opera 50+, Edge 79+; 95.63% (95.65% - 0.02% of Edge 18) usage

And the proposed check will cut at: Firefox 65+, Safari 12.2+, Chrome 71+, Opera 58+, Edge 79+; 94.32% usage

For comparison this is some of minimum versions for ES2016-ES2020 features mentioned at T277675: Add native support for ES2016-ES2020 or higher versions to the minifier:

The following features should be fully supported in mainstream browsers passing current check:

  • (ES2016) ** operator - Firefox 52+, Safari 10.3+, Chrome 52+, Opera 39+, Edge 14+
  • (ES2017) Object.values - Firefox 47+, Safari 10.1+, Chrome 54+, Opera 41+, Edge 14+
  • (ES2017) async functions - Firefox 52+, Safari 11+, Chrome 55+, Opera 42+, Edge 15+
  • (ES2017) padStart - Firefox 48+, Safari 10+, Chrome 57+, Opera 44+, Edge 15+
  • (ES2018) for await - Firefox 58+, Safari 11.1+, Chrome 63+, Opera 50+, Edge 18+
  • (ES2018) spread (...) syntax - Firefox 16+, Safari 8+, Chrome 46+, Opera 37+, Edge 12+
  • (ES2019) optional catch binding - Firefox 58+, Safari 11.1+, Chrome 63+, Opera 50+, Edge 18+

The following requires a higher threshold (though lower than proposed in this task):

  • (ES2019) trimStart - Firefox 58+, Safari 11.1+, Chrome 66+, Opera 53+, Edge 79+ (the only gap is Chrome 63-65 and Opera 50-52)
  • (ES2019) flatMap - Firefox 62+, Safari 12+, Chrome 69+, Opera 56+, Edge 79+
  • (ES2020) import.meta - Firefox 62+, Safari 11.1+, Chrome 64+, Opera 51+, Edge 79+ (the only gap is Chrome 63, Opera 50 and Firefox 58-61)

The following requires a higher threshold than proposed in this task:

  • (ES2019) Object.fromEntries - Firefox 63+, Safari 12.1+, Chrome 73+, Opera 60+, Edge 79+
  • (ES2020) ?? and ?. operators, dynamic import (requires Firefox 67), export * as Foo from 'bar', BigInt (requires Safari 14), matchAll(), Promise.allSettled()

Conclusion: We can now use all JavaScript features up to ES2017, plus non-regex features in ES2018.

Note: as of now, the minifier supports only upto ES2016. So using async functions and the like will have to wait for minifier upgrades. T277675 is the task to track that I believe.

Change 904851 merged by jenkins-bot:

[mediawiki/core@master] ResourceLoader: Tweak startup.js known browsers explanation

https://gerrit.wikimedia.org/r/904851

Change 913663 had a related patch set uploaded (by Krinkle; author: Krinkle):

[mediawiki/core@master] ResourceLoader: Fix startup.js comment, Promise.finally is ES2018

https://gerrit.wikimedia.org/r/913663

@Krinkle I'm looking at the numbers and I'm wondering if maybe we made a mistake in the analysis? I notice that everywhere we indicate that promise.finally is ES6, but Promise.finally is ES2018.

Good catch. I've fixed the startup.js comment in https://gerrit.wikimedia.org/r/913663.

I doubt the usage numbers are very significant, but perhaps we should double check if we should move the promise polyfill back in? It could be more users than all of IE11.....

As I understand it, our current Compatibility policy doesn't cover Safari 10 either way. The policy is always a subset of the wider range of Grade X browsers that technically pass the feature test. E.g. there are about 3 years of Firefox releases that we don't "support" but do meet all present day technical requirements and so continue to recieve the full experience today the same way we also provide it to lesser known browser families that meet the requirements (per T102318: Convert startup blacklist to feature test).

Regarding other ES2018 features, there is a notable gap between ratifying a specification and the last major browser shipping an implementation. Some features ship in all browsers ahead of the spec finalising, others take decades to ship or get cancelled after some time (e.g. some ES2015/ES6 features still haven't shipped). Hence the fact that we guruantee presence of one ES2018-based API is not reason to bump the general grammar and runtime requirement to ES2018 or to guruantee other <= ES2018 features.

Change 913663 merged by jenkins-bot:

[mediawiki/core@master] ResourceLoader: Fix startup.js comment, Promise.finally is ES2018

https://gerrit.wikimedia.org/r/913663

As a note, for users still running Windows XP they may install an unofficial derived browser based on Chromium, such as https://en.wikipedia.org/wiki/360_Secure_Browser which (as of version 13) is based on Chromium 86.

(ES2018) for await - Firefox 58+, Safari 11.1+, Chrome 63+, Opera 50+, Edge 18+

For the record: This is incorrect. Both async and await comes with ES2017/ES8. See e.g.: https://flaviocopes.com/es2017/#async-functions and also https://262.ecma-international.org/8.0/

Browser support: https://caniuse.com/?search=await
Firefox 52+ does support async/await: https://developer.mozilla.org/en-US/docs/Mozilla/Firefox/Releases/52

I noticed MW core doesn't support Windows XP now, but async/await would work. To be clear, I'm kind of glad sites stopped supporting Windows XP ;-), but just wanted to get the facts straight.

obraz.png (1×1 px, 226 KB)

(ES2018) spread (...) syntax - Firefox 16+, Safari 8+, Chrome 46+, Opera 37+, Edge 12+

This is also incorrect. Both spread and destructive assignment is part of ES6/ES2015:
https://compat-table.github.io/compat-table/es6/

(ES2018) for await - Firefox 58+, Safari 11.1+, Chrome 63+, Opera 50+, Edge 18+

For the record: This is incorrect. Both async and await comes with ES2017/ES8. See e.g.: https://flaviocopes.com/es2017/#async-functions and also https://262.ecma-international.org/8.0/

It's not incorrect. for await is for asynchronous iteration which appeared only in ES2018. https://caniuse.com/?search=for%20await

(ES2018) for await - Firefox 58+, Safari 11.1+, Chrome 63+, Opera 50+, Edge 18+

For the record: This is incorrect. Both async and await comes with ES2017/ES8. See e.g.: https://flaviocopes.com/es2017/#async-functions and also https://262.ecma-international.org/8.0/

It's not incorrect. for await is for asynchronous iteration which appeared only in ES2018. https://caniuse.com/?search=for%20await

Oh, sorry. I thought that was "for await" as in "as for await" ;)

So I guess this:

(ES2018) spread (...) syntax - Firefox 16+, Safari 8+, Chrome 46+, Opera 37+, Edge 12+

Might mean not spread in general, but spread in objects like this one:

let { x, y, ...z } = { x: 1, y: 2, a: 3, b: 4 };
x; // 1
y; // 2
z; // { a: 3, b: 4 }

https://github.com/tc39/proposal-object-rest-spread

But spread in objects is not supported in FF52:
https://web.archive.org/web/20180721150407/http://kangax.github.io/compat-table/es2016plus/

So that info about spread is still somewhat inaccurate.