File: sync_startup_tracker.h

package info (click to toggle)
chromium 139.0.7258.127-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 6,122,068 kB
  • sloc: cpp: 35,100,771; ansic: 7,163,530; javascript: 4,103,002; python: 1,436,920; asm: 946,517; xml: 746,709; pascal: 187,653; perl: 88,691; sh: 88,436; objc: 79,953; sql: 51,488; cs: 44,583; fortran: 24,137; makefile: 22,147; tcl: 15,277; php: 13,980; yacc: 8,984; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (96 lines) | stat: -rw-r--r-- 3,387 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
// Copyright 2013 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROME_BROWSER_SYNC_SYNC_STARTUP_TRACKER_H_
#define CHROME_BROWSER_SYNC_SYNC_STARTUP_TRACKER_H_

#include <optional>

#include "base/functional/callback_forward.h"
#include "base/memory/raw_ptr.h"
#include "base/scoped_observation.h"
#include "base/time/time.h"
#include "base/timer/timer.h"
#include "components/sync/service/sync_service.h"
#include "components/sync/service/sync_service_observer.h"

// `SyncStartupTracker` provides an easier way to wait for `SyncService` to be
// successfully started up, or to be notified when startup has failed due to
// some kind of error.
class SyncStartupTracker : public syncer::SyncServiceObserver {
 public:
  enum class ServiceStartupState {
    // Sync backend is still starting up.
    kPending,
    // An error has been detected that prevents the sync backend from starting
    // up.
    kError,
    // Sync startup has completed (i.e. `SyncService::IsEngineInitialized()`
    // returns true).
    kComplete,
    // Sync startup is taking too long. This can only be obtained when waiting
    // for startup via `SyncStartupTracker`.
    kTimeout,
  };

  using SyncStartupStateChangedCallback =
      base::OnceCallback<void(ServiceStartupState)>;

  // Starts observing the status of `sync_service` and runs `callback` when its
  // startup completes (or fails). If the tracker is destroyed before `callback`
  // is run, it will just be dropped without running.
  SyncStartupTracker(syncer::SyncService* sync_service,
                     SyncStartupStateChangedCallback callback);

  SyncStartupTracker(const SyncStartupTracker&) = delete;
  SyncStartupTracker& operator=(const SyncStartupTracker&) = delete;

  ~SyncStartupTracker() override;

  // Returns the current state of the sync service.
  static ServiceStartupState GetServiceStartupState(
      syncer::SyncService* sync_service);

  // syncer::SyncServiceObserver implementation.
  void OnStateChanged(syncer::SyncService* sync) override;

 private:
  // Checks the current service state and notifies the
  // `sync_startup_status_changed_callback_` if the state has changed. Note that
  // it is expected that the observer will free this object, so callers should
  // not reference this object after making this call.
  void CheckServiceState();

  void OnStartupTimeout();

  // The SyncService we should track.
  const raw_ptr<syncer::SyncService> sync_service_;

  base::ScopedObservation<syncer::SyncService, syncer::SyncServiceObserver>
      sync_service_observation_{this};

  base::OneShotTimer timeout_waiter_;
  bool is_timed_out_ = false;

  SyncStartupStateChangedCallback sync_startup_status_changed_callback_;

  base::WeakPtrFactory<SyncStartupTracker> weak_factory_{this};
};

namespace testing {
// Helper to control `SyncStartupTracker`'s timeout mechanism for tests. If it
// is created with an empty timeout value, it will make the tracker not report
// timeouts.
class ScopedSyncStartupTimeoutOverride {
 public:
  explicit ScopedSyncStartupTimeoutOverride(
      std::optional<base::TimeDelta> wait_timeout);
  ~ScopedSyncStartupTimeoutOverride();

 private:
  std::optional<base::TimeDelta> old_wait_timeout_;
};
}  // namespace testing

#endif  // CHROME_BROWSER_SYNC_SYNC_STARTUP_TRACKER_H_