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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
content / browser / service_worker / fake_embedded_worker_instance_client.h [blame]
// Copyright 2019 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_BROWSER_SERVICE_WORKER_FAKE_EMBEDDED_WORKER_INSTANCE_CLIENT_H_
#define CONTENT_BROWSER_SERVICE_WORKER_FAKE_EMBEDDED_WORKER_INSTANCE_CLIENT_H_
#include "base/memory/raw_ptr.h"
#include "base/memory/weak_ptr.h"
#include "mojo/public/cpp/bindings/associated_remote.h"
#include "mojo/public/cpp/bindings/pending_receiver.h"
#include "mojo/public/cpp/bindings/receiver.h"
#include "third_party/blink/public/mojom/service_worker/embedded_worker.mojom.h"
#include "third_party/blink/public/mojom/service_worker/service_worker_installed_scripts_manager.mojom.h"
namespace content {
class EmbeddedWorkerTestHelper;
class FakeServiceWorkerInstalledScriptsManager;
// The default fake for blink::mojom::EmbeddedWorkerInstanceClient. It responds
// to Start/Stop/etc messages without starting an actual service worker thread.
// It is owned by EmbeddedWorkerTestHelper and by default the lifetime is tied
// to the Mojo connection.
class FakeEmbeddedWorkerInstanceClient
: public blink::mojom::EmbeddedWorkerInstanceClient {
public:
// |helper| must outlive this instance.
explicit FakeEmbeddedWorkerInstanceClient(EmbeddedWorkerTestHelper* helper);
FakeEmbeddedWorkerInstanceClient(const FakeEmbeddedWorkerInstanceClient&) =
delete;
FakeEmbeddedWorkerInstanceClient& operator=(
const FakeEmbeddedWorkerInstanceClient&) = delete;
~FakeEmbeddedWorkerInstanceClient() override;
EmbeddedWorkerTestHelper* helper() { return helper_; }
base::WeakPtr<FakeEmbeddedWorkerInstanceClient> GetWeakPtr();
mojo::AssociatedRemote<blink::mojom::EmbeddedWorkerInstanceHost>& host() {
return host_;
}
void Bind(mojo::PendingReceiver<blink::mojom::EmbeddedWorkerInstanceClient>
receiver);
void RunUntilBound();
blink::mojom::ServiceWorkerScriptInfoPtr WaitForTransferInstalledScript();
// Closes the binding and deletes |this|.
void Disconnect();
protected:
// blink::mojom::EmbeddedWorkerInstanceClient implementation.
void StartWorker(blink::mojom::EmbeddedWorkerStartParamsPtr params) override;
void StopWorker() override;
virtual void EvaluateScript();
void DidPopulateScriptCacheMap();
blink::mojom::EmbeddedWorkerStartParamsPtr& start_params() {
return start_params_;
}
virtual void OnConnectionError();
private:
class LoaderClient;
void CallOnConnectionError();
// |helper_| owns |this|.
const raw_ptr<EmbeddedWorkerTestHelper> helper_;
blink::mojom::EmbeddedWorkerStartParamsPtr start_params_;
mojo::AssociatedRemote<blink::mojom::EmbeddedWorkerInstanceHost> host_;
mojo::Receiver<blink::mojom::EmbeddedWorkerInstanceClient> receiver_{this};
base::OnceClosure quit_closure_for_bind_;
std::unique_ptr<FakeServiceWorkerInstalledScriptsManager>
installed_scripts_manager_;
std::unique_ptr<LoaderClient> main_script_loader_client_;
base::WeakPtrFactory<FakeEmbeddedWorkerInstanceClient> weak_factory_{this};
};
// A EmbeddedWorkerInstanceClient fake that doesn't respond to the Start/Stop
// message until instructed to do so.
class DelayedFakeEmbeddedWorkerInstanceClient
: public FakeEmbeddedWorkerInstanceClient {
public:
explicit DelayedFakeEmbeddedWorkerInstanceClient(
EmbeddedWorkerTestHelper* helper);
DelayedFakeEmbeddedWorkerInstanceClient(
const DelayedFakeEmbeddedWorkerInstanceClient&) = delete;
DelayedFakeEmbeddedWorkerInstanceClient& operator=(
const DelayedFakeEmbeddedWorkerInstanceClient&) = delete;
~DelayedFakeEmbeddedWorkerInstanceClient() override;
// Unblocks the Start/StopWorker() call to this instance. May be called before
// or after the Start/StopWorker() call.
void UnblockStartWorker();
void UnblockStopWorker();
// Returns after Start/StopWorker() is called.
void RunUntilStartWorker();
void RunUntilStopWorker();
protected:
void StartWorker(blink::mojom::EmbeddedWorkerStartParamsPtr params) override;
void StopWorker() override;
private:
void CompleteStopWorker();
enum class State { kWillBlock, kWontBlock, kBlocked, kCompleted };
State start_state_ = State::kWillBlock;
State stop_state_ = State::kWillBlock;
base::OnceClosure quit_closure_for_start_worker_;
base::OnceClosure quit_closure_for_stop_worker_;
// Valid after StartWorker() until start is unblocked.
blink::mojom::EmbeddedWorkerStartParamsPtr start_params_;
};
} // namespace content
#endif // CONTENT_BROWSER_SERVICE_WORKER_FAKE_EMBEDDED_WORKER_INSTANCE_CLIENT_H_