1
|
|
|
<?php |
2
|
|
|
|
3
|
|
|
use Automattic\Jetpack\Sync\Actions; |
4
|
|
|
use Automattic\Jetpack\Sync\Modules; |
5
|
|
|
use Automattic\Jetpack\Sync\Modules\Full_Sync; |
6
|
|
|
use Automattic\Jetpack\Sync\Settings; |
7
|
|
|
|
8
|
|
|
/** |
9
|
|
|
* Testing Jetpack's full sync module prior to 8.2 release. |
10
|
|
|
* |
11
|
|
|
* @group legacy-full-sync |
12
|
|
|
*/ |
13
|
|
|
class WP_Test_Jetpack_Sync_Full extends WP_Test_Jetpack_Sync_Base { |
14
|
|
|
private $full_sync; |
15
|
|
|
|
16
|
|
|
private $full_sync_end_checksum; |
17
|
|
|
private $full_sync_start_config; |
18
|
|
|
private $synced_user_ids; |
19
|
|
|
|
20
|
|
|
private $test_posts_count = 20; |
21
|
|
|
private $test_comments_count = 11; |
22
|
|
|
|
23
|
|
View Code Duplication |
public function setUp() { |
24
|
|
|
parent::setUp(); |
25
|
|
|
Settings::reset_data(); |
26
|
|
|
Settings::update_settings( array( 'full_sync_send_immediately' => 0 ) ); |
27
|
|
|
|
28
|
|
|
$this->full_sync = Modules::get_module( 'full-sync' ); |
29
|
|
|
$this->server_replica_storage->reset(); |
30
|
|
|
$this->sender->reset_data(); |
31
|
|
|
} |
32
|
|
|
|
33
|
|
View Code Duplication |
function test_enqueues_sync_start_action() { |
34
|
|
|
$post = $this->factory->post->create(); |
35
|
|
|
$this->factory->comment->create_post_comments( $post, 11 ); |
36
|
|
|
|
37
|
|
|
$this->full_sync->start(); |
|
|
|
|
38
|
|
|
$this->sender->do_full_sync(); |
39
|
|
|
|
40
|
|
|
$start_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_start' ); |
41
|
|
|
$this->assertTrue( $start_event !== false ); |
42
|
|
|
|
43
|
|
|
$start_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_start' ); |
44
|
|
|
|
45
|
|
|
list( $config, $range ) = $start_event->args; |
46
|
|
|
|
47
|
|
|
$this->assertTrue( $config !== false ); |
48
|
|
|
|
49
|
|
|
$this->assertTrue( isset( $range['posts']->max ) ); |
50
|
|
|
$this->assertTrue( isset( $range['posts']->min ) ); |
51
|
|
|
$this->assertTrue( isset( $range['posts']->count ) ); |
52
|
|
|
|
53
|
|
|
$this->assertTrue( isset( $range['comments']->max ) ); |
54
|
|
|
$this->assertTrue( isset( $range['comments']->min ) ); |
55
|
|
|
$this->assertTrue( isset( $range['comments']->count ) ); |
56
|
|
|
} |
57
|
|
|
|
58
|
|
|
function test_enqueues_sync_start_action_without_post_sends_empty_range() { |
59
|
|
|
$this->full_sync->start(); |
|
|
|
|
60
|
|
|
$this->sender->do_full_sync(); |
61
|
|
|
$start_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_start' ); |
62
|
|
|
|
63
|
|
|
list( $config, $range, $empty ) = $start_event->args; |
|
|
|
|
64
|
|
|
|
65
|
|
|
$posts = get_posts(); |
66
|
|
|
if ( empty( $posts ) ) { |
67
|
|
|
$this->assertTrue( $empty['posts'] ); |
68
|
|
|
} |
69
|
|
|
|
70
|
|
|
$comments = get_comments(); |
71
|
|
|
if ( empty( $comments ) ) { |
72
|
|
|
$this->assertTrue( $empty['comments'] ); |
73
|
|
|
} |
74
|
|
|
|
75
|
|
|
$this->full_sync->reset_data(); |
76
|
|
|
|
77
|
|
|
$post = $this->factory->post->create(); |
78
|
|
|
$this->factory->comment->create_post_comments( $post, 1 ); |
79
|
|
|
|
80
|
|
|
|
81
|
|
|
$this->full_sync->start(); |
|
|
|
|
82
|
|
|
$this->full_sync->start(); |
|
|
|
|
83
|
|
|
$this->sender->do_full_sync(); |
84
|
|
|
$start_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_start' ); |
85
|
|
|
list( $config, $range, $empty ) = $start_event->args; |
|
|
|
|
86
|
|
|
|
87
|
|
|
$this->assertFalse( isset( $empty['posts'] ) ); |
88
|
|
|
$this->assertFalse( isset( $empty['comments'] ) ); |
89
|
|
|
|
90
|
|
|
} |
91
|
|
|
|
92
|
|
|
// this only applies to the test replicastore - in production we overlay data |
93
|
|
View Code Duplication |
function test_sync_start_resets_storage() { |
94
|
|
|
$this->factory->post->create(); |
95
|
|
|
$this->sender->do_sync(); |
96
|
|
|
|
97
|
|
|
$this->assertEquals( 1, $this->server_replica_storage->post_count() ); |
98
|
|
|
|
99
|
|
|
do_action( 'jetpack_full_sync_start' ); |
100
|
|
|
$this->sender->do_full_sync(); |
101
|
|
|
|
102
|
|
|
$this->assertEquals( 0, $this->server_replica_storage->post_count() ); |
103
|
|
|
|
104
|
|
|
$this->full_sync->start(); |
|
|
|
|
105
|
|
|
$this->sender->do_full_sync(); |
106
|
|
|
|
107
|
|
|
$this->assertEquals( 1, $this->server_replica_storage->post_count() ); |
108
|
|
|
} |
109
|
|
|
|
110
|
|
|
function test_sync_start_resets_previous_sync_and_sends_full_sync_cancelled() { |
111
|
|
|
$this->factory->post->create(); |
112
|
|
|
$this->full_sync->start(); |
|
|
|
|
113
|
|
|
|
114
|
|
|
$initial_full_sync_queue_size = $this->sender->get_full_sync_queue()->size(); |
115
|
|
|
|
116
|
|
|
// if we start again, it should reset the queue back to its original state, |
117
|
|
|
// plus a "full_sync_cancelled" action |
118
|
|
|
$this->full_sync->start(); |
|
|
|
|
119
|
|
|
|
120
|
|
|
$this->assertEquals( $initial_full_sync_queue_size + 1, $this->sender->get_full_sync_queue()->size() ); |
121
|
|
|
$this->sender->do_full_sync(); |
122
|
|
|
|
123
|
|
|
$cancelled_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_cancelled' ); |
124
|
|
|
|
125
|
|
|
$this->assertTrue( $cancelled_event !== false ); |
126
|
|
|
} |
127
|
|
|
|
128
|
|
View Code Duplication |
function test_full_sync_lock_has_one_hour_timeout() { |
129
|
|
|
$this->started_sync_count = 0; |
130
|
|
|
|
131
|
|
|
add_action( 'jetpack_full_sync_start', array( $this, 'count_full_sync_start' ) ); |
132
|
|
|
|
133
|
|
|
$this->full_sync->start(); |
|
|
|
|
134
|
|
|
|
135
|
|
|
$this->assertEquals( 1, $this->started_sync_count ); |
136
|
|
|
|
137
|
|
|
// fake the last sync being over an hour ago |
138
|
|
|
$prefix = Full_Sync::STATUS_OPTION_PREFIX; |
139
|
|
|
update_option( "{$prefix}_started", time() - 3700 ); |
140
|
|
|
|
141
|
|
|
$this->full_sync->start(); |
|
|
|
|
142
|
|
|
|
143
|
|
|
$this->assertEquals( 2, $this->started_sync_count ); |
144
|
|
|
} |
145
|
|
|
|
146
|
|
|
function count_full_sync_start() { |
147
|
|
|
$this->started_sync_count += 1; |
148
|
|
|
} |
149
|
|
|
|
150
|
|
|
function test_full_sync_can_select_modules() { |
151
|
|
|
$this->server_replica_storage->reset(); |
152
|
|
|
$this->sender->reset_data(); |
153
|
|
|
$this->factory->post->create(); |
154
|
|
|
|
155
|
|
|
$this->full_sync->start( array( 'options' => true ) ); |
|
|
|
|
156
|
|
|
|
157
|
|
|
$this->sender->do_full_sync(); |
158
|
|
|
|
159
|
|
|
$start_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_start' ); |
160
|
|
|
|
161
|
|
|
$options_full_sync_actions = Modules::get_module( 'options' )->get_full_sync_actions(); |
162
|
|
|
$options_event = $this->server_event_storage->get_most_recent_event( $options_full_sync_actions[0] ); |
163
|
|
|
|
164
|
|
|
$posts_full_sync_actions = Modules::get_module( 'posts' )->get_full_sync_actions(); |
165
|
|
|
$posts_event = $this->server_event_storage->get_most_recent_event( $posts_full_sync_actions[0] ); |
166
|
|
|
|
167
|
|
|
$this->assertTrue( $start_event !== false ); |
168
|
|
|
$this->assertTrue( $options_event !== false ); |
169
|
|
|
$this->assertTrue( $posts_event === false ); |
170
|
|
|
} |
171
|
|
|
|
172
|
|
View Code Duplication |
function test_full_sync_sends_wp_version() { |
173
|
|
|
$this->server_replica_storage->reset(); |
174
|
|
|
$this->sender->reset_data(); |
175
|
|
|
|
176
|
|
|
$this->full_sync->start(); |
|
|
|
|
177
|
|
|
$this->sender->do_full_sync(); |
178
|
|
|
|
179
|
|
|
global $wp_version; |
180
|
|
|
$this->assertEquals( $wp_version, $this->server_replica_storage->get_callable( 'wp_version' ) ); |
181
|
|
|
} |
182
|
|
|
|
183
|
|
View Code Duplication |
function test_sync_post_filtered_content_was_filtered_when_syncing_all() { |
184
|
|
|
$post_id = $this->factory->post->create(); |
185
|
|
|
$post = get_post( $post_id ); |
186
|
|
|
add_shortcode( 'foo', array( $this, 'foo_shortcode' ) ); |
187
|
|
|
$post->post_content = "[foo]"; |
188
|
|
|
wp_update_post( $post ); |
189
|
|
|
$this->server_replica_storage->reset(); |
190
|
|
|
$this->sender->reset_data(); |
191
|
|
|
// this only applies to rendered content, which is off by default |
192
|
|
|
Settings::update_settings( array( 'render_filtered_content' => 1 ) ); |
193
|
|
|
|
194
|
|
|
$this->full_sync->start(); |
|
|
|
|
195
|
|
|
$this->sender->do_full_sync(); |
196
|
|
|
|
197
|
|
|
$post_on_server = $this->server_replica_storage->get_post( $post->ID ); |
198
|
|
|
$this->assertEquals( $post_on_server->post_content, '[foo]' ); |
199
|
|
|
$this->assertEquals( trim( $post_on_server->post_content_filtered ), 'bar' ); |
200
|
|
|
} |
201
|
|
|
|
202
|
|
|
function foo_shortcode() { |
203
|
|
|
return 'bar'; |
204
|
|
|
} |
205
|
|
|
|
206
|
|
View Code Duplication |
function test_full_sync_sends_all_comments() { |
207
|
|
|
$post = $this->factory->post->create(); |
208
|
|
|
$this->factory->comment->create_post_comments( $post, 11 ); |
209
|
|
|
|
210
|
|
|
// simulate emptying the server storage |
211
|
|
|
$this->server_replica_storage->reset(); |
212
|
|
|
$this->sender->reset_data(); |
213
|
|
|
|
214
|
|
|
$this->full_sync->start(); |
|
|
|
|
215
|
|
|
$this->sender->do_full_sync(); |
216
|
|
|
|
217
|
|
|
$comments = $this->server_replica_storage->get_comments(); |
218
|
|
|
$this->assertEquals( 11, count( $comments ) ); |
219
|
|
|
} |
220
|
|
|
|
221
|
|
View Code Duplication |
function test_full_sync_sends_all_terms() { |
222
|
|
|
$NUMBER_OF_TERMS_TO_CREATE = 11; |
223
|
|
|
$this->server_replica_storage->reset(); |
224
|
|
|
$this->sender->reset_data(); |
225
|
|
|
for ( $i = 0; $i < $NUMBER_OF_TERMS_TO_CREATE; $i += 1 ) { |
226
|
|
|
wp_insert_term( 'category ' . $i, 'category' ); |
227
|
|
|
wp_insert_term( 'term ' . $i, 'post_tag' ); |
228
|
|
|
} |
229
|
|
|
|
230
|
|
|
// simulate emptying the server storage |
231
|
|
|
$this->server_replica_storage->reset(); |
232
|
|
|
$this->sender->reset_data(); |
233
|
|
|
|
234
|
|
|
$this->full_sync->start(); |
|
|
|
|
235
|
|
|
$this->sender->do_full_sync(); |
236
|
|
|
|
237
|
|
|
$terms = $this->server_replica_storage->get_terms( 'post_tag' ); |
238
|
|
|
$this->assertEquals( $NUMBER_OF_TERMS_TO_CREATE, count( $terms ) ); |
239
|
|
|
|
240
|
|
|
$terms = $this->server_replica_storage->get_terms( 'category' ); |
241
|
|
|
$this->assertEquals( $NUMBER_OF_TERMS_TO_CREATE + 1, count( $terms ) ); // 11 + 1 (for uncategorized term) |
242
|
|
|
} |
243
|
|
|
|
244
|
|
|
function test_full_sync_sends_all_terms_with_previous_interval_end() { |
245
|
|
|
Settings::update_settings( array( 'max_queue_size_full_sync' => 1, 'max_enqueue_full_sync' => 10 ) ); |
246
|
|
|
|
247
|
|
View Code Duplication |
for ( $i = 0; $i < 25; $i += 1 ) { |
248
|
|
|
wp_insert_term( 'term' . $i, 'post_tag' ); |
249
|
|
|
} |
250
|
|
|
|
251
|
|
|
// The first event is for full sync start. |
252
|
|
|
$this->full_sync->start( array( 'terms' => true ) ); |
|
|
|
|
253
|
|
|
$this->sender->do_full_sync(); |
254
|
|
|
|
255
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
256
|
|
|
$this->sender->do_full_sync(); |
257
|
|
|
|
258
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_terms' ); |
259
|
|
|
$terms = $event->args['terms']; |
260
|
|
|
$previous_interval_end = $event->args['previous_end']; |
261
|
|
|
// The first batch has the previous_min_is not set. |
262
|
|
|
// We user ~0 to denote that the previous min id unknown. |
263
|
|
|
$this->assertEquals( $previous_interval_end, '~0' ); |
264
|
|
|
|
265
|
|
|
// Since posts are order by id and the ids are in decending order |
266
|
|
|
// the very last post should be the id with the smallest ID. ( previous_interval_end ) |
267
|
|
|
$last_term = end( $terms ); |
268
|
|
|
|
269
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
270
|
|
|
$this->sender->do_full_sync(); |
271
|
|
|
|
272
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_terms' ); |
273
|
|
|
$second_batch_terms = $event->args['terms']; |
274
|
|
|
$previous_interval_end = $event->args['previous_end']; |
275
|
|
|
$this->assertEquals( (int) $previous_interval_end, $last_term->term_taxonomy_id ); |
276
|
|
|
|
277
|
|
|
$last_term = end( $second_batch_terms ); |
278
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
279
|
|
|
$this->sender->do_full_sync(); |
280
|
|
|
|
281
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_terms' ); |
282
|
|
|
$previous_interval_end = $event->args['previous_end']; |
283
|
|
|
$this->assertEquals( (int) $previous_interval_end, $last_term->term_taxonomy_id ); |
284
|
|
|
|
285
|
|
|
$this->full_sync->reset_data(); |
286
|
|
|
} |
287
|
|
|
|
288
|
|
|
function test_full_sync_sends_all_term_relationships() { |
289
|
|
|
global $wpdb; |
290
|
|
|
$this->sender->reset_data(); |
291
|
|
|
|
292
|
|
|
$post_ids = $this->factory->post->create_many( 20 ); |
293
|
|
|
|
294
|
|
View Code Duplication |
foreach ( $post_ids as $post_id ) { |
295
|
|
|
wp_set_object_terms( $post_id, array( 'cat1', 'cat2', 'cat3' ), 'category', true ); |
296
|
|
|
wp_set_object_terms( $post_id, array( 'tag1', 'tag2', 'tag3' ), 'post_tag', true ); |
297
|
|
|
} |
298
|
|
|
|
299
|
|
|
$original_number_of_term_relationships = $wpdb->get_var( "SELECT COUNT(*) FROM $wpdb->term_relationships" ); |
300
|
|
|
|
301
|
|
|
// simulate emptying the server storage |
302
|
|
|
$this->server_replica_storage->reset(); |
303
|
|
|
|
304
|
|
|
$this->full_sync->start( array( 'term_relationships' => true ) ); |
|
|
|
|
305
|
|
|
$this->sender->do_full_sync(); |
306
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
307
|
|
|
$this->sender->do_full_sync(); |
308
|
|
|
|
309
|
|
|
|
310
|
|
|
$replica_number_of_term_relationships = count( $this->server_replica_storage->get_term_relationships() ); |
311
|
|
|
$this->assertEquals( $original_number_of_term_relationships, $replica_number_of_term_relationships ); |
312
|
|
|
} |
313
|
|
|
|
314
|
|
|
function test_full_sync_enqueue_term_relationships() { |
315
|
|
|
global $wpdb; |
316
|
|
|
|
317
|
|
|
// how many items are we allowed to enqueue on a single request/continue_enqueuing |
318
|
|
|
$max_enqueue_full_sync = 2; |
319
|
|
|
// how many sync items the full sync queue can contain |
320
|
|
|
$max_queue_size_full_sync = 3; |
321
|
|
|
// how many term relationships we can put on a full_sync_term_relationships item |
322
|
|
|
$sync_item_size = 4; |
323
|
|
|
|
324
|
|
|
Settings::update_settings( [ |
325
|
|
|
'term_relationships_full_sync_item_size' => $sync_item_size, |
326
|
|
|
'max_queue_size_full_sync' => $max_queue_size_full_sync, |
327
|
|
|
'max_enqueue_full_sync' => $max_enqueue_full_sync, |
328
|
|
|
] ); |
329
|
|
|
|
330
|
|
|
$post_ids = $this->factory->post->create_many( 4 ); |
331
|
|
|
|
332
|
|
View Code Duplication |
foreach ( $post_ids as $post_id ) { |
333
|
|
|
wp_set_object_terms( $post_id, array( 'cat1', 'cat2', 'cat3' ), 'category', true ); |
334
|
|
|
wp_set_object_terms( $post_id, array( 'tag1', 'tag2', 'tag3' ), 'post_tag', true ); |
335
|
|
|
} |
336
|
|
|
|
337
|
|
|
// 28 |
338
|
|
|
$original_number_of_term_relationships = $wpdb->get_var( "SELECT COUNT(*) FROM $wpdb->term_relationships" ); |
339
|
|
|
// ceil(28/4) = 7 |
340
|
|
|
$total_items = (int) ceil( $original_number_of_term_relationships / $sync_item_size ); |
341
|
|
|
|
342
|
|
|
$this->full_sync->start( array( 'term_relationships' => true ) ); |
|
|
|
|
343
|
|
|
$this->sender->do_full_sync(); // empty the queue since – "full_sync_start" takes one item in the queue |
344
|
|
|
|
345
|
|
|
$status = $this->full_sync->get_enqueue_status(); |
|
|
|
|
346
|
|
|
list( $total, $initial_queued, $finished ) = $status['term_relationships']; |
347
|
|
|
|
348
|
|
|
$this->assertEquals( $total_items, $total ); |
349
|
|
|
$this->assertEquals( $max_enqueue_full_sync, $initial_queued ); |
350
|
|
|
$this->assertNotTrue( $finished ); |
351
|
|
|
|
352
|
|
|
$this->full_sync->continue_enqueuing(); // try to enqueue $max_enqueue_full_sync items |
|
|
|
|
353
|
|
|
$this->full_sync->continue_enqueuing(); // try to enqueue $max_enqueue_full_sync items |
|
|
|
|
354
|
|
|
|
355
|
|
|
// hit $max_queue_size_full_sync limit |
356
|
|
|
$status = $this->full_sync->get_enqueue_status(); |
|
|
|
|
357
|
|
|
list( $total, $queued, $finished ) = $status['term_relationships']; |
358
|
|
|
$this->assertNotTrue( $finished ); |
359
|
|
|
$this->assertEquals( $initial_queued + $max_queue_size_full_sync, $queued ); |
360
|
|
|
|
361
|
|
|
$this->sender->do_full_sync(); |
362
|
|
|
|
363
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
364
|
|
|
|
365
|
|
|
$status = $this->full_sync->get_enqueue_status(); |
|
|
|
|
366
|
|
|
list( $total, $queued, $finished ) = $status['term_relationships']; |
367
|
|
|
|
368
|
|
|
$this->assertEquals( $total_items, $total ); |
369
|
|
|
$this->assertEquals( $total_items, $queued ); |
370
|
|
|
$this->assertSame( $finished, true ); |
371
|
|
|
} |
372
|
|
|
|
373
|
|
|
function test_full_sync_sends_all_term_relationships_with_previous_interval_end() { |
374
|
|
|
$post_id = $this->factory->post->create(); |
375
|
|
|
|
376
|
|
|
$terms = array(); |
377
|
|
View Code Duplication |
for ( $i = 0; $i < 25; $i += 1 ) { |
378
|
|
|
$terms[] = wp_insert_term( 'term ' . $i, 'category' ); |
379
|
|
|
} |
380
|
|
|
|
381
|
|
|
// Sync the posts and terms first. |
382
|
|
|
$this->full_sync->start( array( 'posts' => true, 'terms' => true ) ); |
|
|
|
|
383
|
|
|
$this->sender->do_full_sync(); |
384
|
|
|
|
385
|
|
|
// Simulate emptying the server storage. |
386
|
|
|
$this->server_replica_storage->reset(); |
387
|
|
|
$this->sender->reset_data(); |
388
|
|
|
|
389
|
|
|
Settings::update_settings( |
390
|
|
|
array( |
391
|
|
|
'max_queue_size_full_sync' => 1, |
392
|
|
|
'max_enqueue_full_sync' => 10, |
393
|
|
|
'term_relationships_full_sync_item_size' => 10 |
394
|
|
|
) |
395
|
|
|
); |
396
|
|
|
|
397
|
|
|
foreach ( $terms as $term ) { |
398
|
|
|
wp_set_object_terms( $post_id, array( $term['term_id'] ), 'category', true ); |
399
|
|
|
} |
400
|
|
|
|
401
|
|
|
// The first event is for full sync start. |
402
|
|
|
$this->full_sync->start( array( 'term_relationships' => 1 ) ); |
|
|
|
|
403
|
|
|
$this->sender->do_full_sync(); |
404
|
|
|
|
405
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
406
|
|
|
$this->sender->do_full_sync(); |
407
|
|
|
|
408
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_term_relationships' ); |
409
|
|
|
$term_relationships = $event->args['term_relationships']; |
410
|
|
|
$previous_interval_end = $event->args['previous_end']; |
411
|
|
|
// The first batch has the previous_end not set. |
412
|
|
|
// We use ~0 to denote that the previous_end is unknown. |
413
|
|
|
$this->assertEquals( $previous_interval_end, array( |
414
|
|
|
'object_id' => Modules\Term_Relationships::MAX_INT, |
415
|
|
|
'term_taxonomy_id' => Modules\Term_Relationships::MAX_INT, |
416
|
|
|
) ); |
417
|
|
|
|
418
|
|
|
// Since term relationships are ordered by post IDs and term IDs and the IDs are in descending order |
419
|
|
|
// the very last relationship should have the smallest post ID and term ID. (previous_interval_end) |
420
|
|
|
$last_term = end( $term_relationships ); |
421
|
|
|
|
422
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
423
|
|
|
$this->sender->do_full_sync(); |
424
|
|
|
|
425
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_term_relationships' ); |
426
|
|
|
$second_batch_terms = $event->args['term_relationships']; |
427
|
|
|
$previous_interval_end = $event->args['previous_end']; |
428
|
|
|
$this->assertEquals( (int) $previous_interval_end['object_id'], $last_term['object_id'] ); |
429
|
|
|
$this->assertEquals( (int) $previous_interval_end['term_taxonomy_id'], $last_term['term_taxonomy_id'] ); |
430
|
|
|
|
431
|
|
|
$last_term = end( $second_batch_terms ); |
432
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
433
|
|
|
$this->sender->do_full_sync(); |
434
|
|
|
|
435
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_term_relationships' ); |
436
|
|
|
$previous_interval_end = $event->args['previous_end']; |
437
|
|
|
$this->assertEquals( (int) $previous_interval_end['object_id'], $last_term['object_id'] ); |
438
|
|
|
$this->assertEquals( (int) $previous_interval_end['term_taxonomy_id'], $last_term['term_taxonomy_id'] ); |
439
|
|
|
|
440
|
|
|
$this->full_sync->reset_data(); |
441
|
|
|
} |
442
|
|
|
|
443
|
|
View Code Duplication |
function test_full_sync_sends_all_users() { |
444
|
|
|
$first_user_id = $this->factory->user->create(); |
445
|
|
|
for ( $i = 0; $i < 9; $i += 1 ) { |
446
|
|
|
$user_id = $this->factory->user->create(); |
447
|
|
|
} |
448
|
|
|
|
449
|
|
|
update_user_meta( $user_id, 'locale', 'en_GB' ); |
|
|
|
|
450
|
|
|
// simulate emptying the server storage |
451
|
|
|
$this->server_replica_storage->reset(); |
452
|
|
|
$this->sender->reset_data(); |
453
|
|
|
|
454
|
|
|
$this->full_sync->start(); |
|
|
|
|
455
|
|
|
$this->sender->do_full_sync(); |
456
|
|
|
|
457
|
|
|
// 10 + 1 = 1 users gets always created. |
458
|
|
|
$this->assertEquals( 11, $this->server_replica_storage->user_count() ); |
459
|
|
|
$user = $this->server_replica_storage->get_user( $user_id ); |
460
|
|
|
$this->assertEquals( get_allowed_mime_types( $user_id ), $this->server_replica_storage->get_allowed_mime_types( $user_id ) ); |
461
|
|
|
|
462
|
|
|
$this->assertEquals( get_user_locale( $user_id ), $this->server_replica_storage->get_user_locale( $user_id ) ); |
463
|
|
|
$this->assertNull( $this->server_replica_storage->get_user_locale( $first_user_id ) ); |
464
|
|
|
|
465
|
|
|
// Lets make sure that we don't send users passwords around. |
466
|
|
|
$this->assertFalse( isset( $user->data->user_pass ) ); |
467
|
|
|
} |
468
|
|
|
|
469
|
|
|
function test_full_sync_sends_previous_interval_end_for_users() { |
470
|
|
|
Settings::update_settings( array( 'max_queue_size_full_sync' => 1, 'max_enqueue_full_sync' => 10 ) ); |
471
|
|
|
|
472
|
|
View Code Duplication |
for ( $i = 0; $i < 45; $i += 1 ) { |
473
|
|
|
$user_ids[] = $this->factory->user->create(); |
|
|
|
|
474
|
|
|
} |
475
|
|
|
|
476
|
|
|
// The first event is for full sync start. |
477
|
|
|
$this->full_sync->start( array( 'users' => true ) ); |
|
|
|
|
478
|
|
|
$this->sender->do_full_sync(); |
479
|
|
|
|
480
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
481
|
|
|
$this->sender->do_full_sync(); |
482
|
|
|
|
483
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_users' ); |
484
|
|
|
|
485
|
|
|
$users = $event->args['users']; |
486
|
|
|
$previous_interval_end = $event->args['previous_end']; |
487
|
|
|
|
488
|
|
|
// The first batch has the previous_min_is not set. |
489
|
|
|
// We user ~0 to denote that the previous min id unknown. |
490
|
|
|
$this->assertEquals( $previous_interval_end, '~0' ); |
491
|
|
|
|
492
|
|
|
// Since posts are order by id and the ids are in decending order |
493
|
|
|
// the very last post should be the id with the smallest ID. ( previous_interval_end ) |
494
|
|
|
$last_user = end( $users ); |
495
|
|
|
|
496
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
497
|
|
|
$this->sender->do_full_sync(); |
498
|
|
|
|
499
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_users' ); |
500
|
|
|
|
501
|
|
|
$second_batch_users = $event->args['users']; |
502
|
|
|
$previous_interval_end = $event->args['previous_end']; |
503
|
|
|
|
504
|
|
|
$this->assertEquals( (int) $previous_interval_end, $last_user->ID ); |
505
|
|
|
|
506
|
|
|
$last_user = end( $second_batch_users ); |
507
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
508
|
|
|
$this->sender->do_full_sync(); |
509
|
|
|
|
510
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_users' ); |
511
|
|
|
$previous_interval_end = $event->args['previous_end']; |
512
|
|
|
|
513
|
|
|
$this->assertEquals( (int) $previous_interval_end, $last_user->ID ); |
514
|
|
|
|
515
|
|
|
Settings::reset_data(); |
516
|
|
|
$this->full_sync->reset_data(); |
517
|
|
|
|
518
|
|
|
} |
519
|
|
|
|
520
|
|
|
// phpunit -c tests/php.multisite.xml --filter test_full_sync_sends_only_current_blog_users_in_multisite |
521
|
|
|
function test_full_sync_sends_only_current_blog_users_in_multisite() { |
522
|
|
|
if ( ! is_multisite() ) { |
523
|
|
|
$this->markTestSkipped( 'Run it in multi site mode' ); |
524
|
|
|
} |
525
|
|
|
|
526
|
|
|
$original_blog_id = get_current_blog_id(); |
527
|
|
|
|
528
|
|
|
$user_id = $this->factory->user->create(); |
529
|
|
|
|
530
|
|
|
// NOTE this is necessary because WPMU causes certain assumptions about transients |
531
|
|
|
// to be wrong, and tests to explode. @see: https://github.com/sheabunge/WordPress/commit/ff4f1bb17095c6af8a0f35ac304f79074f3c3ff6 |
532
|
|
|
global $wpdb; |
533
|
|
|
|
534
|
|
|
$suppress = $wpdb->suppress_errors(); |
535
|
|
|
$other_blog_id = wpmu_create_blog( 'foo.com', '', "My Blog", $this->user_id ); |
536
|
|
|
$wpdb->suppress_errors( $suppress ); |
537
|
|
|
|
538
|
|
|
// let's create some users on the other blog |
539
|
|
|
switch_to_blog( $other_blog_id ); |
540
|
|
|
$mu_blog_user_id = $this->factory->user->create(); |
541
|
|
|
$added_mu_blog_user_id = $this->factory->user->create(); |
542
|
|
|
restore_current_blog(); |
543
|
|
|
|
544
|
|
|
// add one of the users to our current blog |
545
|
|
|
add_user_to_blog( $original_blog_id, $added_mu_blog_user_id, 'administrator' ); |
546
|
|
|
|
547
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
548
|
|
|
$this->server_replica_storage->reset(); |
549
|
|
|
$this->sender->get_sync_queue()->reset(); |
550
|
|
|
|
551
|
|
|
// let's register a listener that asserts that only our intended users get enqueued |
552
|
|
|
add_filter( 'jetpack_sync_before_enqueue_jetpack_full_sync_users', array( $this, 'record_full_synced_users' ) ); |
553
|
|
|
|
554
|
|
|
$this->full_sync->start(); |
|
|
|
|
555
|
|
|
|
556
|
|
|
// let's make sure we've only enqueued users from the current blog too |
557
|
|
|
$this->assertTrue( in_array( $added_mu_blog_user_id, $this->synced_user_ids ) ); |
558
|
|
|
$this->assertTrue( in_array( $user_id, $this->synced_user_ids ) ); |
559
|
|
|
$this->assertFalse( in_array( $mu_blog_user_id, $this->synced_user_ids ) ); |
560
|
|
|
|
561
|
|
|
$this->sender->do_full_sync(); |
562
|
|
|
|
563
|
|
|
// admin user, our current-blog-created user and our "added" user |
564
|
|
|
$this->assertEquals( 3, $this->server_replica_storage->user_count() ); |
565
|
|
|
|
566
|
|
|
$this->assertNotNull( $this->server_replica_storage->get_user( $user_id ) ); |
567
|
|
|
$this->assertNotNull( $this->server_replica_storage->get_user( $added_mu_blog_user_id ) ); |
568
|
|
|
$this->assertNull( $this->server_replica_storage->get_user( $mu_blog_user_id ) ); |
569
|
|
|
|
570
|
|
|
// now switch to the other site and sync, and ensure that only that site's users get synced |
571
|
|
|
switch_to_blog( $other_blog_id ); |
572
|
|
|
$this->server_replica_storage->reset(); |
573
|
|
|
$this->sender->get_sync_queue()->reset(); |
574
|
|
|
$this->synced_user_ids = null; |
575
|
|
|
|
576
|
|
|
$this->full_sync->start(); |
|
|
|
|
577
|
|
|
|
578
|
|
|
// first user should be synced, as it's a member of both |
579
|
|
|
$this->assertTrue( in_array( $added_mu_blog_user_id, $this->synced_user_ids ) ); |
580
|
|
|
// second should NOT be synced, as it's only a member of original blog |
581
|
|
|
$this->assertFalse( in_array( $user_id, $this->synced_user_ids ) ); |
582
|
|
|
// third should be synced, as it's a member of created blog |
583
|
|
|
$this->assertTrue( in_array( $mu_blog_user_id, $this->synced_user_ids ) ); |
584
|
|
|
|
585
|
|
|
$this->sender->do_full_sync(); |
586
|
|
|
restore_current_blog(); |
587
|
|
|
|
588
|
|
|
$this->assertEquals( 2, $this->server_replica_storage->user_count() ); |
589
|
|
|
|
590
|
|
|
// again, opposite users from previous sync |
591
|
|
|
$this->assertNotNull( $this->server_replica_storage->get_user( $added_mu_blog_user_id ) ); |
592
|
|
|
$this->assertNull( $this->server_replica_storage->get_user( $user_id ) ); |
593
|
|
|
$this->assertNotNull( $this->server_replica_storage->get_user( $mu_blog_user_id ) ); |
594
|
|
|
} |
595
|
|
|
|
596
|
|
|
function record_full_synced_users( $user_ids ) { |
597
|
|
|
$this->synced_user_ids = $user_ids; |
598
|
|
|
} |
599
|
|
|
|
600
|
|
View Code Duplication |
function test_full_sync_sends_all_constants() { |
601
|
|
|
define( 'TEST_SYNC_ALL_CONSTANTS', 'foo' ); |
602
|
|
|
|
603
|
|
|
$helper = new Jetpack_Sync_Test_Helper(); |
604
|
|
|
$helper->array_override = array( 'TEST_SYNC_ALL_CONSTANTS' ); |
605
|
|
|
add_filter( 'jetpack_sync_constants_whitelist', array( $helper, 'filter_override_array' ) ); |
606
|
|
|
|
607
|
|
|
$this->sender->do_sync(); |
608
|
|
|
|
609
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
610
|
|
|
$this->server_replica_storage->reset(); |
611
|
|
|
|
612
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_constant( 'TEST_SYNC_ALL_CONSTANTS' ) ); |
613
|
|
|
|
614
|
|
|
$this->full_sync->start(); |
|
|
|
|
615
|
|
|
$this->sender->do_full_sync(); |
616
|
|
|
|
617
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_constant( 'TEST_SYNC_ALL_CONSTANTS' ) ); |
618
|
|
|
} |
619
|
|
|
|
620
|
|
View Code Duplication |
function test_full_sync_constants_updates_checksums() { |
621
|
|
|
define( 'FOO_SYNC_ALL_CONSTANTS', 'foo' ); |
622
|
|
|
$this->resetCallableAndConstantTimeouts(); |
623
|
|
|
$helper = new Jetpack_Sync_Test_Helper(); |
624
|
|
|
$helper->array_override = array( 'FOO_SYNC_ALL_CONSTANTS' ); |
625
|
|
|
add_filter( 'jetpack_sync_constants_whitelist', array( $helper, 'filter_override_array' ) ); |
626
|
|
|
$this->full_sync->start(); |
|
|
|
|
627
|
|
|
$this->sender->do_full_sync(); |
628
|
|
|
|
629
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_constant( 'FOO_SYNC_ALL_CONSTANTS' ) ); |
630
|
|
|
|
631
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
632
|
|
|
$this->server_replica_storage->reset(); |
633
|
|
|
$this->server_event_storage->reset(); |
634
|
|
|
// Do Sync shouldn't send anything becuase the checksums are up to date. |
635
|
|
|
$this->sender->do_sync(); |
636
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_constant( 'FOO_SYNC_ALL_CONSTANTS' ) ); |
637
|
|
|
$events = $this->server_event_storage->get_all_events( 'jetpack_sync_constant' ); |
638
|
|
|
$this->assertTrue( empty( $events ) ); |
639
|
|
|
} |
640
|
|
|
|
641
|
|
View Code Duplication |
function test_full_sync_sends_all_functions() { |
642
|
|
|
Modules::get_module( "functions" )->set_callable_whitelist( array( 'jetpack_foo' => 'jetpack_foo_full_sync_callable' ) ); |
|
|
|
|
643
|
|
|
$this->sender->do_sync(); |
644
|
|
|
|
645
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
646
|
|
|
$this->server_replica_storage->reset(); |
647
|
|
|
|
648
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_callable( 'jetpack_foo' ) ); |
649
|
|
|
|
650
|
|
|
$this->full_sync->start(); |
|
|
|
|
651
|
|
|
$this->sender->do_full_sync(); |
652
|
|
|
|
653
|
|
|
$this->assertEquals( 'the value', $this->server_replica_storage->get_callable( 'jetpack_foo' ) ); |
654
|
|
|
} |
655
|
|
|
|
656
|
|
View Code Duplication |
function test_full_sync_sends_all_functions_inverse() { |
657
|
|
|
Modules::get_module( "functions" )->set_callable_whitelist( array( 'jetpack_foo' => 'jetpack_foo_full_sync_callable' ) ); |
|
|
|
|
658
|
|
|
|
659
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
660
|
|
|
$this->server_replica_storage->reset(); |
661
|
|
|
|
662
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_callable( 'jetpack_foo' ) ); |
663
|
|
|
|
664
|
|
|
$this->full_sync->start(); |
|
|
|
|
665
|
|
|
$this->sender->do_full_sync(); |
666
|
|
|
$this->server_replica_storage->reset(); |
667
|
|
|
$this->server_event_storage->reset(); |
668
|
|
|
|
669
|
|
|
$this->resetCallableAndConstantTimeouts(); |
670
|
|
|
$this->sender->do_sync(); |
671
|
|
|
|
672
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_callable( 'jetpack_foo' ) ); |
673
|
|
|
$events = $this->server_event_storage->get_all_events( 'jetpack_sync_callable' ); |
674
|
|
|
$this->assertTrue( empty( $events ) ); |
675
|
|
|
|
676
|
|
|
} |
677
|
|
|
|
678
|
|
View Code Duplication |
function test_full_sync_sends_all_options() { |
679
|
|
|
delete_option( 'non_existant' ); |
680
|
|
|
Modules::get_module( "options" )->set_options_whitelist( array( 'my_option', 'my_prefix_value', 'non_existant' ) ); |
|
|
|
|
681
|
|
|
update_option( 'my_option', 'foo' ); |
682
|
|
|
update_option( 'my_prefix_value', 'bar' ); |
683
|
|
|
update_option( 'my_non_synced_option', 'baz' ); |
684
|
|
|
|
685
|
|
|
$this->sender->do_sync(); |
686
|
|
|
|
687
|
|
|
// confirm sync worked as expected |
688
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_option( 'my_option' ) ); |
689
|
|
|
$this->assertEquals( 'bar', $this->server_replica_storage->get_option( 'my_prefix_value' ) ); |
690
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_option( 'my_non_synced_option' ) ); |
691
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_option( 'non_existant' ) ); |
692
|
|
|
|
693
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
694
|
|
|
$this->server_replica_storage->reset(); |
695
|
|
|
|
696
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_option( 'my_option' ) ); |
697
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_option( 'my_prefix_value' ) ); |
698
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_option( 'non_existant' ) ); |
699
|
|
|
|
700
|
|
|
$this->full_sync->start(); |
|
|
|
|
701
|
|
|
$this->sender->do_full_sync(); |
702
|
|
|
|
703
|
|
|
$synced_options_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_options' ); |
704
|
|
|
$this->assertEquals( sizeof( $synced_options_event->args ), 2, 'Size of synced options not as expected' ); |
705
|
|
|
$this->assertEquals( 'foo', $synced_options_event->args['my_option'] ); |
706
|
|
|
$this->assertEquals( 'bar', $synced_options_event->args['my_prefix_value'] ); |
707
|
|
|
|
708
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_option( 'my_option' ) ); |
709
|
|
|
$this->assertEquals( 'bar', $this->server_replica_storage->get_option( 'my_prefix_value' ) ); |
710
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_option( 'my_non_synced_option' ) ); |
711
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_option( 'non_existant' ) ); |
712
|
|
|
} |
713
|
|
|
|
714
|
|
|
// to test run phpunit -c tests/php.multisite.xml --filter test_full_sync_sends_all_network_options |
715
|
|
View Code Duplication |
function test_full_sync_sends_all_network_options() { |
716
|
|
|
if ( ! is_multisite() ) { |
717
|
|
|
$this->markTestSkipped( 'Run it in multi site mode' ); |
718
|
|
|
} |
719
|
|
|
|
720
|
|
|
Modules::get_module( "network_options" )->set_network_options_whitelist( array( |
|
|
|
|
721
|
|
|
'my_option', |
722
|
|
|
'my_prefix_value' |
723
|
|
|
) ); |
724
|
|
|
update_site_option( 'my_option', 'foo' ); |
725
|
|
|
update_site_option( 'my_prefix_value', 'bar' ); |
726
|
|
|
update_site_option( 'my_non_synced_option', 'baz' ); |
727
|
|
|
|
728
|
|
|
$this->sender->do_sync(); |
729
|
|
|
|
730
|
|
|
// confirm sync worked as expected |
731
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_site_option( 'my_option' ), '' ); |
732
|
|
|
$this->assertEquals( 'bar', $this->server_replica_storage->get_site_option( 'my_prefix_value' ) ); |
733
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_site_option( 'my_non_synced_option' ) ); |
734
|
|
|
|
735
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
736
|
|
|
$this->server_replica_storage->reset(); |
737
|
|
|
|
738
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_site_option( 'my_option' ) ); |
739
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_site_option( 'my_prefix_value' ) ); |
740
|
|
|
|
741
|
|
|
$this->full_sync->start(); |
|
|
|
|
742
|
|
|
$this->sender->do_full_sync(); |
743
|
|
|
|
744
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_site_option( 'my_option' ), 'Network options not synced during full sync' ); |
745
|
|
|
$this->assertEquals( 'bar', $this->server_replica_storage->get_site_option( 'my_prefix_value' ) ); |
746
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_site_option( 'my_non_synced_option' ) ); |
747
|
|
|
} |
748
|
|
|
|
749
|
|
View Code Duplication |
function test_full_sync_sends_all_post_meta() { |
750
|
|
|
$post_id = $this->factory->post->create(); |
751
|
|
|
|
752
|
|
|
Settings::update_settings( array( 'post_meta_whitelist' => array( 'test_meta_key', 'test_meta_array' ) ) ); |
753
|
|
|
|
754
|
|
|
add_post_meta( $post_id, 'test_meta_key', 'foo' ); |
755
|
|
|
add_post_meta( $post_id, 'test_meta_array', array( 'foo', 'bar' ) ); |
756
|
|
|
|
757
|
|
|
$this->sender->do_sync(); |
758
|
|
|
|
759
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_metadata( 'post', $post_id, 'test_meta_key', true ) ); |
760
|
|
|
$this->assertEquals( array( 'foo', 'bar' ), $this->server_replica_storage->get_metadata( 'post', $post_id, 'test_meta_array', true ) ); |
761
|
|
|
|
762
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
763
|
|
|
$this->server_replica_storage->reset(); |
764
|
|
|
|
765
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, 'test_meta_key', true ) ); |
766
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, 'test_meta_array', true ) ); |
767
|
|
|
|
768
|
|
|
$this->full_sync->start(); |
|
|
|
|
769
|
|
|
$this->sender->do_full_sync(); |
770
|
|
|
|
771
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_metadata( 'post', $post_id, 'test_meta_key', true ) ); |
772
|
|
|
$this->assertEquals( array( 'foo', 'bar' ), $this->server_replica_storage->get_metadata( 'post', $post_id, 'test_meta_array', true ) ); |
773
|
|
|
} |
774
|
|
|
|
775
|
|
View Code Duplication |
function test_full_sync_doesnt_sends_forbiden_private_or_public_post_meta() { |
776
|
|
|
$post_id = $this->factory->post->create(); |
777
|
|
|
|
778
|
|
|
$meta_module = Modules::get_module( "meta" ); |
|
|
|
|
779
|
|
|
Settings::update_settings( array( 'post_meta_whitelist' => array( 'a_public_meta' ) ) ); |
780
|
|
|
|
781
|
|
|
// forbidden private meta |
782
|
|
|
add_post_meta( $post_id, '_test_meta_key', 'foo1' ); |
783
|
|
|
add_post_meta( $post_id, '_test_meta_array', array( 'foo2', 'bar' ) ); |
784
|
|
|
// forbidden public meta |
785
|
|
|
add_post_meta( $post_id, 'snapTW', 'foo3' ); |
786
|
|
|
// ok private meta |
787
|
|
|
add_post_meta( $post_id, '_wp_attachment_metadata', 'foo4' ); |
788
|
|
|
// ok public meta |
789
|
|
|
add_post_meta( $post_id, 'a_public_meta', 'foo5' ); |
790
|
|
|
|
791
|
|
|
$this->sender->do_sync(); |
792
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, '_test_meta_key', true ) ); |
793
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, '_test_meta_array', true ) ); |
794
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, 'snapTW', true ) ); |
795
|
|
|
$this->assertEquals( 'foo4', $this->server_replica_storage->get_metadata( 'post', $post_id, '_wp_attachment_metadata', true ) ); |
796
|
|
|
$this->assertEquals( 'foo5', $this->server_replica_storage->get_metadata( 'post', $post_id, 'a_public_meta', true ) ); |
797
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
798
|
|
|
$this->server_replica_storage->reset(); |
799
|
|
|
|
800
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, '_test_meta_key', true ) ); |
801
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, '_test_meta_array', true ) ); |
802
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, 'snapTW', true ) ); |
803
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, '_wp_attachment_metadata', true ) ); |
804
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, 'a_public_meta', true ) ); |
805
|
|
|
|
806
|
|
|
$this->full_sync->start(); |
|
|
|
|
807
|
|
|
$this->sender->do_full_sync(); |
808
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, '_test_meta_key', true ) ); |
809
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, '_test_meta_array', true ) ); |
810
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'post', $post_id, 'snapTW', true ) ); |
811
|
|
|
$this->assertEquals( 'foo4', $this->server_replica_storage->get_metadata( 'post', $post_id, '_wp_attachment_metadata', true ) ); |
812
|
|
|
$this->assertEquals( 'foo5', $this->server_replica_storage->get_metadata( 'post', $post_id, 'a_public_meta', true ) ); |
813
|
|
|
} |
814
|
|
|
|
815
|
|
View Code Duplication |
function test_full_sync_sends_all_post_terms() { |
816
|
|
|
$post_id = $this->factory->post->create(); |
817
|
|
|
wp_set_object_terms( $post_id, 'tag', 'post_tag' ); |
818
|
|
|
|
819
|
|
|
$this->sender->do_sync(); |
820
|
|
|
$terms = get_the_terms( $post_id, 'post_tag' ); |
821
|
|
|
|
822
|
|
|
$this->assertEqualsObject( $terms, $this->server_replica_storage->get_the_terms( $post_id, 'post_tag' ), 'Initial sync doesn\'t work' ); |
823
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
824
|
|
|
$this->server_replica_storage->reset(); |
825
|
|
|
|
826
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_the_terms( $post_id, 'post_tag', 'Not empty' ) ); |
|
|
|
|
827
|
|
|
$this->full_sync->start(); |
|
|
|
|
828
|
|
|
$this->sender->do_full_sync(); |
829
|
|
|
|
830
|
|
|
$this->assertEqualsObject( $terms, $this->server_replica_storage->get_the_terms( $post_id, 'post_tag' ), 'Full sync doesn\'t work' ); |
831
|
|
|
} |
832
|
|
|
|
833
|
|
View Code Duplication |
function test_full_sync_sends_all_comment_meta() { |
834
|
|
|
$post_id = $this->factory->post->create(); |
835
|
|
|
$comment_ids = $this->factory->comment->create_post_comments( $post_id ); |
836
|
|
|
$comment_id = $comment_ids[0]; |
837
|
|
|
|
838
|
|
|
Settings::update_settings( array( 'comment_meta_whitelist' => array( 'test_meta_key' ) ) ); |
839
|
|
|
|
840
|
|
|
add_comment_meta( $comment_id, 'test_meta_key', 'foo' ); |
841
|
|
|
|
842
|
|
|
$this->sender->do_sync(); |
843
|
|
|
|
844
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_metadata( 'comment', $comment_id, 'test_meta_key', true ) ); |
845
|
|
|
|
846
|
|
|
// reset the storage, check value, and do full sync - storage should be set! |
847
|
|
|
$this->server_replica_storage->reset(); |
848
|
|
|
|
849
|
|
|
$this->assertEquals( null, $this->server_replica_storage->get_metadata( 'comment', $comment_id, 'test_meta_key', true ) ); |
850
|
|
|
|
851
|
|
|
$this->full_sync->start(); |
|
|
|
|
852
|
|
|
$this->sender->do_full_sync(); |
853
|
|
|
|
854
|
|
|
$this->assertEquals( 'foo', $this->server_replica_storage->get_metadata( 'comment', $comment_id, 'test_meta_key', true ) ); |
855
|
|
|
} |
856
|
|
|
|
857
|
|
|
function test_full_sync_sends_theme_info() { |
858
|
|
|
// make sure we don't already use this theme |
859
|
|
|
$this->assertNotEquals( 'twentyfourteen', get_option( 'stylesheet' ) ); |
860
|
|
|
|
861
|
|
|
switch_theme( 'twentyfourteen' ); |
862
|
|
|
set_theme_mod( 'foo', 'bar' ); |
863
|
|
|
$this->sender->do_sync(); |
864
|
|
|
|
865
|
|
|
$this->assertEquals( 'twentyfourteen', $this->server_replica_storage->get_option( 'stylesheet' ) ); |
866
|
|
|
|
867
|
|
|
// now reset the storage and confirm the value is reset |
868
|
|
|
$this->server_replica_storage->reset(); |
869
|
|
|
$this->assertNotEquals( 'twentyfourteen', $this->server_replica_storage->get_option( 'stylesheet' ) ); |
870
|
|
|
|
871
|
|
|
// full sync should restore the value |
872
|
|
|
$this->full_sync->start(); |
|
|
|
|
873
|
|
|
$this->sender->do_full_sync(); |
874
|
|
|
|
875
|
|
|
$this->assertEquals( 'twentyfourteen', $this->server_replica_storage->get_option( 'stylesheet' ) ); |
876
|
|
|
$local_option = get_option( 'theme_mods_twentyfourteen' ); |
877
|
|
|
$remote_option = $this->server_replica_storage->get_option( 'theme_mods_twentyfourteen' ); |
878
|
|
|
|
879
|
|
|
if ( isset( $local_option[0] ) ) { |
880
|
|
|
// this is a spurious value that sometimes gets set during tests, and is |
881
|
|
|
// actively removed before sending to WPCOM |
882
|
|
|
// it appears to be due to a bug which sets array( false ) as the default value for theme_mods |
883
|
|
|
unset( $local_option[0] ); |
884
|
|
|
} |
885
|
|
|
|
886
|
|
|
$this->assertEquals( $local_option, $remote_option ); |
887
|
|
|
|
888
|
|
|
$synced_theme_caps_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_theme_data' ); |
889
|
|
|
$synced_theme_info = $synced_theme_caps_event->args[0]; |
890
|
|
|
|
891
|
|
|
$this->assertTrue( isset( $synced_theme_info['name'] ) ); |
892
|
|
|
$this->assertTrue( isset( $synced_theme_info['slug'] ) ); |
893
|
|
|
$this->assertTrue( isset( $synced_theme_info['uri'] ) ); |
894
|
|
|
$this->assertTrue( isset( $synced_theme_info['version'] ) ); |
895
|
|
|
|
896
|
|
|
$theme_support = $this->server_replica_storage->get_callable( 'theme_support' ); |
897
|
|
|
$this->assertTrue( isset( $theme_support['post-thumbnails'] ) ); |
898
|
|
|
} |
899
|
|
|
|
900
|
|
|
function check_for_updates_to_sync() { |
901
|
|
|
$updates_module = Modules::get_module( 'updates' ); |
902
|
|
|
$updates_module->sync_last_event(); |
903
|
|
|
} |
904
|
|
|
|
905
|
|
View Code Duplication |
function test_full_sync_sends_plugin_updates() { |
906
|
|
|
|
907
|
|
|
if ( is_multisite() ) { |
908
|
|
|
$this->markTestSkipped( 'Not compatible with multisite mode' ); |
909
|
|
|
} |
910
|
|
|
|
911
|
|
|
wp_update_plugins(); |
912
|
|
|
$this->check_for_updates_to_sync(); |
913
|
|
|
$this->sender->do_sync(); |
914
|
|
|
|
915
|
|
|
// check that an update just finished |
916
|
|
|
$updates = $this->server_replica_storage->get_updates( 'plugins' ); |
917
|
|
|
$this->assertTrue( $updates->last_checked > strtotime( "-10 seconds" ) ); |
|
|
|
|
918
|
|
|
|
919
|
|
|
$this->server_replica_storage->reset(); |
920
|
|
|
|
921
|
|
|
$this->assertNull( $this->server_replica_storage->get_updates( 'plugins' ) ); |
922
|
|
|
|
923
|
|
|
// full sync should re-check for plugin updates |
924
|
|
|
$this->full_sync->start(); |
|
|
|
|
925
|
|
|
$this->sender->do_full_sync(); |
926
|
|
|
|
927
|
|
|
$updates = $this->server_replica_storage->get_updates( 'plugins' ); |
928
|
|
|
$this->assertNotNull( $updates ); |
929
|
|
|
$this->assertTrue( $updates->last_checked > strtotime( "-10 seconds" ), 'Last checked is less then 2 seconds: ' . $updates->last_checked . ' - lest then 10 sec:' . strtotime( "-10 seconds" ) ); |
|
|
|
|
930
|
|
|
} |
931
|
|
|
|
932
|
|
View Code Duplication |
function test_full_sync_sends_theme_updates() { |
933
|
|
|
|
934
|
|
|
if ( is_multisite() ) { |
935
|
|
|
$this->markTestSkipped( 'Not compatible with multisite mode' ); |
936
|
|
|
} |
937
|
|
|
|
938
|
|
|
wp_update_themes(); |
939
|
|
|
$this->check_for_updates_to_sync(); |
940
|
|
|
$this->sender->do_sync(); |
941
|
|
|
|
942
|
|
|
// check that an update just finished |
943
|
|
|
$updates = $this->server_replica_storage->get_updates( 'themes' ); |
944
|
|
|
$this->assertTrue( $updates->last_checked > strtotime( "-2 seconds" ) ); |
|
|
|
|
945
|
|
|
|
946
|
|
|
// we need to do this because there's a check for elapsed time since last update |
947
|
|
|
// in the wp_update_themes() function |
948
|
|
|
$this->server_replica_storage->reset(); |
949
|
|
|
|
950
|
|
|
$this->assertNull( $this->server_replica_storage->get_updates( 'themes' ) ); |
951
|
|
|
|
952
|
|
|
// full sync should re-check for plugin updates |
953
|
|
|
$this->full_sync->start(); |
|
|
|
|
954
|
|
|
$this->sender->do_full_sync(); |
955
|
|
|
|
956
|
|
|
$updates = $this->server_replica_storage->get_updates( 'themes' ); |
957
|
|
|
$this->assertNotNull( $updates ); |
958
|
|
|
$this->assertTrue( $updates->last_checked > strtotime( "-10 seconds" ) ); |
|
|
|
|
959
|
|
|
} |
960
|
|
|
|
961
|
|
View Code Duplication |
function test_full_sync_sends_core_updates() { |
962
|
|
|
|
963
|
|
|
if ( is_multisite() ) { |
964
|
|
|
$this->markTestSkipped( 'Not compatible with multisite mode' ); |
965
|
|
|
} |
966
|
|
|
|
967
|
|
|
_maybe_update_core(); |
968
|
|
|
|
969
|
|
|
$this->sender->do_sync(); |
970
|
|
|
|
971
|
|
|
// check that an update just finished |
972
|
|
|
$updates = $this->server_replica_storage->get_updates( 'core' ); |
973
|
|
|
$this->assertTrue( $updates->last_checked > strtotime( "-10 seconds" ) ); |
|
|
|
|
974
|
|
|
|
975
|
|
|
// we need to do this because there's a check for elapsed time since last update |
976
|
|
|
// in the wp_update_core() function |
977
|
|
|
$this->server_replica_storage->reset(); |
978
|
|
|
|
979
|
|
|
$this->assertNull( $this->server_replica_storage->get_updates( 'core' ) ); |
980
|
|
|
|
981
|
|
|
// full sync should re-check for plugin updates |
982
|
|
|
$this->full_sync->start(); |
|
|
|
|
983
|
|
|
$this->sender->do_full_sync(); |
984
|
|
|
|
985
|
|
|
$updates = $this->server_replica_storage->get_updates( 'core' ); |
986
|
|
|
$this->assertNotNull( $updates ); |
987
|
|
|
$this->assertTrue( $updates->last_checked > strtotime( "-10 seconds" ) ); |
|
|
|
|
988
|
|
|
} |
989
|
|
|
|
990
|
|
|
function test_full_sync_start_sends_configuration() { |
991
|
|
|
$post_ids = $this->factory->post->create_many( 3 ); |
992
|
|
|
|
993
|
|
|
// this is so that on WPCOM we can tell what has been synchronized in the past |
994
|
|
|
add_action( 'jetpack_full_sync_start', array( $this, 'record_full_sync_start_config' ), 10, 1 ); |
995
|
|
|
|
996
|
|
|
$standard_config = array( |
997
|
|
|
'constants' => true, |
998
|
|
|
'functions' => true, |
999
|
|
|
'options' => true, |
1000
|
|
|
'terms' => true, |
1001
|
|
|
'term_relationships' => true, |
1002
|
|
|
'themes' => true, |
1003
|
|
|
'users' => true, |
1004
|
|
|
'updates' => true, |
1005
|
|
|
'posts' => true, |
1006
|
|
|
'network_options' => true, |
1007
|
|
|
); |
1008
|
|
|
|
1009
|
|
|
$this->full_sync->start(); |
|
|
|
|
1010
|
|
|
|
1011
|
|
|
$this->assertEquals( $standard_config, $this->full_sync_start_config ); |
1012
|
|
|
|
1013
|
|
|
$custom_config = array( 'posts' => $post_ids ); |
1014
|
|
|
|
1015
|
|
|
$this->full_sync->start( $custom_config ); |
|
|
|
|
1016
|
|
|
|
1017
|
|
|
$this->assertEquals( $custom_config, $this->full_sync_start_config ); |
1018
|
|
|
} |
1019
|
|
|
|
1020
|
|
View Code Duplication |
function test_full_sync_end_sends_checksums() { |
1021
|
|
|
$this->markTestSkipped( "We don't send checksums in this version" ); |
1022
|
|
|
add_action( 'jetpack_full_sync_end', array( $this, 'record_full_sync_end_checksum' ), 10, 1 ); |
1023
|
|
|
|
1024
|
|
|
$this->full_sync->start(); |
|
|
|
|
1025
|
|
|
$this->sender->do_full_sync(); |
1026
|
|
|
$this->sender->do_full_sync(); |
1027
|
|
|
$this->sender->do_full_sync(); |
1028
|
|
|
|
1029
|
|
|
$this->assertTrue( isset( $this->full_sync_end_checksum ) ); |
1030
|
|
|
$this->assertTrue( isset( $this->full_sync_end_checksum['posts'] ) ); |
1031
|
|
|
$this->assertTrue( isset( $this->full_sync_end_checksum['comments'] ) ); |
1032
|
|
|
} |
1033
|
|
|
|
1034
|
|
View Code Duplication |
function test_full_sync_end_sends_range() { |
1035
|
|
|
$this->create_dummy_data_and_empty_the_queue(); |
1036
|
|
|
add_action( 'jetpack_full_sync_end', array( $this, 'record_full_sync_end_checksum' ), 10, 2 ); |
1037
|
|
|
|
1038
|
|
|
$this->full_sync->start(); |
|
|
|
|
1039
|
|
|
$this->sender->do_full_sync(); |
1040
|
|
|
$this->sender->do_full_sync(); |
1041
|
|
|
$this->sender->do_full_sync(); |
1042
|
|
|
|
1043
|
|
|
$this->assertTrue( isset( $this->full_sync_end_range ) ); |
1044
|
|
|
$this->assertTrue( isset( $this->full_sync_end_range['posts']->max ) ); |
1045
|
|
|
$this->assertTrue( isset( $this->full_sync_end_range['posts']->min ) ); |
1046
|
|
|
$this->assertTrue( isset( $this->full_sync_end_range['posts']->count ) ); |
1047
|
|
|
|
1048
|
|
|
$this->assertTrue( isset( $this->full_sync_end_range['comments']->max ) ); |
1049
|
|
|
$this->assertTrue( isset( $this->full_sync_end_range['comments']->min ) ); |
1050
|
|
|
$this->assertTrue( isset( $this->full_sync_end_range['comments']->count ) ); |
1051
|
|
|
|
1052
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_end' ); |
1053
|
|
|
|
1054
|
|
|
list( $checksum, $range ) = $event->args; |
|
|
|
|
1055
|
|
|
$this->assertTrue( isset( $range['posts']->max ) ); |
1056
|
|
|
$this->assertTrue( isset( $range['posts']->min ) ); |
1057
|
|
|
$this->assertTrue( isset( $range['posts']->count ) ); |
1058
|
|
|
|
1059
|
|
|
$this->assertTrue( isset( $range['comments']->max ) ); |
1060
|
|
|
$this->assertTrue( isset( $range['comments']->min ) ); |
1061
|
|
|
$this->assertTrue( isset( $range['comments']->count ) ); |
1062
|
|
|
} |
1063
|
|
|
function record_full_sync_end_checksum( $checksum, $range ) { |
1064
|
|
|
// $checksum has been deprecated... |
1065
|
|
|
$this->full_sync_end_range = $range; |
1066
|
|
|
} |
1067
|
|
|
|
1068
|
|
|
function record_full_sync_start_config( $modules ) { |
1069
|
|
|
$this->full_sync_start_config = $modules; |
1070
|
|
|
} |
1071
|
|
|
|
1072
|
|
View Code Duplication |
function create_dummy_data_and_empty_the_queue() { |
1073
|
|
|
// lets create a bunch of posts |
1074
|
|
|
for ( $i = 0; $i < $this->test_posts_count; $i += 1 ) { |
1075
|
|
|
$post = $this->factory->post->create(); |
1076
|
|
|
} |
1077
|
|
|
// lets create a bunch of comments |
1078
|
|
|
$this->factory->comment->create_post_comments( $post, $this->test_comments_count ); |
|
|
|
|
1079
|
|
|
|
1080
|
|
|
// reset the data before the full sync |
1081
|
|
|
$this->sender->reset_data(); |
1082
|
|
|
} |
1083
|
|
|
|
1084
|
|
|
function test_full_sync_status_should_be_not_started_after_reset() { |
1085
|
|
|
$this->create_dummy_data_and_empty_the_queue(); |
1086
|
|
|
|
1087
|
|
|
$full_sync_status = $this->full_sync->get_status(); |
|
|
|
|
1088
|
|
|
$this->assertEquals( |
1089
|
|
|
$full_sync_status, |
1090
|
|
|
array( |
1091
|
|
|
'started' => null, |
1092
|
|
|
'queue_finished' => null, |
1093
|
|
|
'send_started' => null, |
1094
|
|
|
'finished' => null, |
1095
|
|
|
'total' => array(), |
1096
|
|
|
'sent' => array(), |
1097
|
|
|
'sent_total' => array(), |
1098
|
|
|
'queue' => array(), |
1099
|
|
|
'config' => null, |
1100
|
|
|
) |
1101
|
|
|
); |
1102
|
|
|
} |
1103
|
|
|
|
1104
|
|
|
function test_full_sync_status_after_start() { |
1105
|
|
|
$this->create_dummy_data_and_empty_the_queue(); |
1106
|
|
|
|
1107
|
|
|
$this->full_sync->start(); |
|
|
|
|
1108
|
|
|
|
1109
|
|
|
$full_sync_status = $this->full_sync->get_status(); |
|
|
|
|
1110
|
|
|
|
1111
|
|
|
$should_be_status = array( |
1112
|
|
|
'queue' => array( |
1113
|
|
|
'constants' => 1, |
1114
|
|
|
'functions' => 1, |
1115
|
|
|
'options' => 1, |
1116
|
|
|
'posts' => 2, |
1117
|
|
|
'comments' => 2, |
1118
|
|
|
'themes' => 1, |
1119
|
|
|
'updates' => 1, |
1120
|
|
|
'users' => 1, |
1121
|
|
|
'terms' => 1, |
1122
|
|
|
'term_relationships' => 1, |
1123
|
|
|
'network_options' => 1, |
1124
|
|
|
), |
1125
|
|
|
'config' => null |
1126
|
|
|
); |
1127
|
|
|
|
1128
|
|
|
$this->assertEquals( $should_be_status['queue'], $full_sync_status['queue'] ); |
1129
|
|
|
$this->assertEquals( $should_be_status['config'], $full_sync_status['config'] ); |
1130
|
|
|
$this->assertInternalType( 'int', $full_sync_status['started'] ); |
1131
|
|
|
$this->assertInternalType( 'int', $full_sync_status['queue_finished'] ); |
1132
|
|
|
$this->assertNull( $full_sync_status['send_started'] ); |
1133
|
|
|
$this->assertNull( $full_sync_status['finished'] ); |
1134
|
|
|
$this->assertInternalType( 'array', $full_sync_status['sent'] ); |
1135
|
|
|
$this->assertInternalType( 'array', $full_sync_status['sent_total'] ); |
1136
|
|
|
} |
1137
|
|
|
|
1138
|
|
|
function test_full_sync_status_after_end() { |
1139
|
|
|
$this->create_dummy_data_and_empty_the_queue(); |
1140
|
|
|
|
1141
|
|
|
$this->full_sync->start(); |
|
|
|
|
1142
|
|
|
$this->sender->do_full_sync(); |
1143
|
|
|
|
1144
|
|
|
$full_sync_status = $this->full_sync->get_status(); |
|
|
|
|
1145
|
|
|
|
1146
|
|
|
$should_be_status = array( |
1147
|
|
|
'sent' => array( |
1148
|
|
|
'constants' => 1, |
1149
|
|
|
'functions' => 1, |
1150
|
|
|
'options' => 1, |
1151
|
|
|
'posts' => 2, |
1152
|
|
|
'comments' => 2, |
1153
|
|
|
'themes' => 1, |
1154
|
|
|
'updates' => 1, |
1155
|
|
|
'users' => 1, |
1156
|
|
|
'terms' => 1, |
1157
|
|
|
'term_relationships' => 1, |
1158
|
|
|
'network_options' => 1, |
1159
|
|
|
), |
1160
|
|
|
'sent_total' => array( |
1161
|
|
|
'constants' => -1, |
1162
|
|
|
'functions' => -1, |
1163
|
|
|
'options' => -1, |
1164
|
|
|
'themes' => -1, |
1165
|
|
|
'updates' => -1, |
1166
|
|
|
'posts' => $this->test_posts_count, |
1167
|
|
|
'comments' => $this->test_comments_count, |
1168
|
|
|
'users' => 1, |
1169
|
|
|
'terms' => 1, |
1170
|
|
|
'term_relationships' => $this->test_posts_count, // Intentional; each post is in minimum one category by default. |
1171
|
|
|
'network_options' => -1, |
1172
|
|
|
), |
1173
|
|
|
'queue' => array( |
1174
|
|
|
'constants' => 1, |
1175
|
|
|
'functions' => 1, |
1176
|
|
|
'options' => 1, |
1177
|
|
|
'posts' => 2, |
1178
|
|
|
'comments' => 2, |
1179
|
|
|
'themes' => 1, |
1180
|
|
|
'updates' => 1, |
1181
|
|
|
'users' => 1, |
1182
|
|
|
'terms' => 1, |
1183
|
|
|
'term_relationships' => 1, |
1184
|
|
|
'network_options' => 1, |
1185
|
|
|
) |
1186
|
|
|
); |
1187
|
|
|
|
1188
|
|
|
$this->assertEquals( $full_sync_status['queue'], $should_be_status['queue'] ); |
1189
|
|
|
$this->assertEquals( $full_sync_status['sent'], $should_be_status['sent'] ); |
1190
|
|
|
$this->assertEquals( $full_sync_status['sent_total'], $should_be_status['sent_total'] ); |
1191
|
|
|
$this->assertInternalType( 'int', $full_sync_status['started'] ); |
1192
|
|
|
$this->assertInternalType( 'int', $full_sync_status['queue_finished'] ); |
1193
|
|
|
$this->assertInternalType( 'int', $full_sync_status['send_started'] ); |
1194
|
|
|
$this->assertInternalType( 'int', $full_sync_status['finished'] ); |
1195
|
|
|
} |
1196
|
|
|
|
1197
|
|
View Code Duplication |
function test_full_sync_respects_post_and_comment_filters() { |
1198
|
|
|
add_filter( 'jetpack_sync_prevent_sending_comment_data', '__return_true' ); |
1199
|
|
|
add_filter( 'jetpack_sync_prevent_sending_post_data', '__return_true' ); |
1200
|
|
|
|
1201
|
|
|
$post_id = $this->factory->post->create(); |
1202
|
|
|
$this->factory->comment->create_post_comments( $post_id, 3 ); |
1203
|
|
|
|
1204
|
|
|
$this->full_sync->start(); |
|
|
|
|
1205
|
|
|
$this->sender->do_full_sync(); |
1206
|
|
|
|
1207
|
|
|
remove_filter( 'jetpack_sync_prevent_sending_comment_data', '__return_true' ); |
1208
|
|
|
remove_filter( 'jetpack_sync_prevent_sending_post_data', '__return_true' ); |
1209
|
|
|
|
1210
|
|
|
$this->assertEquals( 3, $this->server_replica_storage->comment_count( 'jetpack_sync_blocked' ) ); |
1211
|
|
|
$blocked_post = $this->server_replica_storage->get_post( $post_id ); |
1212
|
|
|
$this->assertEquals( 'jetpack_sync_blocked', $blocked_post->post_status ); |
1213
|
|
|
} |
1214
|
|
|
|
1215
|
|
View Code Duplication |
function test_full_sync_do_not_sync_events_if_no_data_to_sync() { |
1216
|
|
|
$non_existent_id = 123123123123123213; |
1217
|
|
|
$non_existent_post = get_post( $non_existent_id ); |
1218
|
|
|
$non_existent_comment = get_comment( $non_existent_id ); |
1219
|
|
|
$non_existent_user = get_user_by( 'id', $non_existent_id ); |
1220
|
|
|
|
1221
|
|
|
$this->assertTrue( empty( $non_existent_post ) ); |
1222
|
|
|
$this->assertTrue( empty( $non_existent_comment ) ); |
1223
|
|
|
$this->assertTrue( empty( $non_existent_user ) ); |
1224
|
|
|
|
1225
|
|
|
$this->full_sync->start( array( 'posts' => array( $non_existent_id ), 'comments' => array( $non_existent_id ), 'users' => array( $non_existent_id ) ) ); |
|
|
|
|
1226
|
|
|
$this->sender->do_full_sync(); |
1227
|
|
|
|
1228
|
|
|
$this->assertFalse( $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_posts' ) ); |
1229
|
|
|
$this->assertFalse( $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_comments' ) ); |
1230
|
|
|
$this->assertFalse( $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_users' ) ); |
1231
|
|
|
} |
1232
|
|
|
|
1233
|
|
View Code Duplication |
function test_full_sync_can_sync_individual_posts() { |
1234
|
|
|
$sync_post_id = $this->factory->post->create(); |
1235
|
|
|
$sync_post_id_2 = $this->factory->post->create(); |
1236
|
|
|
$no_sync_post_id = $this->factory->post->create(); |
|
|
|
|
1237
|
|
|
|
1238
|
|
|
$this->full_sync->start( array( 'posts' => array( $sync_post_id, $sync_post_id_2 ) ) ); |
|
|
|
|
1239
|
|
|
$this->sender->do_full_sync(); |
1240
|
|
|
|
1241
|
|
|
$synced_posts_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_posts' ); |
1242
|
|
|
|
1243
|
|
|
$posts = $synced_posts_event->args[0]; |
1244
|
|
|
|
1245
|
|
|
$this->assertEquals( 2, count( $posts ) ); |
1246
|
|
|
$this->assertEquals( $sync_post_id_2, $posts[0]->ID ); |
1247
|
|
|
$this->assertEquals( $sync_post_id, $posts[1]->ID ); |
1248
|
|
|
|
1249
|
|
|
$sync_status = $this->full_sync->get_status(); |
|
|
|
|
1250
|
|
|
$this->assertEquals( array( $sync_post_id, $sync_post_id_2 ), $sync_status['config']['posts'] ); |
1251
|
|
|
} |
1252
|
|
|
|
1253
|
|
View Code Duplication |
function test_full_sync_can_sync_individual_comments() { |
1254
|
|
|
$post_id = $this->factory->post->create(); |
1255
|
|
|
list( $sync_comment_id, $no_sync_comment_id, $sync_comment_id_2 ) = $this->factory->comment->create_post_comments( $post_id, 3 ); |
|
|
|
|
1256
|
|
|
|
1257
|
|
|
$this->full_sync->start( array( 'comments' => array( $sync_comment_id, $sync_comment_id_2 ) ) ); |
|
|
|
|
1258
|
|
|
$this->sender->do_full_sync(); |
1259
|
|
|
|
1260
|
|
|
$synced_comments_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_comments' ); |
1261
|
|
|
|
1262
|
|
|
$comments = $synced_comments_event->args[0]; |
1263
|
|
|
|
1264
|
|
|
$this->assertEquals( 2, count( $comments ) ); |
1265
|
|
|
$comment_IDs = array( $comments[0]->comment_ID, $comments[1]->comment_ID ); |
1266
|
|
|
|
1267
|
|
|
$this->assertContains( $sync_comment_id, $comment_IDs ); |
1268
|
|
|
$this->assertContains( $sync_comment_id_2, $comment_IDs ); |
1269
|
|
|
|
1270
|
|
|
$sync_status = $this->full_sync->get_status(); |
|
|
|
|
1271
|
|
|
$this->assertEquals( array( $sync_comment_id, $sync_comment_id_2 ), $sync_status['config']['comments'] ); |
1272
|
|
|
} |
1273
|
|
|
|
1274
|
|
View Code Duplication |
function test_full_sync_can_sync_individual_users() { |
1275
|
|
|
$sync_user_id = $this->factory->user->create(); |
1276
|
|
|
$sync_user_id_2 = $this->factory->user->create(); |
1277
|
|
|
$no_sync_user_id = $this->factory->user->create(); |
|
|
|
|
1278
|
|
|
|
1279
|
|
|
$this->full_sync->start( array( 'users' => array( $sync_user_id, $sync_user_id_2) ) ); |
|
|
|
|
1280
|
|
|
$this->sender->do_full_sync(); |
1281
|
|
|
|
1282
|
|
|
$synced_users_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_users' ); |
1283
|
|
|
|
1284
|
|
|
$users = $synced_users_event->args['users']; |
1285
|
|
|
|
1286
|
|
|
$this->assertEquals( 2, count( $users ) ); |
1287
|
|
|
// The users are ordered in reverse order now. |
1288
|
|
|
$this->assertEquals( $sync_user_id_2, $users[0]->ID ); |
1289
|
|
|
$this->assertEquals( $sync_user_id, $users[1]->ID ); |
1290
|
|
|
|
1291
|
|
|
$sync_status = $this->full_sync->get_status(); |
|
|
|
|
1292
|
|
|
$this->assertEquals( array( $sync_user_id, $sync_user_id_2 ), $sync_status['config']['users'] ); |
1293
|
|
|
} |
1294
|
|
|
|
1295
|
|
View Code Duplication |
function test_full_sync_doesnt_send_deleted_posts() { |
1296
|
|
|
|
1297
|
|
|
// previously, the behavior was to send false or throw errors - we |
1298
|
|
|
// should actively detect false values and remove them |
1299
|
|
|
$keep_post_id = $this->factory->post->create(); |
1300
|
|
|
$delete_post_id = $this->factory->post->create(); |
1301
|
|
|
|
1302
|
|
|
$this->full_sync->start(); |
|
|
|
|
1303
|
|
|
|
1304
|
|
|
wp_delete_post( $delete_post_id, true ); |
1305
|
|
|
|
1306
|
|
|
$this->sender->do_full_sync(); |
1307
|
|
|
|
1308
|
|
|
$synced_posts_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_posts' ); |
1309
|
|
|
|
1310
|
|
|
$posts = $synced_posts_event->args[0]; |
1311
|
|
|
$this->assertEquals( 1, count( $posts ) ); |
1312
|
|
|
$this->assertEquals( $keep_post_id, $posts[0]->ID ); |
1313
|
|
|
} |
1314
|
|
|
|
1315
|
|
View Code Duplication |
function test_full_sync_doesnt_send_deleted_comments() { |
1316
|
|
|
|
1317
|
|
|
// previously, the behavior was to send false or throw errors - we |
1318
|
|
|
// should actively detect false values and remove them |
1319
|
|
|
$post_id = $this->factory->post->create(); |
1320
|
|
|
list( $keep_comment_id, $delete_comment_id ) = $this->factory->comment->create_post_comments( $post_id, 2 ); |
1321
|
|
|
|
1322
|
|
|
$this->full_sync->start(); |
|
|
|
|
1323
|
|
|
|
1324
|
|
|
wp_delete_comment( $delete_comment_id, true ); |
1325
|
|
|
|
1326
|
|
|
$this->sender->do_full_sync(); |
1327
|
|
|
|
1328
|
|
|
$synced_comments_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_comments' ); |
1329
|
|
|
|
1330
|
|
|
$comments = $synced_comments_event->args[0]; |
1331
|
|
|
$this->assertEquals( 1, count( $comments ) ); |
1332
|
|
|
$this->assertEquals( $keep_comment_id, $comments[0]->comment_ID ); |
1333
|
|
|
} |
1334
|
|
|
|
1335
|
|
View Code Duplication |
function test_full_sync_doesnt_send_deleted_users() { |
1336
|
|
|
|
1337
|
|
|
$user_counts = count_users(); |
1338
|
|
|
$existing_user_count = $user_counts['total_users']; |
1339
|
|
|
|
1340
|
|
|
// previously, the behavior was to send false or throw errors - we |
1341
|
|
|
// should actively detect false values and remove them |
1342
|
|
|
$keep_user_id = $this->factory->user->create(); |
1343
|
|
|
$delete_user_id = $this->factory->user->create(); |
1344
|
|
|
|
1345
|
|
|
$this->full_sync->start(); |
|
|
|
|
1346
|
|
|
|
1347
|
|
|
wp_delete_user( $delete_user_id ); |
1348
|
|
|
|
1349
|
|
|
$this->sender->do_full_sync(); |
1350
|
|
|
|
1351
|
|
|
$synced_users_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_users' ); |
1352
|
|
|
$users = $synced_users_event->args['users']; |
1353
|
|
|
|
1354
|
|
|
$this->assertEquals( $existing_user_count+1, count( $users ) ); |
1355
|
|
|
// the last created user should be the fist sent out. |
1356
|
|
|
$this->assertEquals( $keep_user_id, $users[ 0 ]->ID ); |
1357
|
|
|
} |
1358
|
|
|
|
1359
|
|
|
function test_full_sync_has_correct_sent_count_even_if_some_actions_unsent() { |
1360
|
|
|
// if actions get filtered out after dequeue, this can lead to the sent count |
1361
|
|
|
// not matching the queued count - we should make sure the count is incremented even for late-deleted items |
1362
|
|
|
|
1363
|
|
|
$this->sender->do_sync(); |
1364
|
|
|
|
1365
|
|
|
add_filter( 'jetpack_sync_before_send_jetpack_full_sync_users', array( $this, 'dont_sync_users' ) ); |
1366
|
|
|
|
1367
|
|
|
foreach( range( 1, 3 ) as $i ) { |
1368
|
|
|
$this->factory->user->create(); |
1369
|
|
|
} |
1370
|
|
|
|
1371
|
|
|
$this->full_sync->start( array( 'users' => true ) ); |
|
|
|
|
1372
|
|
|
|
1373
|
|
|
$this->sender->do_full_sync(); |
1374
|
|
|
$this->sender->do_full_sync(); |
1375
|
|
|
$this->sender->do_full_sync(); |
1376
|
|
|
|
1377
|
|
|
$full_sync_status = $this->full_sync->get_status(); |
|
|
|
|
1378
|
|
|
|
1379
|
|
|
$this->assertEquals( $full_sync_status['sent']['users'], $full_sync_status['queue']['users'] ); |
1380
|
|
|
} |
1381
|
|
|
|
1382
|
|
|
function dont_sync_users( $args ) { |
1383
|
|
|
return false; |
1384
|
|
|
} |
1385
|
|
|
|
1386
|
|
|
function test_full_sync_status_with_a_small_queue() { |
1387
|
|
|
|
1388
|
|
|
$this->sender->set_dequeue_max_bytes( 1250 ); // process 0.00125MB of items at a time |
1389
|
|
|
|
1390
|
|
|
$this->create_dummy_data_and_empty_the_queue(); |
1391
|
|
|
|
1392
|
|
|
$this->full_sync->start(); |
|
|
|
|
1393
|
|
|
|
1394
|
|
|
$this->sender->do_full_sync(); |
1395
|
|
|
$full_sync_status = $this->full_sync->get_status(); |
|
|
|
|
1396
|
|
|
$this->assertSame( null, $full_sync_status['finished'] ); |
1397
|
|
|
|
1398
|
|
|
$this->sender->do_full_sync(); |
1399
|
|
|
$full_sync_status = $this->full_sync->get_status(); |
|
|
|
|
1400
|
|
|
$this->assertSame( null, $full_sync_status['finished'] ); |
1401
|
|
|
|
1402
|
|
|
$this->sender->do_full_sync(); |
1403
|
|
|
$this->sender->do_full_sync(); // juuuust in case |
1404
|
|
|
$this->sender->do_full_sync(); // juuuust in case - otherwise we use too many bytes for multisite |
1405
|
|
|
|
1406
|
|
|
$full_sync_status = $this->full_sync->get_status(); |
|
|
|
|
1407
|
|
|
|
1408
|
|
|
$should_be_status = array( |
1409
|
|
|
'sent' => array( |
1410
|
|
|
'constants' => 1, |
1411
|
|
|
'functions' => 1, |
1412
|
|
|
'options' => 1, |
1413
|
|
|
'posts' => 2, |
1414
|
|
|
'comments' => 2, |
1415
|
|
|
'themes' => 1, |
1416
|
|
|
'updates' => 1, |
1417
|
|
|
'users' => 1, |
1418
|
|
|
'terms' => 1, |
1419
|
|
|
'term_relationships' => 1, |
1420
|
|
|
'network_options' => 1, |
1421
|
|
|
), |
1422
|
|
|
'queue' => array( |
1423
|
|
|
'constants' => 1, |
1424
|
|
|
'functions' => 1, |
1425
|
|
|
'options' => 1, |
1426
|
|
|
'posts' => 2, |
1427
|
|
|
'comments' => 2, |
1428
|
|
|
'themes' => 1, |
1429
|
|
|
'updates' => 1, |
1430
|
|
|
'users' => 1, |
1431
|
|
|
'terms' => 1, |
1432
|
|
|
'term_relationships' => 1, |
1433
|
|
|
'network_options' => 1, |
1434
|
|
|
), |
1435
|
|
|
'total' => array( |
1436
|
|
|
'constants' => 1, |
1437
|
|
|
'functions' => 1, |
1438
|
|
|
'options' => 1, |
1439
|
|
|
'posts' => 2, |
1440
|
|
|
'comments' => 2, |
1441
|
|
|
'themes' => 1, |
1442
|
|
|
'updates' => 1, |
1443
|
|
|
'users' => 1, |
1444
|
|
|
'terms' => 1, |
1445
|
|
|
'term_relationships' => 1, |
1446
|
|
|
'network_options' => 1, |
1447
|
|
|
) |
1448
|
|
|
); |
1449
|
|
|
|
1450
|
|
|
$this->assertEquals( $full_sync_status['queue'], $should_be_status['queue'] ); |
1451
|
|
|
$this->assertEquals( $full_sync_status['sent'], $should_be_status['sent'] ); |
1452
|
|
|
$this->assertEquals( $full_sync_status['total'], $should_be_status['total'] ); |
1453
|
|
|
$this->assertInternalType( 'int', $full_sync_status['started'], 'Started is not an integer' ); |
1454
|
|
|
$this->assertInternalType( 'int', $full_sync_status['queue_finished'], 'Queue finished is not an integer' ); |
1455
|
|
|
$this->assertInternalType( 'int', $full_sync_status['send_started'], 'Send started is not an integer' ); |
1456
|
|
|
$this->assertInternalType( 'int', $full_sync_status['finished'], 'Finished is not an integer' ); |
1457
|
|
|
|
1458
|
|
|
// Reset all the defaults |
1459
|
|
|
$this->setSyncClientDefaults(); |
1460
|
|
|
} |
1461
|
|
|
|
1462
|
|
|
function test_sync_modules_can_estimate_total_actions() { |
1463
|
|
|
|
1464
|
|
|
// make some stuff |
1465
|
|
|
foreach( range( 0, 25 ) as $number ) { |
1466
|
|
|
$post_id = $this->factory->post->create(); |
1467
|
|
|
$this->factory->user->create(); |
1468
|
|
|
$this->factory->comment->create_post_comments( $post_id, 2 ); |
1469
|
|
|
} |
1470
|
|
|
|
1471
|
|
|
foreach ( Modules::get_modules() as $module ) { |
1472
|
|
|
$module_name = $module->name(); |
|
|
|
|
1473
|
|
|
$estimate = $module->estimate_full_sync_actions( true ); |
|
|
|
|
1474
|
|
|
list( $actual, $state ) = $module->enqueue_full_sync_actions( true, 100, false ); |
|
|
|
|
1475
|
|
|
|
1476
|
|
|
$this->assertSame( $estimate, $actual ); |
1477
|
|
|
} |
1478
|
|
|
} |
1479
|
|
|
|
1480
|
|
View Code Duplication |
function test_sync_call_ables_does_not_modify_globals() { |
1481
|
|
|
global $wp_taxonomies; |
1482
|
|
|
// assert that $wp_taxonomy object stays an array. |
1483
|
|
|
$this->assertTrue( is_array( $wp_taxonomies['category']->rewrite ) ); |
1484
|
|
|
$this->setSyncClientDefaults(); |
1485
|
|
|
$this->full_sync->start(); |
|
|
|
|
1486
|
|
|
$this->sender->do_full_sync(); |
1487
|
|
|
$this->assertTrue( is_array( $wp_taxonomies['category']->rewrite ) ); |
1488
|
|
|
} |
1489
|
|
|
|
1490
|
|
View Code Duplication |
function test_initial_sync_doesnt_sync_subscribers() { |
1491
|
|
|
$this->factory->user->create( array( 'user_login' => 'theauthor', 'role' => 'author' ) ); |
1492
|
|
|
$this->factory->user->create( array( 'user_login' => 'theadmin', 'role' => 'administrator' ) ); |
1493
|
|
|
foreach( range( 1, 10 ) as $i ) { |
1494
|
|
|
$this->factory->user->create( array( 'role' => 'subscriber' ) ); |
1495
|
|
|
} |
1496
|
|
|
$this->full_sync->start(); |
|
|
|
|
1497
|
|
|
$this->sender->do_full_sync(); |
1498
|
|
|
$this->assertEquals( 13, $this->server_replica_storage->user_count() ); |
1499
|
|
|
$this->server_replica_storage->reset(); |
1500
|
|
|
$this->assertEquals( 0, $this->server_replica_storage->user_count() ); |
1501
|
|
|
$user_ids = Modules::get_module( 'users' )->get_initial_sync_user_config(); |
|
|
|
|
1502
|
|
|
$this->assertEquals( 3, count( $user_ids ) ); |
1503
|
|
|
$this->full_sync->start( array( 'users' => 'initial' ) ); |
|
|
|
|
1504
|
|
|
$this->sender->do_full_sync(); |
1505
|
|
|
$this->assertEquals( 3, $this->server_replica_storage->user_count() ); |
1506
|
|
|
// finally, let's make sure that the initial sync method actually invokes our initial sync user config |
1507
|
|
|
Actions::do_initial_sync( '4.2', '4.1' ); |
|
|
|
|
1508
|
|
|
$current_user = wp_get_current_user(); |
1509
|
|
|
|
1510
|
|
|
$expected_sync_config = array( |
1511
|
|
|
'options' => true, |
1512
|
|
|
'functions' => true, |
1513
|
|
|
'constants' => true, |
1514
|
|
|
'users' => array( $current_user->ID ), |
1515
|
|
|
'network_options' => true, |
1516
|
|
|
); |
1517
|
|
|
|
1518
|
|
|
$full_sync_status = $this->full_sync->get_status(); |
|
|
|
|
1519
|
|
|
$this->assertEquals( |
1520
|
|
|
$expected_sync_config, |
1521
|
|
|
$full_sync_status[ 'config' ] |
1522
|
|
|
); |
1523
|
|
|
} |
1524
|
|
|
|
1525
|
|
|
function test_full_sync_enqueues_limited_number_of_items() { |
1526
|
|
|
Settings::update_settings( array( 'max_enqueue_full_sync' => 2 ) ); |
1527
|
|
|
|
1528
|
|
|
global $wpdb; |
1529
|
|
|
|
1530
|
|
|
// enough posts for three queue items |
1531
|
|
|
$synced_post_ids = $this->factory->post->create_many( 25 ); |
|
|
|
|
1532
|
|
|
|
1533
|
|
|
$this->full_sync->start( array( 'posts' => true ) ); |
|
|
|
|
1534
|
|
|
|
1535
|
|
|
// test number of items in full sync queue - should be 4 (= full_sync_start + 2xposts + full_sync_end) |
1536
|
|
|
$this->assertEquals( 3, $this->sender->get_full_sync_queue()->size() ); |
1537
|
|
|
|
1538
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1539
|
|
|
|
1540
|
|
|
$this->assertEquals( 5, $this->sender->get_full_sync_queue()->size() ); |
1541
|
|
|
|
1542
|
|
|
// should not keep adding full_sync_end or other items afterward |
1543
|
|
|
$queue_size = $this->sender->get_full_sync_queue()->size(); |
1544
|
|
|
|
1545
|
|
|
// continuing to enqueue shouldn't add more items |
1546
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1547
|
|
|
$this->assertEquals( $queue_size, $this->sender->get_full_sync_queue()->size() ); |
1548
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1549
|
|
|
$this->assertEquals( $queue_size, $this->sender->get_full_sync_queue()->size() ); |
1550
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1551
|
|
|
$this->assertEquals( $queue_size, $this->sender->get_full_sync_queue()->size() ); |
1552
|
|
|
} |
1553
|
|
|
|
1554
|
|
|
function test_full_sync_continue_does_nothing_if_no_sync_started() { |
1555
|
|
|
$full_sync_queue_size_before = $this->sender->get_full_sync_queue()->size(); |
1556
|
|
|
|
1557
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1558
|
|
|
|
1559
|
|
|
$this->assertEquals( $full_sync_queue_size_before, $this->sender->get_full_sync_queue()->size() ); |
1560
|
|
|
} |
1561
|
|
|
|
1562
|
|
|
function test_full_sync_stops_enqueuing_at_max_queue_size() { |
1563
|
|
|
Settings::update_settings( array( 'max_queue_size_full_sync' => 2, 'max_enqueue_full_sync' => 10 ) ); |
1564
|
|
|
|
1565
|
|
|
// this should become three items |
1566
|
|
|
$synced_post_ids = $this->factory->post->create_many( 25 ); |
|
|
|
|
1567
|
|
|
|
1568
|
|
|
$this->full_sync->start( array( 'posts' => true ) ); |
|
|
|
|
1569
|
|
|
|
1570
|
|
|
// full_sync_start plus 10 posts |
1571
|
|
|
$this->assertEquals( 2, $this->sender->get_full_sync_queue()->size() ); |
1572
|
|
|
|
1573
|
|
|
// attempting to continue enqueuing shouldn't work because the queue is at max size |
1574
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1575
|
|
|
$this->assertEquals( 2, $this->sender->get_full_sync_queue()->size() ); |
1576
|
|
|
|
1577
|
|
|
// flush the queue |
1578
|
|
|
$this->sender->do_full_sync(); |
1579
|
|
|
|
1580
|
|
|
$this->assertEquals( 0, $this->sender->get_full_sync_queue()->size() ); |
1581
|
|
|
|
1582
|
|
|
// continue enqueuing and hit the limit again - 2 more sets of posts (10 and 5) |
1583
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1584
|
|
|
$this->assertEquals( 2, $this->sender->get_full_sync_queue()->size() ); |
1585
|
|
|
|
1586
|
|
|
$this->sender->do_full_sync(); |
1587
|
|
|
|
1588
|
|
|
// last one - this time just sending full_sync_end |
1589
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1590
|
|
|
$this->assertEquals( 1, $this->sender->get_full_sync_queue()->size() ); |
1591
|
|
|
|
1592
|
|
|
$this->sender->do_full_sync(); |
1593
|
|
|
|
1594
|
|
|
// full sync is done, continuing should do nothing |
1595
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1596
|
|
|
$this->assertEquals( 0, $this->sender->get_full_sync_queue()->size() ); |
1597
|
|
|
} |
1598
|
|
|
|
1599
|
|
|
function test_full_sync_sends_previous_interval_end_on_posts() { |
1600
|
|
|
Settings::update_settings( array( 'max_queue_size_full_sync' => 1, 'max_enqueue_full_sync' => 10 ) ); |
1601
|
|
|
|
1602
|
|
|
$this->factory->post->create_many( 25 ); |
1603
|
|
|
|
1604
|
|
|
// The first event is for full sync start. |
1605
|
|
|
$this->full_sync->start( array( 'posts' => true ) ); |
|
|
|
|
1606
|
|
|
$this->sender->do_full_sync(); |
1607
|
|
|
|
1608
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1609
|
|
|
$this->sender->do_full_sync(); |
1610
|
|
|
|
1611
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_posts' ); |
1612
|
|
|
list( $posts, $meta, $taxonomy, $previous_interval_end ) = $event->args; |
|
|
|
|
1613
|
|
|
|
1614
|
|
|
// The first batch has the previous_min_is not set. |
1615
|
|
|
// We user ~0 to denote that the previous min id unknown. |
1616
|
|
|
$this->assertEquals( $previous_interval_end, '~0' ); |
1617
|
|
|
|
1618
|
|
|
// Since posts are order by id and the ids are in decending order |
1619
|
|
|
// the very last post should be the id with the smallest ID. ( previous_interval_end ) |
1620
|
|
|
$last_post = end( $posts ); |
1621
|
|
|
|
1622
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1623
|
|
|
$this->sender->do_full_sync(); |
1624
|
|
|
|
1625
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_posts' ); |
1626
|
|
|
list( $second_batch_posts, $meta, $taxonomy, $previous_interval_end ) = $event->args; |
|
|
|
|
1627
|
|
|
$this->assertEquals( (int) $previous_interval_end, $last_post->ID ); |
1628
|
|
|
|
1629
|
|
|
$last_post = end( $second_batch_posts ); |
1630
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1631
|
|
|
$this->sender->do_full_sync(); |
1632
|
|
|
|
1633
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_posts' ); |
1634
|
|
|
list( $third_batch_posts, $meta, $taxonomy, $previous_interval_end ) = $event->args; |
|
|
|
|
1635
|
|
|
$this->assertEquals( (int) $previous_interval_end, $last_post->ID ); |
1636
|
|
|
|
1637
|
|
|
$this->full_sync->reset_data(); |
1638
|
|
|
} |
1639
|
|
|
|
1640
|
|
|
function test_full_sync_sends_previous_interval_end_on_comments() { |
1641
|
|
|
Settings::update_settings( array( 'max_queue_size_full_sync' => 1, 'max_enqueue_full_sync' => 10 ) ); |
1642
|
|
|
$this->post_id = $this->factory->post->create(); |
1643
|
|
|
for( $i = 0; $i < 25; $i++ ) { |
1644
|
|
|
$this->factory->comment->create_post_comments( $this->post_id ); |
1645
|
|
|
} |
1646
|
|
|
// The first event is for full sync start. |
1647
|
|
|
$this->full_sync->start( array( 'comments' => true ) ); |
|
|
|
|
1648
|
|
|
$this->sender->do_full_sync(); |
1649
|
|
|
|
1650
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1651
|
|
|
$this->sender->do_full_sync(); |
1652
|
|
|
|
1653
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_comments' ); |
1654
|
|
|
list( $comments, $meta, $previous_interval_end ) = $event->args; |
|
|
|
|
1655
|
|
|
$last_comment = end( $comments ); |
1656
|
|
|
|
1657
|
|
|
// The first batch has the previous_min_is not set. |
1658
|
|
|
// We user ~0 to denote that the previous min id unknown. |
1659
|
|
|
$this->assertEquals( $previous_interval_end, '~0' ); |
1660
|
|
|
|
1661
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1662
|
|
|
$this->sender->do_full_sync(); |
1663
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_comments' ); |
1664
|
|
|
list( $comments, $meta, $previous_interval_end ) = $event->args; |
|
|
|
|
1665
|
|
|
$this->assertEquals( $previous_interval_end, $last_comment->comment_ID ); |
1666
|
|
|
$last_comment = end( $comments ); |
1667
|
|
|
|
1668
|
|
|
$this->full_sync->continue_enqueuing(); |
|
|
|
|
1669
|
|
|
$this->sender->do_full_sync(); |
1670
|
|
|
$event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_comments' ); |
1671
|
|
|
list( $comments, $meta, $previous_interval_end ) = $event->args; |
|
|
|
|
1672
|
|
|
$this->assertEquals( $previous_interval_end, $last_comment->comment_ID ); |
1673
|
|
|
|
1674
|
|
|
$this->full_sync->reset_data(); |
1675
|
|
|
} |
1676
|
|
|
|
1677
|
|
View Code Duplication |
function test_disable_sending_full_sync() { |
1678
|
|
|
$this->factory->post->create_many( 2 ); |
1679
|
|
|
|
1680
|
|
|
$this->sender->reset_data(); |
1681
|
|
|
$this->server_event_storage->reset(); |
1682
|
|
|
|
1683
|
|
|
Settings::update_settings( array( 'full_sync_sender_enabled' => 0 ) ); |
1684
|
|
|
|
1685
|
|
|
$this->full_sync->start(); |
|
|
|
|
1686
|
|
|
$this->sender->do_full_sync(); |
1687
|
|
|
|
1688
|
|
|
$start_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_start' ); |
1689
|
|
|
$this->assertTrue( ! $start_event ); |
1690
|
|
|
} |
1691
|
|
|
|
1692
|
|
View Code Duplication |
function test_enable_sending_full_sync() { |
1693
|
|
|
$this->factory->post->create_many( 2 ); |
1694
|
|
|
|
1695
|
|
|
$this->sender->reset_data(); |
1696
|
|
|
$this->server_event_storage->reset(); |
1697
|
|
|
|
1698
|
|
|
Settings::update_settings( array( 'full_sync_sender_enabled' => 1 ) ); |
1699
|
|
|
|
1700
|
|
|
$this->full_sync->start(); |
|
|
|
|
1701
|
|
|
$this->sender->do_full_sync(); |
1702
|
|
|
|
1703
|
|
|
$start_event = $this->server_event_storage->get_most_recent_event( 'jetpack_full_sync_start' ); |
1704
|
|
|
$this->assertTrue( ! empty( $start_event ) ); |
1705
|
|
|
} |
1706
|
|
|
|
1707
|
|
|
function _do_cron() { |
1708
|
|
|
$_GET['check'] = wp_hash( '187425' ); |
1709
|
|
|
require( ABSPATH . '/wp-cron.php' ); |
1710
|
|
|
} |
1711
|
|
|
} |
1712
|
|
|
|
Let’s take a look at an example:
In the above example, the authenticate() method works fine as long as you just pass instances of MyUser. However, if you now also want to pass a different sub-classes of User which does not have a getDisplayName() method, the code will break.
Available Fixes
Change the type-hint for the parameter:
Add an additional type-check:
Add the method to the parent class: