Query result called twice #492
Replies: 25 comments 2 replies
-
| @nomadoda it looks like it might be related to caching https://imgur.com/a/1HUdfZa Maybe someone that has read the Apollo API can bring some light to the tunnel! | 
Beta Was this translation helpful? Give feedback.
-
| @nomadoda I believe that the first response is the result you get from the cache. | 
Beta Was this translation helpful? Give feedback.
-
| Getting similar behaviour, looks to be cache related. I don't understand the difference between the results either: partial, stale If you set the fetchPolicy = "no-cache" then you no longer get the partial result "partial: false". apollo: {
    me: {
        query: ME_QUERY,
        fetchPolicy: 'no-cache', // cache for this query only
        result(res) {
            console.log({ res });
        },
    },
},You can turn this off globally using: new ApolloClient({
  cache,
  link,
  defaultOptions: {
    fetchPolicy: 'no-cache'
  }
}) | 
Beta Was this translation helpful? Give feedback.
-
| Ok, that makes sense. Is there any hook called once, when the query is finished? | 
Beta Was this translation helpful? Give feedback.
-
| I have the same issue. It's definitely cache related. The Apollo Component only calls result once so this behavior is confusing. | 
Beta Was this translation helpful? Give feedback.
-
| Beware of using  To get a single query result try using a  For more info: https://www.apollographql.com/docs/react/api/apollo-client/#apolloclient-functions | 
Beta Was this translation helpful? Give feedback.
-
| Did someone find a solution? | 
Beta Was this translation helpful? Give feedback.
-
| 
 | 
Beta Was this translation helpful? Give feedback.
-
| Since the query sent by ApolloQuery may be periodically re-issued (look at pollInterval), it's conceptually necessary that you be prepared to process a progressive sequence of revisions/updates to the result object. The idea with the two callbacks you are seeing in your log is that you got an initial set of answers from the cache followed by a refined set of answers from the network-based query to the server. Subsequent re-fetch operations may produce further refinements. Basic use (as documented and intended) of ApolloQuery exploits the fact that the result object is reactive to get your application UI to update dynamically, but more sophisticated patterns may need your application to "wrap" that object in a fashion that deals with the ongoing updates. Re-run your test with a pollInterval parameter of 1000 and watch what happens. Now that I'm thinking about it, my guess is that the  If you get multiple events as I expect, then this isn't a bug. In fact, it's an essential and necessary behavior. | 
Beta Was this translation helpful? Give feedback.
-
| I am also experiencing this with queries (ie. result or error is called twice back to back). const apolloClient = new ApolloClient({
  link,
  cache,
  connectToDevTools: !config.app.isProduction,
  defaultOptions: {
    query: {
      fetchPolicy: "cache-first",
    },
  },
});apollo: {
  viewer() {
    return {
      query: ViewerQuery,
      fetchPolicy: "network-only",
      result(result) { console.log(result); },
      error(error) { console.log(error); }
    }
  }
}This results in the result or error being logged twice | 
Beta Was this translation helpful? Give feedback.
-
| Hi everyone, there any update about this issue? | 
Beta Was this translation helpful? Give feedback.
-
| no update here? | 
Beta Was this translation helpful? Give feedback.
-
| The same...Any results? | 
Beta Was this translation helpful? Give feedback.
-
| @nomadoda , did you solve this issue? @Akryum, maybe you can suggest what could be a reason? Because I figured out that for vue-apollo 2.1.0-beta.9 it's work as expected | 
Beta Was this translation helpful? Give feedback.
-
| I don’t think so, I’m afraid…  On 16 Nov 2020, at 19:07, Evgen ***@***.***> wrote:
 @nomadoda <https://github.com/nomadoda> , did you solve this issue?
 —
 You are receiving this because you were mentioned.
 Reply to this email directly, view it on GitHub <https://github.com/vuejs/vue-apollo/issues/492#issuecomment-728231867>, or unsubscribe <https://github.com/notifications/unsubscribe-auth/AGFS5SVPA7ACS5DQ65QYDZTSQFS7XANCNFSM4GREOJTQ>.
 | 
Beta Was this translation helpful? Give feedback.
-
| So it turns out this is not a bug. It's an intentional behavior. I gave an less-than-correct explanation above, but here's what's happening: The first callback happens using the cached data on the client. The intent is to give the UI whatever data is already known so that it can get started. The second callback happens when the network query returns values, which may be different from what was already in the client-side cache. For most objects returned from the network there will be no change, but a few will have changed, some may be added, and others may be dropped. Which means that a new response is required for the client view to revise what it shows. You can confirm this by overriding the query behavior. If you set the query to "cache only" or "network only", you should find that the callback only occurs once. This bug should be closed as not-a-bug. The behavior is correct and intentional. | 
Beta Was this translation helpful? Give feedback.
-
| This is still ocurring for me even with  | 
Beta Was this translation helpful? Give feedback.
-
| Then my explanation is clearly wrong. But I would still guess that there is
something going on at the cache layer that is driving this.
If you change the applications's *global* fetch policy (the default) to
"Network only", do you still get two callbacks? And does the first callback
actually have any objects in it, or is it null?… On Fri, Nov 27, 2020 at 4:33 PM Kendall Roth ***@***.***> wrote:
 This is still ocurring for me even with network-only (see comment above
 for config).
 —
 You are receiving this because you commented.
 Reply to this email directly, view it on GitHub
 <https://github.com/vuejs/vue-apollo/issues/492#issuecomment-735018247>,
 or unsubscribe
 <https://github.com/notifications/unsubscribe-auth/AEJX3CW6QIXIOCQ7AATJOBTSSBAL3ANCNFSM4GREOJTQ>
 .
 | 
Beta Was this translation helpful? Give feedback.
-
| 
 @b-jsshapiro, Let's imagine that it is correct, like you said. | 
Beta Was this translation helpful? Give feedback.
-
| @MaevskiyE: That's a good question, and the answer is: I don't know. Perhaps if you put a breakpoint in the callback using the browser debugger, you'll be able to see in the callstack where the calls are happening from. I'd do it here, but right now I'm focused on a server-side problem that's a bit urgent. | 
Beta Was this translation helpful? Give feedback.
-
| @NataliaTepluhina , very nice! Thanx a lot! | 
Beta Was this translation helpful? Give feedback.
-
| Consider you have the following: 
 Then the is rendered twice. This is not the vue. It should be that what exists inside the ApolloQuery object should render once when is done. Or am I missing something? | 
Beta Was this translation helpful? Give feedback.
-
| @b-jsshapiro suggested looking at the callstack.  I did that (which is how I ended up here in the first place).  I added  Results: 
 
 It looks like the second has to do with subscriptions, but I'm not currently using any.  My  | 
Beta Was this translation helpful? Give feedback.
-
| I think the discussion if it is intended or not is useless, we need a event to be called only once to be aware that our query was executed and our data is avaliable, if the  | 
Beta Was this translation helpful? Give feedback.
-
| I'm having this issue too, where it doesn't matter what I set  
 | 
Beta Was this translation helpful? Give feedback.
Uh oh!
There was an error while loading. Please reload this page.
-
Minimal example:
Outcome:
Query loads twice, before and after lifecycle hooks. Is this expected behaviour? Notice that the first result contains
partial: false, and the second containsstale: false.Expected outcome:
I only want result to be called once.
Beta Was this translation helpful? Give feedback.
All reactions