Skip to content

Commit e7e4143

Browse files
committed
feat(PubSub): Add OptimisticSubscribe sample
1 parent ff3d936 commit e7e4143

File tree

2 files changed

+104
-0
lines changed

2 files changed

+104
-0
lines changed
Lines changed: 66 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
<?php
2+
3+
/**
4+
* Copyright 2025 Google LLC.
5+
*
6+
* Licensed under the Apache License, Version 2.0 (the "License");
7+
* you may not use this file except in compliance with the License.
8+
* You may obtain a copy of the License at
9+
*
10+
* http://www.apache.org/licenses/LICENSE-2.0
11+
*
12+
* Unless required by applicable law or agreed to in writing, software
13+
* distributed under the License is distributed on an "AS IS" BASIS,
14+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15+
* See the License for the specific language governing permissions and
16+
* limitations under the License.
17+
*/
18+
19+
/**
20+
* For instructions on how to run the full sample:
21+
*
22+
* @see https://github.com/GoogleCloudPlatform/php-docs-samples/blob/main/pubsub/api/README.md
23+
*/
24+
25+
namespace Google\Cloud\Samples\PubSub;
26+
27+
# [START pubsub_optimistic_subscribe]
28+
use Google\Cloud\Core\Exception\NotFoundException;
29+
use Google\Cloud\PubSub\PubSubClient;
30+
31+
/**
32+
* Optimistically subscribes to a topic
33+
*
34+
* @param string $projectId The Google project ID.
35+
* @param string $topicName The Pub/Sub topic name.
36+
* @param string $subscriptionId The ID of the subscription.
37+
*/
38+
function optimistic_subscribe(
39+
string $projectId,
40+
string $topicName,
41+
string $subscriptionId
42+
): void {
43+
44+
$pubsub = new PubSubClient([
45+
'projectId' => $projectId,
46+
]);
47+
48+
$subscription = $pubsub->subscription($subscriptionId);
49+
50+
try {
51+
$messages = $subscription->pull();
52+
foreach ($messages as $message) {
53+
printf('PubSub Message: %s' . PHP_EOL, $message->data());
54+
$subscription->acknowledge($message);
55+
}
56+
} catch (NotFoundException $e) { // Subscription is not found
57+
printf('Exception Message: %s' . PHP_EOL, $e->getMessage());
58+
printf('StackTrace: %s' . PHP_EOL, $e->getTraceAsString());
59+
// Create subscription and retry the pull. Any messages published before subscription creation would not be received.
60+
$pubsub->subscribe($subscriptionId, $topicName);
61+
optimistic_subscribe($projectId, $topicName, $subscriptionId);
62+
}
63+
}
64+
# [END pubsub_optimistic_subscribe]
65+
require_once __DIR__ . '/../../../testing/sample_helpers.php';
66+
\Google\Cloud\Samples\execute_sample(__FILE__, __NAMESPACE__, $argv);

pubsub/api/test/pubsubTest.php

Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -487,4 +487,42 @@ public function testPublishAndSubscribeWithOrderingKeys()
487487
$this->assertMatchesRegularExpression('/Created subscription with ordering/', $output);
488488
$this->assertMatchesRegularExpression('/\"enableMessageOrdering\":true/', $output);
489489
}
490+
491+
public function testOptimisticSubscribe()
492+
{
493+
$topic = $this->requireEnv('GOOGLE_PUBSUB_TOPIC');
494+
$subcriptionId = 'test-subscription-' . rand();
495+
496+
$output = $this->runFunctionSnippet('optimistic_subscribe', [
497+
self::$projectId,
498+
$topic,
499+
$subcriptionId
500+
]);
501+
$this->assertMatchesRegularExpression('/Exception Message/', $output);
502+
$this->assertMatchesRegularExpression(sprintf('/Resource not found \(resource=%s\)/', $subcriptionId), $output);
503+
504+
$testMessage = 'This is a test message';
505+
$output = $this->runFunctionSnippet('publish_message', [
506+
self::$projectId,
507+
$topic,
508+
$testMessage,
509+
]);
510+
$this->assertMatchesRegularExpression('/Message published/', $output);
511+
$output = $this->runFunctionSnippet('optimistic_subscribe', [
512+
self::$projectId,
513+
$topic,
514+
$subcriptionId
515+
]);
516+
$this->assertMatchesRegularExpression(sprintf('/PubSub Message: %s/', $testMessage), $output);
517+
$this->assertDoesNotMatchRegularExpression('/Exception Message/', $output);
518+
$this->assertDoesNotMatchRegularExpression(sprintf('/Resource not found \(resource=%s\)/', $subcriptionId), $output);
519+
520+
// Delete subscription
521+
$output = $this->runFunctionSnippet('delete_subscription', [
522+
self::$projectId,
523+
$subcriptionId,
524+
]);
525+
$this->assertMatchesRegularExpression('/Subscription deleted:/', $output);
526+
$this->assertMatchesRegularExpression(sprintf('/%s/', $subcriptionId), $output);
527+
}
490528
}

0 commit comments

Comments
 (0)