Consider a replica set where node A is syncing from node B. Every time A receives a batch of oplog entries from B, it will re-evalaute if its sync source is still a good option. One key criteria is whether or not A is caught up to B, and if it is, is B either the primary or have its own sync source (so that we know B will keep advancing its last applied).
The problem can arise depending on B's sync source. When B chooses a sync source candidate, it sets its sync source in the topology coordinator, but it doesn't clear it if that sync source candidate does not successfully become the new sync source.
When A re-evaluates its sync source based on the OplogQueryMetadata it gets from B, it thinks that B has a sync source, so it never decides to change who to sync from. This can mean that A takes a long time to realize it needs to switch sync sources.