Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow implicit return with explicit undefined return type #53092

Merged
merged 9 commits into from
Mar 17, 2023

Conversation

saschanaz
Copy link
Contributor

Fixes #36288

@typescript-bot typescript-bot added the For Uncommitted Bug PR for untriaged, rejected, closed or missing bug label Mar 4, 2023
@typescript-bot
Copy link
Collaborator

The TypeScript team hasn't accepted the linked issue #36288. If you can get it accepted, this PR will have a better chance of being reviewed.

// Fine since are typed any.
return;
}

function f9(): void {
function f9(): any {
// Fine since we are typed any and return undefined
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(To match the comments, as otherwise these two are exactly same with f5 and f6.)

@jakebailey
Copy link
Member

@typescript-bot test this
@typescript-bot test top100
@typescript-bot user test this
@typescript-bot run dt
@typescript-bot perf test this
@typescript-bot pack this

@typescript-bot
Copy link
Collaborator

typescript-bot commented Mar 4, 2023

Heya @jakebailey, I've started to run the diff-based top-repos suite on this PR at 3bee8eb. You can monitor the build here.

Update: The results are in!

@typescript-bot
Copy link
Collaborator

typescript-bot commented Mar 4, 2023

Heya @jakebailey, I've started to run the tarball bundle task on this PR at 3bee8eb. You can monitor the build here.

@typescript-bot
Copy link
Collaborator

typescript-bot commented Mar 4, 2023

Heya @jakebailey, I've started to run the parallelized Definitely Typed test suite on this PR at 3bee8eb. You can monitor the build here.

Update: The results are in!

@typescript-bot
Copy link
Collaborator

typescript-bot commented Mar 4, 2023

Heya @jakebailey, I've started to run the extended test suite on this PR at 3bee8eb. You can monitor the build here.

@typescript-bot
Copy link
Collaborator

typescript-bot commented Mar 4, 2023

Heya @jakebailey, I've started to run the perf test suite on this PR at 3bee8eb. You can monitor the build here.

Update: The results are in!

@typescript-bot
Copy link
Collaborator

typescript-bot commented Mar 4, 2023

Heya @jakebailey, I've started to run the diff-based user code test suite on this PR at 3bee8eb. You can monitor the build here.

Update: The results are in!

@typescript-bot
Copy link
Collaborator

typescript-bot commented Mar 4, 2023

Hey @jakebailey, I've packed this into an installable tgz. You can install it for testing by referencing it in your package.json like so:

{
    "devDependencies": {
        "typescript": "https://typescript.visualstudio.com/cf7ac146-d525-443c-b23c-0d58337efebc/_apis/build/builds/148246/artifacts?artifactName=tgz&fileId=82C1D525C0488DE608808B718A39774814B6F87A373D180D94EA38CA7D69C2B002&fileName=/typescript-5.1.0-insiders.20230304.tgz"
    }
}

and then running npm install.


There is also a playground for this build and an npm module you can use via "typescript": "npm:@typescript-deploys/[email protected]".;

@typescript-bot
Copy link
Collaborator

@jakebailey Here are the results of running the user test suite comparing main and refs/pull/53092/merge:

Everything looks good!

@typescript-bot
Copy link
Collaborator

@jakebailey
The results of the perf run you requested are in!

Here they are:

Compiler

Comparison Report - main..53092
Metric main 53092 Delta Best Worst p-value
Angular - node (v18.10.0, x64)
Memory used 359,740k (± 0.02%) 359,775k (± 0.02%) ~ 359,686k 359,853k p=0.575 n=6
Parse Time 3.48s (± 0.80%) 3.48s (± 0.62%) ~ 3.45s 3.51s p=0.747 n=6
Bind Time 1.13s (± 0.74%) 1.13s (± 0.56%) ~ 1.12s 1.14s p=0.226 n=6
Check Time 8.66s (± 0.54%) 8.64s (± 0.53%) ~ 8.59s 8.72s p=0.629 n=6
Emit Time 7.43s (± 0.35%) 7.41s (± 0.71%) ~ 7.33s 7.49s p=0.257 n=6
Total Time 20.69s (± 0.29%) 20.65s (± 0.28%) ~ 20.59s 20.76s p=0.171 n=6
Compiler-Unions - node (v18.10.0, x64)
Memory used 192,551k (± 1.49%) 191,706k (± 1.23%) ~ 190,593k 196,526k p=0.810 n=6
Parse Time 1.49s (± 0.55%) 1.48s (± 1.16%) ~ 1.46s 1.51s p=0.452 n=6
Bind Time 0.77s (± 0.67%) 0.77s (± 0.98%) ~ 0.76s 0.78s p=0.784 n=6
Check Time 9.35s (± 0.57%) 9.38s (± 0.63%) ~ 9.32s 9.49s p=0.935 n=6
Emit Time 2.73s (± 1.05%) 2.73s (± 0.54%) ~ 2.71s 2.75s p=0.746 n=6
Total Time 14.33s (± 0.53%) 14.36s (± 0.42%) ~ 14.30s 14.47s p=0.936 n=6
Monaco - node (v18.10.0, x64)
Memory used 343,850k (± 0.01%) 343,857k (± 0.01%) ~ 343,812k 343,921k p=0.689 n=6
Parse Time 2.63s (± 0.39%) 2.62s (± 0.92%) ~ 2.60s 2.66s p=0.462 n=6
Bind Time 1.00s (± 1.22%) 1.01s (± 0.81%) ~ 1.00s 1.02s p=1.000 n=6
Check Time 7.00s (± 0.52%) 6.99s (± 0.71%) ~ 6.93s 7.05s p=0.574 n=6
Emit Time 4.24s (± 0.77%) 4.23s (± 0.55%) ~ 4.20s 4.26s p=0.686 n=6
Total Time 14.88s (± 0.41%) 14.85s (± 0.51%) ~ 14.75s 14.95s p=0.377 n=6
TFS - node (v18.10.0, x64)
Memory used 299,880k (± 0.01%) 299,866k (± 0.01%) ~ 299,843k 299,918k p=0.298 n=6
Parse Time 2.04s (± 0.51%) 2.04s (± 0.98%) ~ 2.01s 2.06s p=0.461 n=6
Bind Time 1.13s (± 0.36%) 1.14s (± 0.66%) ~ 1.13s 1.15s p=0.100 n=6
Check Time 6.49s (± 0.42%) 6.50s (± 0.38%) ~ 6.47s 6.54s p=1.000 n=6
Emit Time 3.85s (± 0.73%) 3.83s (± 0.60%) ~ 3.80s 3.87s p=0.375 n=6
Total Time 13.51s (± 0.27%) 13.51s (± 0.43%) ~ 13.46s 13.62s p=0.518 n=6
material-ui - node (v18.10.0, x64)
Memory used 476,423k (± 0.00%) 476,438k (± 0.00%) +14k (+ 0.00%) 476,430k 476,450k p=0.020 n=6
Parse Time 3.11s (± 0.43%) 3.11s (± 0.72%) ~ 3.08s 3.13s p=0.744 n=6
Bind Time 0.91s (± 0.57%) 0.91s (± 0.98%) ~ 0.90s 0.92s p=0.541 n=6
Check Time 17.06s (± 0.44%) 17.02s (± 0.44%) ~ 16.93s 17.13s p=0.520 n=6
Emit Time 0.00s (± 0.00%) 0.00s (± 0.00%) ~ 0.00s 0.00s p=1.000 n=6
Total Time 21.07s (± 0.37%) 21.04s (± 0.34%) ~ 20.96s 21.12s p=0.810 n=6
xstate - node (v18.10.0, x64)
Memory used 548,865k (± 0.02%) 548,948k (± 0.02%) ~ 548,848k 549,094k p=0.173 n=6
Parse Time 4.07s (± 0.55%) 4.07s (± 0.41%) ~ 4.05s 4.09s p=0.627 n=6
Bind Time 1.67s (± 0.59%) 1.66s (± 0.62%) ~ 1.65s 1.67s p=0.557 n=6
Check Time 2.76s (± 0.74%) 2.75s (± 0.65%) ~ 2.73s 2.78s p=0.466 n=6
Emit Time 0.08s (± 4.99%) 0.08s (± 4.99%) ~ 0.08s 0.09s p=1.000 n=6
Total Time 8.58s (± 0.38%) 8.57s (± 0.26%) ~ 8.54s 8.61s p=0.870 n=6
Angular - node (v16.17.1, x64)
Memory used 359,078k (± 0.00%) 359,088k (± 0.01%) ~ 359,035k 359,127k p=0.298 n=6
Parse Time 3.72s (± 0.22%) 3.71s (± 0.20%) ~ 3.70s 3.72s p=0.652 n=6
Bind Time 1.19s (± 0.46%) 1.19s (± 0.63%) ~ 1.18s 1.20s p=0.137 n=6
Check Time 9.42s (± 0.62%) 9.41s (± 0.56%) ~ 9.33s 9.49s p=0.627 n=6
Emit Time 7.90s (± 0.84%) 7.88s (± 0.54%) ~ 7.84s 7.95s p=0.572 n=6
Total Time 22.23s (± 0.25%) 22.19s (± 0.17%) ~ 22.13s 22.24s p=0.196 n=6
Compiler-Unions - node (v16.17.1, x64)
Memory used 192,383k (± 0.03%) 192,348k (± 0.02%) ~ 192,315k 192,428k p=0.521 n=6
Parse Time 1.56s (± 0.52%) 1.56s (± 1.43%) ~ 1.52s 1.58s p=0.739 n=6
Bind Time 0.82s (± 0.00%) 0.82s (± 0.63%) ~ 0.82s 0.83s p=0.174 n=6
Check Time 10.12s (± 0.60%) 10.11s (± 0.39%) ~ 10.04s 10.15s p=0.809 n=6
Emit Time 2.98s (± 0.86%) 2.98s (± 0.97%) ~ 2.95s 3.03s p=0.567 n=6
Total Time 15.48s (± 0.45%) 15.46s (± 0.18%) ~ 15.43s 15.50s p=0.748 n=6
Monaco - node (v16.17.1, x64)
Memory used 343,113k (± 0.00%) 343,105k (± 0.00%) ~ 343,081k 343,121k p=0.574 n=6
Parse Time 2.79s (± 0.27%) 2.79s (± 0.54%) ~ 2.78s 2.82s p=0.503 n=6
Bind Time 1.08s (± 0.76%) 1.08s (± 0.59%) ~ 1.07s 1.09s p=0.599 n=6
Check Time 7.67s (± 0.37%) 7.65s (± 0.41%) ~ 7.62s 7.69s p=0.373 n=6
Emit Time 4.42s (± 0.44%) 4.42s (± 0.49%) ~ 4.38s 4.44s p=0.868 n=6
Total Time 15.97s (± 0.18%) 15.96s (± 0.25%) ~ 15.90s 16.00s p=0.806 n=6
TFS - node (v16.17.1, x64)
Memory used 299,227k (± 0.01%) 299,236k (± 0.01%) ~ 299,202k 299,253k p=0.297 n=6
Parse Time 2.17s (± 0.48%) 2.17s (± 0.86%) ~ 2.14s 2.19s p=0.935 n=6
Bind Time 1.24s (± 0.41%) 1.24s (± 0.33%) ~ 1.24s 1.25s p=0.595 n=6
Check Time 7.17s (± 0.39%) 7.16s (± 0.28%) ~ 7.14s 7.19s p=0.624 n=6
Emit Time 4.33s (± 0.65%) 4.33s (± 0.61%) ~ 4.30s 4.38s p=1.000 n=6
Total Time 14.91s (± 0.15%) 14.91s (± 0.30%) ~ 14.86s 14.98s p=0.624 n=6
material-ui - node (v16.17.1, x64)
Memory used 475,669k (± 0.01%) 475,658k (± 0.00%) ~ 475,629k 475,677k p=0.336 n=6
Parse Time 3.28s (± 0.42%) 3.28s (± 0.32%) ~ 3.27s 3.30s p=1.000 n=6
Bind Time 0.96s (± 0.57%) 0.96s (± 0.54%) ~ 0.95s 0.96s p=0.640 n=6
Check Time 17.99s (± 0.24%) 18.03s (± 0.35%) ~ 17.96s 18.12s p=0.419 n=6
Emit Time 0.00s (± 0.00%) 0.00s (± 0.00%) ~ 0.00s 0.00s p=1.000 n=6
Total Time 22.23s (± 0.16%) 22.27s (± 0.31%) ~ 22.20s 22.39s p=0.261 n=6
xstate - node (v16.17.1, x64)
Memory used 546,456k (± 0.02%) 546,450k (± 0.02%) ~ 546,316k 546,619k p=0.936 n=6
Parse Time 4.28s (± 0.54%) 4.26s (± 0.27%) ~ 4.24s 4.27s p=0.169 n=6
Bind Time 1.77s (± 0.46%) 1.76s (± 0.43%) ~ 1.75s 1.77s p=0.120 n=6
Check Time 2.98s (± 0.76%) 2.96s (± 0.50%) ~ 2.95s 2.98s p=0.120 n=6
Emit Time 0.09s (± 5.53%) 0.09s (± 4.45%) ~ 0.09s 0.10s p=0.595 n=6
Total Time 9.11s (± 0.36%) 9.08s (± 0.22%) -0.04s (- 0.40%) 9.05s 9.11s p=0.041 n=6
Angular - node (v14.15.1, x64)
Memory used 352,866k (± 0.00%) 352,876k (± 0.00%) ~ 352,858k 352,890k p=0.199 n=6
Parse Time 3.71s (± 0.37%) 3.69s (± 0.37%) ~ 3.68s 3.72s p=0.158 n=6
Bind Time 1.25s (± 0.60%) 1.25s (± 0.97%) ~ 1.24s 1.27s p=0.485 n=6
Check Time 9.73s (± 0.31%) 9.71s (± 0.85%) ~ 9.60s 9.82s p=1.000 n=6
Emit Time 8.29s (± 0.35%) 8.32s (± 0.83%) ~ 8.25s 8.44s p=1.000 n=6
Total Time 22.98s (± 0.26%) 22.97s (± 0.57%) ~ 22.83s 23.14s p=0.810 n=6
Compiler-Unions - node (v14.15.1, x64)
Memory used 187,621k (± 0.01%) 187,629k (± 0.01%) ~ 187,604k 187,656k p=0.689 n=6
Parse Time 1.57s (± 0.80%) 1.58s (± 0.87%) ~ 1.56s 1.59s p=0.564 n=6
Bind Time 0.84s (± 0.00%) 0.84s (± 0.75%) ~ 0.83s 0.85s p=1.000 n=6
Check Time 10.15s (± 0.60%) 10.16s (± 0.55%) ~ 10.11s 10.25s p=0.870 n=6
Emit Time 3.12s (± 0.92%) 3.13s (± 0.72%) ~ 3.09s 3.15s p=0.466 n=6
Total Time 15.67s (± 0.45%) 15.70s (± 0.52%) ~ 15.64s 15.83s p=0.810 n=6
Monaco - node (v14.15.1, x64)
Memory used 338,108k (± 0.00%) 338,133k (± 0.01%) +25k (+ 0.01%) 338,105k 338,162k p=0.037 n=6
Parse Time 2.87s (± 0.46%) 2.87s (± 0.92%) ~ 2.84s 2.91s p=0.742 n=6
Bind Time 1.10s (± 0.94%) 1.09s (± 0.50%) ~ 1.09s 1.10s p=0.138 n=6
Check Time 8.07s (± 0.50%) 8.08s (± 0.35%) ~ 8.04s 8.11s p=0.685 n=6
Emit Time 4.67s (± 1.03%) 4.67s (± 0.66%) ~ 4.64s 4.73s p=0.808 n=6
Total Time 16.72s (± 0.45%) 16.72s (± 0.19%) ~ 16.68s 16.77s p=0.630 n=6
TFS - node (v14.15.1, x64)
Memory used 294,292k (± 0.00%) 294,296k (± 0.01%) ~ 294,265k 294,309k p=0.748 n=6
Parse Time 2.37s (± 1.05%) 2.38s (± 0.57%) ~ 2.36s 2.40s p=0.462 n=6
Bind Time 1.06s (± 0.38%) 1.06s (± 0.60%) ~ 1.05s 1.07s p=0.673 n=6
Check Time 7.42s (± 0.47%) 7.47s (± 0.61%) ~ 7.43s 7.54s p=0.250 n=6
Emit Time 4.26s (± 0.75%) 4.28s (± 0.36%) ~ 4.26s 4.30s p=0.217 n=6
Total Time 15.11s (± 0.40%) 15.19s (± 0.47%) ~ 15.12s 15.31s p=0.092 n=6
material-ui - node (v14.15.1, x64)
Memory used 471,392k (± 0.00%) 471,362k (± 0.00%) -31k (- 0.01%) 471,338k 471,385k p=0.020 n=6
Parse Time 3.45s (± 0.51%) 3.45s (± 0.57%) ~ 3.42s 3.47s p=1.000 n=6
Bind Time 1.00s (± 1.04%) 1.00s (± 0.75%) ~ 0.99s 1.01s p=0.273 n=6
Check Time 18.91s (± 0.34%) 18.95s (± 0.59%) ~ 18.88s 19.18s p=0.467 n=6
Emit Time 0.00s (± 0.00%) 0.00s (± 0.00%) ~ 0.00s 0.00s p=1.000 n=6
Total Time 23.37s (± 0.28%) 23.40s (± 0.53%) ~ 23.30s 23.64s p=0.936 n=6
xstate - node (v14.15.1, x64)
Memory used 535,172k (± 0.00%) 535,172k (± 0.00%) ~ 535,156k 535,200k p=0.810 n=6
Parse Time 4.45s (± 0.46%) 4.47s (± 0.52%) ~ 4.43s 4.50s p=0.417 n=6
Bind Time 1.79s (± 0.46%) 1.79s (± 0.50%) ~ 1.78s 1.80s p=0.550 n=6
Check Time 3.18s (± 0.59%) 3.16s (± 0.66%) ~ 3.14s 3.19s p=0.259 n=6
Emit Time 0.09s (± 4.45%) 0.09s (± 0.00%) ~ 0.09s 0.09s p=0.405 n=6
Total Time 9.51s (± 0.38%) 9.51s (± 0.44%) ~ 9.44s 9.56s p=0.748 n=6
System
Machine Namets-ci-ubuntu
Platformlinux 5.4.0-135-generic
Architecturex64
Available Memory16 GB
Available Memory15 GB
CPUs4 × Intel(R) Core(TM) i7-4770 CPU @ 3.40GHz
Hosts
  • node (v18.10.0, x64)
  • node (v16.17.1, x64)
  • node (v14.15.1, x64)
Scenarios
  • Angular - node (v18.10.0, x64)
  • Angular - node (v16.17.1, x64)
  • Angular - node (v14.15.1, x64)
  • Compiler-Unions - node (v18.10.0, x64)
  • Compiler-Unions - node (v16.17.1, x64)
  • Compiler-Unions - node (v14.15.1, x64)
  • Monaco - node (v18.10.0, x64)
  • Monaco - node (v16.17.1, x64)
  • Monaco - node (v14.15.1, x64)
  • TFS - node (v18.10.0, x64)
  • TFS - node (v16.17.1, x64)
  • TFS - node (v14.15.1, x64)
  • material-ui - node (v18.10.0, x64)
  • material-ui - node (v16.17.1, x64)
  • material-ui - node (v14.15.1, x64)
  • xstate - node (v18.10.0, x64)
  • xstate - node (v16.17.1, x64)
  • xstate - node (v14.15.1, x64)
Benchmark Name Iterations
Current 53092 6
Baseline main 6

TSServer

Comparison Report - main..53092
Metric main 53092 Delta Best Worst p-value
Compiler-UnionsTSServer - node (v18.10.0, x64)
Req 1 - updateOpen 2,359ms (± 0.46%) 2,365ms (± 0.64%) ~ 2,350ms 2,392ms p=0.628 n=6
Req 2 - geterr 5,337ms (± 0.24%) 5,337ms (± 0.47%) ~ 5,303ms 5,366ms p=1.000 n=6
Req 3 - references 325ms (± 0.45%) 330ms (± 1.19%) ~ 325ms 336ms p=0.053 n=6
Req 4 - navto 285ms (± 0.72%) 283ms (± 0.84%) ~ 280ms 286ms p=0.170 n=6
Req 5 - completionInfo count 1,356 (± 0.00%) 1,356 (± 0.00%) ~ 1,356 1,356 p=1.000 n=6
Req 5 - completionInfo 79ms (± 1.13%) 81ms (± 7.67%) ~ 72ms 89ms p=0.677 n=6
CompilerTSServer - node (v18.10.0, x64)
Req 1 - updateOpen 2,516ms (± 0.66%) 2,497ms (± 0.75%) ~ 2,474ms 2,526ms p=0.109 n=6
Req 2 - geterr 4,009ms (± 0.59%) 4,003ms (± 0.53%) ~ 3,974ms 4,035ms p=0.470 n=6
Req 3 - references 346ms (± 0.72%) 348ms (± 0.76%) ~ 346ms 353ms p=0.195 n=6
Req 4 - navto 292ms (± 0.80%) 293ms (± 0.29%) ~ 291ms 293ms p=0.797 n=6
Req 5 - completionInfo count 1,518 (± 0.00%) 1,518 (± 0.00%) ~ 1,518 1,518 p=1.000 n=6
Req 5 - completionInfo 72ms (± 4.68%) 77ms (± 5.46%) ~ 72ms 84ms p=0.059 n=6
xstateTSServer - node (v18.10.0, x64)
Req 1 - updateOpen 3,168ms (± 0.37%) 3,159ms (± 0.57%) ~ 3,132ms 3,183ms p=0.469 n=6
Req 2 - geterr 1,600ms (± 0.44%) 1,599ms (± 0.96%) ~ 1,582ms 1,621ms p=1.000 n=6
Req 3 - references 103ms (± 2.42%) 103ms (± 1.13%) ~ 102ms 105ms p=0.677 n=6
Req 4 - navto 360ms (± 1.35%) 361ms (± 1.51%) ~ 354ms 371ms p=0.257 n=6
Req 5 - completionInfo count 3,136 (± 0.00%) 3,136 (± 0.00%) ~ 3,136 3,136 p=1.000 n=6
Req 5 - completionInfo 428ms (± 0.46%) 425ms (± 1.47%) ~ 416ms 434ms p=0.465 n=6
Compiler-UnionsTSServer - node (v16.17.1, x64)
Req 1 - updateOpen 2,476ms (± 1.27%) 2,471ms (± 1.59%) ~ 2,429ms 2,523ms p=0.810 n=6
Req 2 - geterr 5,728ms (± 0.55%) 5,736ms (± 0.58%) ~ 5,677ms 5,774ms p=0.689 n=6
Req 3 - references 342ms (± 0.68%) 342ms (± 0.73%) ~ 339ms 345ms p=0.870 n=6
Req 4 - navto 279ms (± 1.69%) 278ms (± 0.75%) ~ 275ms 280ms p=0.805 n=6
Req 5 - completionInfo count 1,356 (± 0.00%) 1,356 (± 0.00%) ~ 1,356 1,356 p=1.000 n=6
Req 5 - completionInfo 94ms (± 4.70%) 91ms (± 5.93%) ~ 84ms 97ms p=0.220 n=6
CompilerTSServer - node (v16.17.1, x64)
Req 1 - updateOpen 2,672ms (± 1.01%) 2,682ms (± 0.32%) ~ 2,673ms 2,695ms p=1.000 n=6
Req 2 - geterr 4,362ms (± 0.22%) 4,364ms (± 0.41%) ~ 4,342ms 4,388ms p=0.936 n=6
Req 3 - references 360ms (± 0.53%) 357ms (± 0.74%) ~ 354ms 361ms p=0.053 n=6
Req 4 - navto 288ms (± 0.74%) 291ms (± 0.42%) +2ms (+ 0.81%) 289ms 292ms p=0.050 n=6
Req 5 - completionInfo count 1,518 (± 0.00%) 1,518 (± 0.00%) ~ 1,518 1,518 p=1.000 n=6
Req 5 - completionInfo 76ms (± 3.72%) 75ms (± 3.53%) ~ 72ms 78ms p=0.867 n=6
xstateTSServer - node (v16.17.1, x64)
Req 1 - updateOpen 3,345ms (± 0.25%) 3,343ms (± 0.26%) ~ 3,329ms 3,353ms p=0.572 n=6
Req 2 - geterr 1,733ms (± 1.32%) 1,739ms (± 1.07%) ~ 1,709ms 1,759ms p=0.520 n=6
Req 3 - references 112ms (± 0.88%) 112ms (± 1.26%) ~ 110ms 114ms p=0.869 n=6
Req 4 - navto 345ms (± 1.41%) 344ms (± 1.56%) ~ 339ms 352ms p=0.871 n=6
Req 5 - completionInfo count 3,136 (± 0.00%) 3,136 (± 0.00%) ~ 3,136 3,136 p=1.000 n=6
Req 5 - completionInfo 433ms (± 0.86%) 435ms (± 0.67%) ~ 432ms 439ms p=0.573 n=6
Compiler-UnionsTSServer - node (v14.15.1, x64)
Req 1 - updateOpen 2,568ms (± 0.44%) 2,563ms (± 1.00%) ~ 2,524ms 2,585ms p=1.000 n=6
Req 2 - geterr 6,045ms (± 0.31%) 6,066ms (± 0.43%) ~ 6,033ms 6,104ms p=0.199 n=6
Req 3 - references 359ms (± 0.27%) 358ms (± 0.49%) ~ 355ms 360ms p=0.117 n=6
Req 4 - navto 275ms (± 0.54%) 277ms (± 1.22%) ~ 273ms 283ms p=0.330 n=6
Req 5 - completionInfo count 1,356 (± 0.00%) 1,356 (± 0.00%) ~ 1,356 1,356 p=1.000 n=6
Req 5 - completionInfo 101ms (± 2.14%) 99ms (± 4.62%) ~ 91ms 103ms p=0.864 n=6
CompilerTSServer - node (v14.15.1, x64)
Req 1 - updateOpen 2,824ms (± 0.67%) 2,814ms (± 0.30%) ~ 2,802ms 2,828ms p=0.258 n=6
Req 2 - geterr 4,438ms (± 0.44%) 4,446ms (± 0.54%) ~ 4,418ms 4,480ms p=0.689 n=6
Req 3 - references 402ms (± 6.88%) 384ms (± 6.50%) ~ 364ms 418ms p=0.196 n=6
Req 4 - navto 290ms (± 1.47%) 293ms (± 1.66%) ~ 285ms 297ms p=0.145 n=6
Req 5 - completionInfo count 1,518 (± 0.00%) 1,518 (± 0.00%) ~ 1,518 1,518 p=1.000 n=6
Req 5 - completionInfo 98ms (± 3.32%) 95ms (± 7.90%) ~ 85ms 102ms p=0.357 n=6
xstateTSServer - node (v14.15.1, x64)
Req 1 - updateOpen 3,652ms (± 0.24%) 3,649ms (± 0.25%) ~ 3,639ms 3,659ms p=1.000 n=6
Req 2 - geterr 1,841ms (± 0.83%) 1,847ms (± 0.94%) ~ 1,819ms 1,863ms p=0.575 n=6
Req 3 - references 129ms (± 1.79%) 129ms (± 2.86%) ~ 123ms 132ms p=1.000 n=6
Req 4 - navto 375ms (± 0.99%) 374ms (± 1.26%) ~ 368ms 382ms p=0.421 n=6
Req 5 - completionInfo count 3,136 (± 0.00%) 3,136 (± 0.00%) ~ 3,136 3,136 p=1.000 n=6
Req 5 - completionInfo 449ms (± 3.36%) 449ms (± 2.64%) ~ 438ms 468ms p=0.748 n=6
System
Machine Namets-ci-ubuntu
Platformlinux 5.4.0-135-generic
Architecturex64
Available Memory16 GB
Available Memory15 GB
CPUs4 × Intel(R) Core(TM) i7-4770 CPU @ 3.40GHz
Hosts
  • node (v18.10.0, x64)
  • node (v16.17.1, x64)
  • node (v14.15.1, x64)
Scenarios
  • Compiler-UnionsTSServer - node (v18.10.0, x64)
  • Compiler-UnionsTSServer - node (v16.17.1, x64)
  • Compiler-UnionsTSServer - node (v14.15.1, x64)
  • CompilerTSServer - node (v18.10.0, x64)
  • CompilerTSServer - node (v16.17.1, x64)
  • CompilerTSServer - node (v14.15.1, x64)
  • xstateTSServer - node (v18.10.0, x64)
  • xstateTSServer - node (v16.17.1, x64)
  • xstateTSServer - node (v14.15.1, x64)
Benchmark Name Iterations
Current 53092 6
Baseline main 6

Startup

Comparison Report - main..53092
Metric main 53092 Delta Best Worst p-value
tsc-startup - node (v16.17.1, x64)
Execution time 141.53ms (± 0.24%) 141.47ms (± 0.19%) ~ 140.82ms 143.79ms p=0.073 n=600
tsserver-startup - node (v16.17.1, x64)
Execution time 226.58ms (± 0.19%) 226.68ms (± 0.15%) +0.09ms (+ 0.04%) 225.58ms 231.00ms p=0.000 n=600
tsserverlibrary-startup - node (v16.17.1, x64)
Execution time 228.44ms (± 0.15%) 228.64ms (± 0.16%) +0.20ms (+ 0.09%) 227.68ms 232.87ms p=0.000 n=600
typescript-startup - node (v16.17.1, x64)
Execution time 209.31ms (± 0.16%) 209.19ms (± 0.14%) -0.12ms (- 0.06%) 208.40ms 213.27ms p=0.000 n=600
System
Machine Namets-ci-ubuntu
Platformlinux 5.4.0-135-generic
Architecturex64
Available Memory16 GB
Available Memory15 GB
CPUs4 × Intel(R) Core(TM) i7-4770 CPU @ 3.40GHz
Hosts
  • node (v16.17.1, x64)
Scenarios
  • tsc-startup - node (v16.17.1, x64)
  • tsserver-startup - node (v16.17.1, x64)
  • tsserverlibrary-startup - node (v16.17.1, x64)
  • typescript-startup - node (v16.17.1, x64)
Benchmark Name Iterations
Current 53092 6
Baseline main 6

Developer Information:

Download Benchmark

@typescript-bot
Copy link
Collaborator

Hey @jakebailey, the results of running the DT tests are ready.
Everything looks the same!
You can check the log here.

@typescript-bot
Copy link
Collaborator

@jakebailey Here are the results of running the top-repos suite comparing main and refs/pull/53092/merge:

Everything looks good!

Copy link
Member

@DanielRosenwasser DanielRosenwasser left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just add one more test case with a union type (EDIT: let me know if I missed another case in the same file).

@DanielRosenwasser
Copy link
Member

There's this check below your code

            else if (type && strictNullChecks && !isTypeAssignableTo(undefinedType, type)) {
                error(errorNode, Diagnostics.Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined);
            }

Do we need the assignability check anymore?

-             else if (type && strictNullChecks && !isTypeAssignableTo(undefinedType, type)) {
+             else if (type && strictNullChecks) {
                  error(errorNode, Diagnostics.Function_lacks_ending_return_statement_and_return_type_does_not_include_undefined);
              }

…xpressions.errors.txt

Co-authored-by: Daniel Rosenwasser <[email protected]>
// Okay; return type allows implicit return of undefined
}

function f23(): undefined | number {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think your last commit only included this baseline, as f23 doesn't appear to be anywhere else.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I just tapped the commit button from GitHub, will add it with the another change for the feedback.

@saschanaz
Copy link
Contributor Author

saschanaz commented Mar 6, 2023

Do we need the assignability check anymore?

I'm not sure, isn't that for some different situation, as there's still a test for that:

class A {
a(): string | null {
if (Math.random() > 0.5) {
return '';
}
// it does error here as expected
}
}

==== tests/cases/compiler/getterControlFlowStrictNull.ts (3 errors) ====
class A {
a(): string | null {
~~~~~~~~~~~~~
!!! error TS2366: Function lacks ending return statement and return type does not include 'undefined'.
if (Math.random() > 0.5) {
return '';
}
// it does error here as expected
}
}

@DanielRosenwasser
Copy link
Member

You're saying that TypeScript no longer issues an error in that test if you remove that assignability check? I can't see why that would happen.

@saschanaz
Copy link
Contributor Author

saschanaz commented Mar 6, 2023

You're saying that TypeScript no longer issues an error in that test if you remove that assignability check? I can't see why that would happen.

Oh, you want to change the error? Okay then 👀 Scratch it, I guess I need coffee.

@@ -1868,7 +1868,7 @@
"category": "Error",
"code": 2354
},
"A function whose declared type is neither 'void' nor 'any' must return a value.": {
"A function whose declared type is neither 'void' nor 'any' must return a value. 'undefined' is also allowed with --strictNullChecks.": {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think I'd rather us duplicate this message to have two (@DanielRosenwasser may be able to better write these):

A function whose declared type is neither 'void' nor 'any' must return a value.

A function whose declared type is not 'void', 'any', or 'undefined' must return a value.

Then, conditionally emit one based on the variable strictNullChecks.

Then below in codefixes/returnValueCorrect.ts, handle both.

Copy link
Member

@jakebailey jakebailey left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM but deferring to @DanielRosenwasser for diagnostic wording.

@DanielRosenwasser DanielRosenwasser merged commit f473058 into microsoft:main Mar 17, 2023
@saschanaz saschanaz deleted the return-undefined branch March 17, 2023 19:19
}
else if (type && strictNullChecks && !isTypeAssignableTo(undefinedType, type)) {
else if (type && strictNullChecks) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jakebailey @DanielRosenwasser The removal of this assignability check has caused a regression. This example now errors when it shouldn't:

function fx2(x: boolean): unknown {
  if (x) {
    return "hello";
  }
};

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I noticed the regression here: #53515 (comment)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Funny. We were just talking about adding this check back again in #53490

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'll look into why it's not working as we expected.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh, no, that PR was exactly to fix the issue you mentioned. So it should be fixed in main now.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Checked, and it is fixed, yep.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
For Uncommitted Bug PR for untriaged, rejected, closed or missing bug
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

Allow non returning functions to have contextually required undefined return type
5 participants