Page MenuHomePhabricator

[Flow202][lib][skip-ci] [0/23] Fix Flow issues relating to unsealed objects
ClosedPublic

Authored by ashoat on Nov 4 2023, 11:53 AM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 14, 12:32 AM
Unknown Object (File)
Sat, Jan 11, 10:06 PM
Unknown Object (File)
Thu, Jan 9, 7:56 PM
Unknown Object (File)
Sun, Jan 5, 5:44 PM
Unknown Object (File)
Sat, Jan 4, 3:26 PM
Unknown Object (File)
Thu, Jan 2, 3:57 PM
Unknown Object (File)
Tue, Dec 31, 3:08 PM
Unknown Object (File)
Thu, Dec 26, 5:59 PM
Subscribers

Details

Summary

In older versions of Flow, creating an empty object (eg. const test = {}) resulting in an "unsealed object" type, which had weird quirks and wasn't typechecked as closely.

The new version of Flow changes this behavior. This diff addresses those changes, mostly by introducing types to {} declarations. It also fixes issues that were surfaced after typing the unsealed objects.

NOTE: CI will fail on this diff. I considered the possibility of fixing Flow errors BEFORE upgrading Flow, but it wasn't possible... in some cases, the fixes to support the new version of Flow caused errors in the old version. I could have hidden these type errors with $FlowFixMe lines and then later revert those, but that seemed like too much busy work.

Depends on D9691

Test Plan

Confirm the Flow errors go away

Diff Detail

Repository
rCOMM Comm
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

Harbormaster returned this revision to the author for changes because remote builds failed.Nov 4 2023, 12:04 PM
Harbormaster failed remote builds in B23734: Diff 32696!
This revision is now accepted and ready to land.Nov 5 2023, 10:26 AM

Update promiseAll after seeing type errors from other invocations

  1. Prettier fixes for last revision
  2. Update tryflow link in socket.react.js
ashoat retitled this revision from [Flow202][lib] [0/23] Fix Flow issues relating to unsealed objects to [Flow202][lib][skip-ci] [0/23] Fix Flow issues relating to unsealed objects.Nov 19 2023, 11:44 AM