| // Copyright 2014 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef CONTENT_PUBLIC_TEST_BROWSING_DATA_REMOVER_TEST_UTIL_H_ |
| #define CONTENT_PUBLIC_TEST_BROWSING_DATA_REMOVER_TEST_UTIL_H_ |
| |
| #include <memory> |
| |
| #include "base/memory/raw_ptr.h" |
| #include "base/run_loop.h" |
| #include "base/scoped_observation.h" |
| #include "base/task/sequenced_task_runner.h" |
| #include "content/public/browser/browsing_data_remover.h" |
| |
| namespace content { |
| |
| // This class can be used to wait for a BrowsingDataRemover to complete |
| // operation. It is not suitable for repeated use. |
| class BrowsingDataRemoverCompletionObserver |
| : public BrowsingDataRemover::Observer { |
| public: |
| explicit BrowsingDataRemoverCompletionObserver(BrowsingDataRemover* remover); |
| |
| BrowsingDataRemoverCompletionObserver( |
| const BrowsingDataRemoverCompletionObserver&) = delete; |
| BrowsingDataRemoverCompletionObserver& operator=( |
| const BrowsingDataRemoverCompletionObserver&) = delete; |
| |
| ~BrowsingDataRemoverCompletionObserver() override; |
| |
| void BlockUntilCompletion(); |
| |
| bool browsing_data_remover_done() { return browsing_data_remover_done_; } |
| |
| uint64_t failed_data_types() { return failed_data_types_; } |
| |
| protected: |
| // BrowsingDataRemover::Observer: |
| void OnBrowsingDataRemoverDone(uint64_t failed_data_types) override; |
| |
| private: |
| void FlushForTestingComplete(); |
| void QuitRunLoopWhenTasksComplete(); |
| |
| // Tracks when the Task Scheduler task flushing is done. |
| bool flush_for_testing_complete_ = false; |
| |
| // Tracks when BrowsingDataRemover::Observer::OnBrowsingDataRemoverDone() is |
| // called. |
| bool browsing_data_remover_done_ = false; |
| |
| // Stores the |failed_data_types| mask passed into |
| // OnBrowsingDataRemoverDone(). |
| uint64_t failed_data_types_ = 0; |
| |
| base::RunLoop run_loop_; |
| base::ScopedObservation<BrowsingDataRemover, BrowsingDataRemover::Observer> |
| observation_{this}; |
| scoped_refptr<base::SequencedTaskRunner> origin_task_runner_; |
| }; |
| |
| // The completion inhibitor can artificially delay completion of the browsing |
| // data removal process. It is used during testing to simulate scenarios in |
| // which the deletion stalls or takes a very long time. |
| // |
| // This class will detach itself from |remover| upon its destruction. |
| // If |remover| is destroyed during a test (e.g. in profile shutdown tests), |
| // users must call Reset() to detach it in advance. |
| class BrowsingDataRemoverCompletionInhibitor { |
| public: |
| explicit BrowsingDataRemoverCompletionInhibitor(BrowsingDataRemover* remover); |
| |
| BrowsingDataRemoverCompletionInhibitor( |
| const BrowsingDataRemoverCompletionInhibitor&) = delete; |
| BrowsingDataRemoverCompletionInhibitor& operator=( |
| const BrowsingDataRemoverCompletionInhibitor&) = delete; |
| |
| virtual ~BrowsingDataRemoverCompletionInhibitor(); |
| |
| void Reset(); |
| |
| void BlockUntilNearCompletion(); |
| void ContinueToCompletion(); |
| |
| protected: |
| virtual void OnBrowsingDataRemoverWouldComplete( |
| base::OnceClosure continue_to_completion); |
| |
| private: |
| void FlushForTestingComplete(); |
| void QuitRunLoopWhenTasksComplete(); |
| |
| // Tracks when the Task Scheduler task flushing is done. |
| bool flush_for_testing_complete_ = false; |
| |
| // Tracks when OnBrowsingDataRemoverWouldComplete() is called. |
| bool browsing_data_remover_would_complete_done_ = false; |
| |
| // Not owned by this class. If the pointer becomes invalid, the owner of |
| // this class is responsible for calling Reset(). |
| raw_ptr<BrowsingDataRemover> remover_; |
| |
| std::unique_ptr<base::RunLoop> run_loop_; |
| base::OnceClosure continue_to_completion_callback_; |
| scoped_refptr<base::SequencedTaskRunner> origin_task_runner_; |
| }; |
| |
| } // namespace content |
| |
| #endif // CONTENT_PUBLIC_TEST_BROWSING_DATA_REMOVER_TEST_UTIL_H_ |