[v3.4] Unexpected Console Warning: "Missing cache result fields"
See original GitHub issueIntended outcome: Should not print warning to console when two separate queries request different subsets of the same field
Actual outcome: Console warning is printed
How to reproduce the issue: https://github.com/dylanwulf/react-apollo-error-template/tree/cache-miss-error (use branch cache-miss-error) Instructions: Start app, open console, click any unselected radio button, see that a warning is printed to console.
Conditions necessary for issue to occur:
- Two separate queries request different subsets of the same field
- Both queries have the same variable values
- One query resolves before the other
- Both queries are using
notifyOnNetworkStatusChange: true
- Both queries are using
fetchPolicy: 'cache-and-network'
- Apollo Client version must be >=
3.4.0-beta.14
(possibly caused by #7761?)
Versions
System:
OS: Windows 10 10.0.19042
Binaries:
Node: 14.16.1 - C:\Program Files\nodejs\node.EXE
Yarn: 1.21.1 - C:\Program Files (x86)\Yarn\bin\yarn.CMD
npm: 6.14.12 - C:\Program Files\nodejs\npm.CMD
Browsers:
Chrome: 91.0.4472.114
Edge: Spartan (44.19041.1023.0), Chromium (91.0.864.59)
npmPackages:
@apollo/client: 3.4.0-rc.15 => 3.4.0-rc.15
Issue Analytics
- State:
- Created 2 years ago
- Comments:12 (9 by maintainers)
Top Results From Across the Web
Missing field after update cache vue-apollo - Stack Overflow
I have a mutation that work great and fortunately I make my apollo cache get update too, but for some reason I get...
Read more >Error handling - Apollo GraphQL Docs
Whenever Apollo Server encounters errors while processing a GraphQL operation, its response to the client includes an errors array containing each error that ......
Read more >Looker error catalog | Google Cloud
A collection of common Looker errors and troubleshooting resources.
Read more >Errors - discord.js Guide
This error is commonly thrown by your system in response to the process unexpectedly closing. Cleaning the npm cache and deleting node_modules ...
Read more >Web API implementation - Best practices for cloud applications
If the data is no longer available (status code 404) then the object should be removed from the cache. Note. If the response...
Read more >Top Related Medium Post
No results found
Top Related StackOverflow Question
No results found
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start FreeTop Related Reddit Thread
No results found
Top Related Hackernoon Post
No results found
Top Related Tweet
No results found
Top Related Dev.to Post
No results found
Top Related Hashnode Post
No results found
Top GitHub Comments
@benjamn this did the trick, many thanks
@dylanwulf @benjamn
I’m experiencing these as well since I switched to rc15/18. I’m getting a lot of them, systematically.
However they are triggered by the exact same request in my case, requesting the exact same fields. Only the variable changes. Can I humbly request a flag to lower the verbosity? With the associated stack trace, these are taking over my browser console output.
Below are 3 such requests, which were performed in a row. Apologies, I don’t know how to format the request payload seen in the Chrome’s network tab, I’ll be copy/pasting.
The only part that changes here are the variables:
"startDate":"2021-07-05","endDate":"2021-07-11"
,"startDate":"2021-06-28","endDate":"2021-07-04"
,"startDate":"2021-06-21","endDate":"2021-06-27"
– as you can surmise, I’m looking at a weekly calendar UI, going back in time week by week.Each time I press the “Previous week” button, a request for that week’s date interval is made, and each time I’m getting:
Note: the
me
field’s__typename
isEmployee
, and the authenticated employee’sid
in these examples is 12.The thing is, the
me
entrypoint field is used extensively. This is how our users receive their data.If they look at their time entries page, we will request:
then if they head to their projects page, we will request:
in their proposals page:
etc. The schema itself has many other “root” fields than
me
but you get the idea, and I assume there is nothing out of the ordinary here in our schema (?). There is an actualemployee
root field as well that accepts anid
, andme
is essentially just a convenience shortcut that returns the same type,Employee
, but for the authenticated employee.Before performing these 3 requests in this specific example, one was made as soon as they authenticated, to get their name and profile picture, so I assume this filled the cache with the corresponding data first:
Am I possibly missing something with these new warnings/eerroors? This type of request on the
me
field in our app will never fully features all the fields it can accept, that would be way too much data to fetch. My assumption is that 3.4 would merge these just fine, as it had been working well in 3.3 (to my knowleddge). I can see the data being cached fine in 3.3. For example, if I head back in the UI to a week that was fetched before, the data comes from the cache instantaneously and the UI refreshes right away, which is very appreciated.Thanks