diff --git a/TextToSpeech/metadata/V1/CloudTts.php b/TextToSpeech/metadata/V1/CloudTts.php
index 6d6a89bd7987..c932aa5ff159 100644
Binary files a/TextToSpeech/metadata/V1/CloudTts.php and b/TextToSpeech/metadata/V1/CloudTts.php differ
diff --git a/TextToSpeech/owlbot.py b/TextToSpeech/owlbot.py
index 6f26c8b7db49..6e99b3c79ca5 100644
--- a/TextToSpeech/owlbot.py
+++ b/TextToSpeech/owlbot.py
@@ -1,4 +1,4 @@
-# Copyright 2018 Google LLC
+# Copyright 2024 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
@@ -32,31 +32,14 @@
php.owlbot_main(src=src, dest=dest)
-### [START] protoc backwards compatibility fixes
-
-# roll back to private properties.
-s.replace(
- "src/**/V*/**/*.php",
- r"Generated from protobuf field ([^\n]{0,})\n\s{5}\*/\n\s{4}protected \$",
- r"""Generated from protobuf field \1
- */
- private $""")
-
-# Replace "Unwrapped" with "Value" for method names.
-s.replace(
- "src/**/V*/**/*.php",
- r"public function ([s|g]\w{3,})Unwrapped",
- r"public function \1Value"
-)
-
-### [END] protoc backwards compatibility fixes
-
-# fix relative cloud.google.com links
+# remove class_alias code
s.replace(
- "src/**/V*/**/*.php",
- r"(.{0,})\]\((/.{0,})\)",
- r"\1](https://cloud.google.com\2)"
-)
+ "src/V*/**/*.php",
+ r"^// Adding a class alias for backwards compatibility with the previous class name.$"
+ + "\n"
+ + r"^class_alias\(.*\);$"
+ + "\n",
+ '')
# format generated clients
subprocess.run([
@@ -66,8 +49,8 @@
'--package=@prettier/plugin-php@^0.16',
'--',
'prettier',
- '**/Gapic/*',
+ '**/Client/*',
'--write',
'--parser=php',
'--single-quote',
- '--print-width=80'])
+ '--print-width=120'])
diff --git a/TextToSpeech/src/V1/AdvancedVoiceOptions.php b/TextToSpeech/src/V1/AdvancedVoiceOptions.php
index ed664e1ba685..2222ba2fcb32 100644
--- a/TextToSpeech/src/V1/AdvancedVoiceOptions.php
+++ b/TextToSpeech/src/V1/AdvancedVoiceOptions.php
@@ -21,7 +21,7 @@ class AdvancedVoiceOptions extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field optional bool low_latency_journey_synthesis = 1;
*/
- private $low_latency_journey_synthesis = null;
+ protected $low_latency_journey_synthesis = null;
/**
* Constructor.
diff --git a/TextToSpeech/src/V1/AudioConfig.php b/TextToSpeech/src/V1/AudioConfig.php
index 49a0532fadb7..7d299d36de5a 100644
--- a/TextToSpeech/src/V1/AudioConfig.php
+++ b/TextToSpeech/src/V1/AudioConfig.php
@@ -20,7 +20,7 @@ class AudioConfig extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field .google.cloud.texttospeech.v1.AudioEncoding audio_encoding = 1 [(.google.api.field_behavior) = REQUIRED];
*/
- private $audio_encoding = 0;
+ protected $audio_encoding = 0;
/**
* Optional. Input only. Speaking rate/speed, in the range [0.25, 4.0]. 1.0 is
* the normal native speed supported by the specific voice. 2.0 is twice as
@@ -29,7 +29,7 @@ class AudioConfig extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field double speaking_rate = 2 [(.google.api.field_behavior) = INPUT_ONLY, (.google.api.field_behavior) = OPTIONAL];
*/
- private $speaking_rate = 0.0;
+ protected $speaking_rate = 0.0;
/**
* Optional. Input only. Speaking pitch, in the range [-20.0, 20.0]. 20 means
* increase 20 semitones from the original pitch. -20 means decrease 20
@@ -37,7 +37,7 @@ class AudioConfig extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field double pitch = 3 [(.google.api.field_behavior) = INPUT_ONLY, (.google.api.field_behavior) = OPTIONAL];
*/
- private $pitch = 0.0;
+ protected $pitch = 0.0;
/**
* Optional. Input only. Volume gain (in dB) of the normal native volume
* supported by the specific voice, in the range [-96.0, 16.0]. If unset, or
@@ -50,7 +50,7 @@ class AudioConfig extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field double volume_gain_db = 4 [(.google.api.field_behavior) = INPUT_ONLY, (.google.api.field_behavior) = OPTIONAL];
*/
- private $volume_gain_db = 0.0;
+ protected $volume_gain_db = 0.0;
/**
* Optional. The synthesis sample rate (in hertz) for this audio. When this is
* specified in SynthesizeSpeechRequest, if this is different from the voice's
@@ -62,7 +62,7 @@ class AudioConfig extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field int32 sample_rate_hertz = 5 [(.google.api.field_behavior) = OPTIONAL];
*/
- private $sample_rate_hertz = 0;
+ protected $sample_rate_hertz = 0;
/**
* Optional. Input only. An identifier which selects 'audio effects' profiles
* that are applied on (post synthesized) text to speech. Effects are applied
diff --git a/TextToSpeech/src/V1/AudioEncoding.php b/TextToSpeech/src/V1/AudioEncoding.php
index 1a3ee8800a95..91b47bf3262c 100644
--- a/TextToSpeech/src/V1/AudioEncoding.php
+++ b/TextToSpeech/src/V1/AudioEncoding.php
@@ -57,6 +57,14 @@ class AudioEncoding
* Generated from protobuf enum ALAW = 6;
*/
const ALAW = 6;
+ /**
+ * Uncompressed 16-bit signed little-endian samples (Linear PCM).
+ * Note that as opposed to LINEAR16, audio will not be wrapped in a WAV (or
+ * any other) header.
+ *
+ * Generated from protobuf enum PCM = 7;
+ */
+ const PCM = 7;
private static $valueToName = [
self::AUDIO_ENCODING_UNSPECIFIED => 'AUDIO_ENCODING_UNSPECIFIED',
@@ -65,6 +73,7 @@ class AudioEncoding
self::OGG_OPUS => 'OGG_OPUS',
self::MULAW => 'MULAW',
self::ALAW => 'ALAW',
+ self::PCM => 'PCM',
];
public static function name($value)
diff --git a/TextToSpeech/src/V1/Client/TextToSpeechClient.php b/TextToSpeech/src/V1/Client/TextToSpeechClient.php
index 1aec1f39ea80..baae2598e59c 100644
--- a/TextToSpeech/src/V1/Client/TextToSpeechClient.php
+++ b/TextToSpeech/src/V1/Client/TextToSpeechClient.php
@@ -1,6 +1,6 @@
startApiCall('SynthesizeSpeech', $request, $callOptions)->wait();
}
}
diff --git a/TextToSpeech/src/V1/Client/TextToSpeechLongAudioSynthesizeClient.php b/TextToSpeech/src/V1/Client/TextToSpeechLongAudioSynthesizeClient.php
index 63caccb8fcb3..c2363d5dcdae 100644
--- a/TextToSpeech/src/V1/Client/TextToSpeechLongAudioSynthesizeClient.php
+++ b/TextToSpeech/src/V1/Client/TextToSpeechLongAudioSynthesizeClient.php
@@ -1,6 +1,6 @@
self::SERVICE_NAME,
'apiEndpoint' => self::SERVICE_ADDRESS . ':' . self::DEFAULT_SERVICE_PORT,
'clientConfig' => __DIR__ . '/../resources/text_to_speech_long_audio_synthesize_client_config.json',
- 'descriptorsConfigPath' => __DIR__ . '/../resources/text_to_speech_long_audio_synthesize_descriptor_config.php',
+ 'descriptorsConfigPath' =>
+ __DIR__ . '/../resources/text_to_speech_long_audio_synthesize_descriptor_config.php',
'gcpApiConfigPath' => __DIR__ . '/../resources/text_to_speech_long_audio_synthesize_grpc_config.json',
'credentialsConfig' => [
'defaultScopes' => self::$serviceScopes,
],
'transportConfig' => [
'rest' => [
- 'restClientConfigPath' => __DIR__ . '/../resources/text_to_speech_long_audio_synthesize_rest_client_config.php',
+ 'restClientConfigPath' =>
+ __DIR__ . '/../resources/text_to_speech_long_audio_synthesize_rest_client_config.php',
],
],
];
@@ -125,12 +125,33 @@ public function getOperationsClient()
*/
public function resumeOperation($operationName, $methodName = null)
{
- $options = isset($this->descriptors[$methodName]['longRunning']) ? $this->descriptors[$methodName]['longRunning'] : [];
+ $options = isset($this->descriptors[$methodName]['longRunning'])
+ ? $this->descriptors[$methodName]['longRunning']
+ : [];
$operation = new OperationResponse($operationName, $this->getOperationsClient(), $options);
$operation->reload();
return $operation;
}
+ /**
+ * Create the default operation client for the service.
+ *
+ * @param array $options ClientOptions for the client.
+ *
+ * @return OperationsClient
+ */
+ private function createOperationsClient(array $options)
+ {
+ // Unset client-specific configuration options
+ unset($options['serviceName'], $options['clientConfig'], $options['descriptorsConfigPath']);
+
+ if (isset($options['operationsClient'])) {
+ return $options['operationsClient'];
+ }
+
+ return new OperationsClient($options);
+ }
+
/**
* Formats a string containing the fully-qualified path to represent a model
* resource.
diff --git a/TextToSpeech/src/V1/CustomPronunciationParams.php b/TextToSpeech/src/V1/CustomPronunciationParams.php
index b7ae33a3dadf..2a2283ce0dea 100644
--- a/TextToSpeech/src/V1/CustomPronunciationParams.php
+++ b/TextToSpeech/src/V1/CustomPronunciationParams.php
@@ -22,20 +22,20 @@ class CustomPronunciationParams extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field optional string phrase = 1;
*/
- private $phrase = null;
+ protected $phrase = null;
/**
* The phonetic encoding of the phrase.
*
* Generated from protobuf field optional .google.cloud.texttospeech.v1.CustomPronunciationParams.PhoneticEncoding phonetic_encoding = 2;
*/
- private $phonetic_encoding = null;
+ protected $phonetic_encoding = null;
/**
* The pronunciation of the phrase. This must be in the phonetic encoding
* specified above.
*
* Generated from protobuf field optional string pronunciation = 3;
*/
- private $pronunciation = null;
+ protected $pronunciation = null;
/**
* Constructor.
diff --git a/TextToSpeech/src/V1/CustomPronunciationParams/PhoneticEncoding.php b/TextToSpeech/src/V1/CustomPronunciationParams/PhoneticEncoding.php
index d7631a1efee4..c75a17431f2a 100644
--- a/TextToSpeech/src/V1/CustomPronunciationParams/PhoneticEncoding.php
+++ b/TextToSpeech/src/V1/CustomPronunciationParams/PhoneticEncoding.php
@@ -61,6 +61,4 @@ public static function value($name)
}
}
-// Adding a class alias for backwards compatibility with the previous class name.
-class_alias(PhoneticEncoding::class, \Google\Cloud\TextToSpeech\V1\CustomPronunciationParams_PhoneticEncoding::class);
diff --git a/TextToSpeech/src/V1/CustomVoiceParams.php b/TextToSpeech/src/V1/CustomVoiceParams.php
index 175f22bed38e..bc208aa890c7 100644
--- a/TextToSpeech/src/V1/CustomVoiceParams.php
+++ b/TextToSpeech/src/V1/CustomVoiceParams.php
@@ -20,7 +20,7 @@ class CustomVoiceParams extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field string model = 1 [(.google.api.field_behavior) = REQUIRED, (.google.api.resource_reference) = {
*/
- private $model = '';
+ protected $model = '';
/**
* Optional. Deprecated. The usage of the synthesized audio to be reported.
*
diff --git a/TextToSpeech/src/V1/CustomVoiceParams/ReportedUsage.php b/TextToSpeech/src/V1/CustomVoiceParams/ReportedUsage.php
index 6e8d93d63f04..253853aa0e70 100644
--- a/TextToSpeech/src/V1/CustomVoiceParams/ReportedUsage.php
+++ b/TextToSpeech/src/V1/CustomVoiceParams/ReportedUsage.php
@@ -63,6 +63,4 @@ public static function value($name)
}
}
-// Adding a class alias for backwards compatibility with the previous class name.
-class_alias(ReportedUsage::class, \Google\Cloud\TextToSpeech\V1\CustomVoiceParams_ReportedUsage::class);
diff --git a/TextToSpeech/src/V1/CustomVoiceParams_ReportedUsage.php b/TextToSpeech/src/V1/CustomVoiceParams_ReportedUsage.php
deleted file mode 100644
index 85d643cbca1f..000000000000
--- a/TextToSpeech/src/V1/CustomVoiceParams_ReportedUsage.php
+++ /dev/null
@@ -1,16 +0,0 @@
-listVoices();
- * } finally {
- * $textToSpeechClient->close();
- * }
- * ```
- *
- * Many parameters require resource names to be formatted in a particular way. To
- * assist with these names, this class includes a format method for each type of
- * name, and additionally a parseName method to extract the individual identifiers
- * contained within formatted names that are returned by the API.
- *
- * @deprecated Please use the new service client {@see \Google\Cloud\TextToSpeech\V1\Client\TextToSpeechClient}.
- */
-class TextToSpeechGapicClient
-{
- use GapicClientTrait;
-
- /** The name of the service. */
- const SERVICE_NAME = 'google.cloud.texttospeech.v1.TextToSpeech';
-
- /**
- * The default address of the service.
- *
- * @deprecated SERVICE_ADDRESS_TEMPLATE should be used instead.
- */
- const SERVICE_ADDRESS = 'texttospeech.googleapis.com';
-
- /** The address template of the service. */
- private const SERVICE_ADDRESS_TEMPLATE = 'texttospeech.UNIVERSE_DOMAIN';
-
- /** The default port of the service. */
- const DEFAULT_SERVICE_PORT = 443;
-
- /** The name of the code generator, to be included in the agent header. */
- const CODEGEN_NAME = 'gapic';
-
- /** The default scopes required by the service. */
- public static $serviceScopes = [
- 'https://www.googleapis.com/auth/cloud-platform',
- ];
-
- private static $modelNameTemplate;
-
- private static $pathTemplateMap;
-
- private static function getClientDefaults()
- {
- return [
- 'serviceName' => self::SERVICE_NAME,
- 'apiEndpoint' =>
- self::SERVICE_ADDRESS . ':' . self::DEFAULT_SERVICE_PORT,
- 'clientConfig' =>
- __DIR__ . '/../resources/text_to_speech_client_config.json',
- 'descriptorsConfigPath' =>
- __DIR__ . '/../resources/text_to_speech_descriptor_config.php',
- 'gcpApiConfigPath' =>
- __DIR__ . '/../resources/text_to_speech_grpc_config.json',
- 'credentialsConfig' => [
- 'defaultScopes' => self::$serviceScopes,
- ],
- 'transportConfig' => [
- 'rest' => [
- 'restClientConfigPath' =>
- __DIR__ .
- '/../resources/text_to_speech_rest_client_config.php',
- ],
- ],
- ];
- }
-
- private static function getModelNameTemplate()
- {
- if (self::$modelNameTemplate == null) {
- self::$modelNameTemplate = new PathTemplate(
- 'projects/{project}/locations/{location}/models/{model}'
- );
- }
-
- return self::$modelNameTemplate;
- }
-
- private static function getPathTemplateMap()
- {
- if (self::$pathTemplateMap == null) {
- self::$pathTemplateMap = [
- 'model' => self::getModelNameTemplate(),
- ];
- }
-
- return self::$pathTemplateMap;
- }
-
- /**
- * Formats a string containing the fully-qualified path to represent a model
- * resource.
- *
- * @param string $project
- * @param string $location
- * @param string $model
- *
- * @return string The formatted model resource.
- */
- public static function modelName($project, $location, $model)
- {
- return self::getModelNameTemplate()->render([
- 'project' => $project,
- 'location' => $location,
- 'model' => $model,
- ]);
- }
-
- /**
- * Parses a formatted name string and returns an associative array of the components in the name.
- * The following name formats are supported:
- * Template: Pattern
- * - model: projects/{project}/locations/{location}/models/{model}
- *
- * The optional $template argument can be supplied to specify a particular pattern,
- * and must match one of the templates listed above. If no $template argument is
- * provided, or if the $template argument does not match one of the templates
- * listed, then parseName will check each of the supported templates, and return
- * the first match.
- *
- * @param string $formattedName The formatted name string
- * @param string $template Optional name of template to match
- *
- * @return array An associative array from name component IDs to component values.
- *
- * @throws ValidationException If $formattedName could not be matched.
- */
- public static function parseName($formattedName, $template = null)
- {
- $templateMap = self::getPathTemplateMap();
- if ($template) {
- if (!isset($templateMap[$template])) {
- throw new ValidationException(
- "Template name $template does not exist"
- );
- }
-
- return $templateMap[$template]->match($formattedName);
- }
-
- foreach ($templateMap as $templateName => $pathTemplate) {
- try {
- return $pathTemplate->match($formattedName);
- } catch (ValidationException $ex) {
- // Swallow the exception to continue trying other path templates
- }
- }
-
- throw new ValidationException(
- "Input did not match any known format. Input: $formattedName"
- );
- }
-
- /**
- * Constructor.
- *
- * @param array $options {
- * Optional. Options for configuring the service API wrapper.
- *
- * @type string $apiEndpoint
- * The address of the API remote host. May optionally include the port, formatted
- * as ":". Default 'texttospeech.googleapis.com:443'.
- * @type string|array|FetchAuthTokenInterface|CredentialsWrapper $credentials
- * The credentials to be used by the client to authorize API calls. This option
- * accepts either a path to a credentials file, or a decoded credentials file as a
- * PHP array.
- * *Advanced usage*: In addition, this option can also accept a pre-constructed
- * {@see \Google\Auth\FetchAuthTokenInterface} object or
- * {@see \Google\ApiCore\CredentialsWrapper} object. Note that when one of these
- * objects are provided, any settings in $credentialsConfig will be ignored.
- * @type array $credentialsConfig
- * Options used to configure credentials, including auth token caching, for the
- * client. For a full list of supporting configuration options, see
- * {@see \Google\ApiCore\CredentialsWrapper::build()} .
- * @type bool $disableRetries
- * Determines whether or not retries defined by the client configuration should be
- * disabled. Defaults to `false`.
- * @type string|array $clientConfig
- * Client method configuration, including retry settings. This option can be either
- * a path to a JSON file, or a PHP array containing the decoded JSON data. By
- * default this settings points to the default client config file, which is
- * provided in the resources folder.
- * @type string|TransportInterface $transport
- * The transport used for executing network requests. May be either the string
- * `rest` or `grpc`. Defaults to `grpc` if gRPC support is detected on the system.
- * *Advanced usage*: Additionally, it is possible to pass in an already
- * instantiated {@see \Google\ApiCore\Transport\TransportInterface} object. Note
- * that when this object is provided, any settings in $transportConfig, and any
- * $apiEndpoint setting, will be ignored.
- * @type array $transportConfig
- * Configuration options that will be used to construct the transport. Options for
- * each supported transport type should be passed in a key for that transport. For
- * example:
- * $transportConfig = [
- * 'grpc' => [...],
- * 'rest' => [...],
- * ];
- * See the {@see \Google\ApiCore\Transport\GrpcTransport::build()} and
- * {@see \Google\ApiCore\Transport\RestTransport::build()} methods for the
- * supported options.
- * @type callable $clientCertSource
- * A callable which returns the client cert as a string. This can be used to
- * provide a certificate and private key to the transport layer for mTLS.
- * }
- *
- * @throws ValidationException
- */
- public function __construct(array $options = [])
- {
- $clientOptions = $this->buildClientOptions($options);
- $this->setClientOptions($clientOptions);
- }
-
- /**
- * Returns a list of Voice supported for synthesis.
- *
- * Sample code:
- * ```
- * $textToSpeechClient = new TextToSpeechClient();
- * try {
- * $response = $textToSpeechClient->listVoices();
- * } finally {
- * $textToSpeechClient->close();
- * }
- * ```
- *
- * @param array $optionalArgs {
- * Optional.
- *
- * @type string $languageCode
- * Optional. Recommended.
- * [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language tag.
- * If not specified, the API will return all supported voices.
- * If specified, the ListVoices call will only return voices that can be used
- * to synthesize this language_code. For example, if you specify `"en-NZ"`,
- * all `"en-NZ"` voices will be returned. If you specify `"no"`, both
- * `"no-\*"` (Norwegian) and `"nb-\*"` (Norwegian Bokmal) voices will be
- * returned.
- * @type RetrySettings|array $retrySettings
- * Retry settings to use for this call. Can be a {@see RetrySettings} object, or an
- * associative array of retry settings parameters. See the documentation on
- * {@see RetrySettings} for example usage.
- * }
- *
- * @return \Google\Cloud\TextToSpeech\V1\ListVoicesResponse
- *
- * @throws ApiException if the remote call fails
- */
- public function listVoices(array $optionalArgs = [])
- {
- $request = new ListVoicesRequest();
- if (isset($optionalArgs['languageCode'])) {
- $request->setLanguageCode($optionalArgs['languageCode']);
- }
-
- return $this->startCall(
- 'ListVoices',
- ListVoicesResponse::class,
- $optionalArgs,
- $request
- )->wait();
- }
-
- /**
- * Performs bidirectional streaming speech synthesis: receive audio while
- * sending text.
- *
- * Sample code:
- * ```
- * $textToSpeechClient = new TextToSpeechClient();
- * try {
- * $request = new StreamingSynthesizeRequest();
- * // Write all requests to the server, then read all responses until the
- * // stream is complete
- * $requests = [
- * $request,
- * ];
- * $stream = $textToSpeechClient->streamingSynthesize();
- * $stream->writeAll($requests);
- * foreach ($stream->closeWriteAndReadAll() as $element) {
- * // doSomethingWith($element);
- * }
- * // Alternatively:
- * // Write requests individually, making read() calls if
- * // required. Call closeWrite() once writes are complete, and read the
- * // remaining responses from the server.
- * $requests = [
- * $request,
- * ];
- * $stream = $textToSpeechClient->streamingSynthesize();
- * foreach ($requests as $request) {
- * $stream->write($request);
- * // if required, read a single response from the stream
- * $element = $stream->read();
- * // doSomethingWith($element)
- * }
- * $stream->closeWrite();
- * $element = $stream->read();
- * while (!is_null($element)) {
- * // doSomethingWith($element)
- * $element = $stream->read();
- * }
- * } finally {
- * $textToSpeechClient->close();
- * }
- * ```
- *
- * @param array $optionalArgs {
- * Optional.
- *
- * @type int $timeoutMillis
- * Timeout to use for this call.
- * }
- *
- * @return \Google\ApiCore\BidiStream
- *
- * @throws ApiException if the remote call fails
- */
- public function streamingSynthesize(array $optionalArgs = [])
- {
- return $this->startCall(
- 'StreamingSynthesize',
- StreamingSynthesizeResponse::class,
- $optionalArgs,
- null,
- Call::BIDI_STREAMING_CALL
- );
- }
-
- /**
- * Synthesizes speech synchronously: receive results after all text input
- * has been processed.
- *
- * Sample code:
- * ```
- * $textToSpeechClient = new TextToSpeechClient();
- * try {
- * $input = new SynthesisInput();
- * $voice = new VoiceSelectionParams();
- * $audioConfig = new AudioConfig();
- * $response = $textToSpeechClient->synthesizeSpeech($input, $voice, $audioConfig);
- * } finally {
- * $textToSpeechClient->close();
- * }
- * ```
- *
- * @param SynthesisInput $input Required. The Synthesizer requires either plain text or SSML as input.
- * @param VoiceSelectionParams $voice Required. The desired voice of the synthesized audio.
- * @param AudioConfig $audioConfig Required. The configuration of the synthesized audio.
- * @param array $optionalArgs {
- * Optional.
- *
- * @type AdvancedVoiceOptions $advancedVoiceOptions
- * Advanced voice options.
- * @type RetrySettings|array $retrySettings
- * Retry settings to use for this call. Can be a {@see RetrySettings} object, or an
- * associative array of retry settings parameters. See the documentation on
- * {@see RetrySettings} for example usage.
- * }
- *
- * @return \Google\Cloud\TextToSpeech\V1\SynthesizeSpeechResponse
- *
- * @throws ApiException if the remote call fails
- */
- public function synthesizeSpeech(
- $input,
- $voice,
- $audioConfig,
- array $optionalArgs = []
- ) {
- $request = new SynthesizeSpeechRequest();
- $request->setInput($input);
- $request->setVoice($voice);
- $request->setAudioConfig($audioConfig);
- if (isset($optionalArgs['advancedVoiceOptions'])) {
- $request->setAdvancedVoiceOptions(
- $optionalArgs['advancedVoiceOptions']
- );
- }
-
- return $this->startCall(
- 'SynthesizeSpeech',
- SynthesizeSpeechResponse::class,
- $optionalArgs,
- $request
- )->wait();
- }
-}
diff --git a/TextToSpeech/src/V1/Gapic/TextToSpeechLongAudioSynthesizeGapicClient.php b/TextToSpeech/src/V1/Gapic/TextToSpeechLongAudioSynthesizeGapicClient.php
deleted file mode 100644
index 466a0f5c3406..000000000000
--- a/TextToSpeech/src/V1/Gapic/TextToSpeechLongAudioSynthesizeGapicClient.php
+++ /dev/null
@@ -1,436 +0,0 @@
-synthesizeLongAudio($input, $audioConfig);
- * $operationResponse->pollUntilComplete();
- * if ($operationResponse->operationSucceeded()) {
- * $result = $operationResponse->getResult();
- * // doSomethingWith($result)
- * } else {
- * $error = $operationResponse->getError();
- * // handleError($error)
- * }
- * // Alternatively:
- * // start the operation, keep the operation name, and resume later
- * $operationResponse = $textToSpeechLongAudioSynthesizeClient->synthesizeLongAudio($input, $audioConfig);
- * $operationName = $operationResponse->getName();
- * // ... do other work
- * $newOperationResponse = $textToSpeechLongAudioSynthesizeClient->resumeOperation($operationName, 'synthesizeLongAudio');
- * while (!$newOperationResponse->isDone()) {
- * // ... do other work
- * $newOperationResponse->reload();
- * }
- * if ($newOperationResponse->operationSucceeded()) {
- * $result = $newOperationResponse->getResult();
- * // doSomethingWith($result)
- * } else {
- * $error = $newOperationResponse->getError();
- * // handleError($error)
- * }
- * } finally {
- * $textToSpeechLongAudioSynthesizeClient->close();
- * }
- * ```
- *
- * Many parameters require resource names to be formatted in a particular way. To
- * assist with these names, this class includes a format method for each type of
- * name, and additionally a parseName method to extract the individual identifiers
- * contained within formatted names that are returned by the API.
- *
- * @deprecated Please use the new service client {@see \Google\Cloud\TextToSpeech\V1\Client\TextToSpeechLongAudioSynthesizeClient}.
- */
-class TextToSpeechLongAudioSynthesizeGapicClient
-{
- use GapicClientTrait;
-
- /** The name of the service. */
- const SERVICE_NAME = 'google.cloud.texttospeech.v1.TextToSpeechLongAudioSynthesize';
-
- /**
- * The default address of the service.
- *
- * @deprecated SERVICE_ADDRESS_TEMPLATE should be used instead.
- */
- const SERVICE_ADDRESS = 'texttospeech.googleapis.com';
-
- /** The address template of the service. */
- private const SERVICE_ADDRESS_TEMPLATE = 'texttospeech.UNIVERSE_DOMAIN';
-
- /** The default port of the service. */
- const DEFAULT_SERVICE_PORT = 443;
-
- /** The name of the code generator, to be included in the agent header. */
- const CODEGEN_NAME = 'gapic';
-
- /** The default scopes required by the service. */
- public static $serviceScopes = [
- 'https://www.googleapis.com/auth/cloud-platform',
- ];
-
- private static $modelNameTemplate;
-
- private static $pathTemplateMap;
-
- private $operationsClient;
-
- private static function getClientDefaults()
- {
- return [
- 'serviceName' => self::SERVICE_NAME,
- 'apiEndpoint' =>
- self::SERVICE_ADDRESS . ':' . self::DEFAULT_SERVICE_PORT,
- 'clientConfig' =>
- __DIR__ .
- '/../resources/text_to_speech_long_audio_synthesize_client_config.json',
- 'descriptorsConfigPath' =>
- __DIR__ .
- '/../resources/text_to_speech_long_audio_synthesize_descriptor_config.php',
- 'gcpApiConfigPath' =>
- __DIR__ .
- '/../resources/text_to_speech_long_audio_synthesize_grpc_config.json',
- 'credentialsConfig' => [
- 'defaultScopes' => self::$serviceScopes,
- ],
- 'transportConfig' => [
- 'rest' => [
- 'restClientConfigPath' =>
- __DIR__ .
- '/../resources/text_to_speech_long_audio_synthesize_rest_client_config.php',
- ],
- ],
- ];
- }
-
- private static function getModelNameTemplate()
- {
- if (self::$modelNameTemplate == null) {
- self::$modelNameTemplate = new PathTemplate(
- 'projects/{project}/locations/{location}/models/{model}'
- );
- }
-
- return self::$modelNameTemplate;
- }
-
- private static function getPathTemplateMap()
- {
- if (self::$pathTemplateMap == null) {
- self::$pathTemplateMap = [
- 'model' => self::getModelNameTemplate(),
- ];
- }
-
- return self::$pathTemplateMap;
- }
-
- /**
- * Formats a string containing the fully-qualified path to represent a model
- * resource.
- *
- * @param string $project
- * @param string $location
- * @param string $model
- *
- * @return string The formatted model resource.
- */
- public static function modelName($project, $location, $model)
- {
- return self::getModelNameTemplate()->render([
- 'project' => $project,
- 'location' => $location,
- 'model' => $model,
- ]);
- }
-
- /**
- * Parses a formatted name string and returns an associative array of the components in the name.
- * The following name formats are supported:
- * Template: Pattern
- * - model: projects/{project}/locations/{location}/models/{model}
- *
- * The optional $template argument can be supplied to specify a particular pattern,
- * and must match one of the templates listed above. If no $template argument is
- * provided, or if the $template argument does not match one of the templates
- * listed, then parseName will check each of the supported templates, and return
- * the first match.
- *
- * @param string $formattedName The formatted name string
- * @param string $template Optional name of template to match
- *
- * @return array An associative array from name component IDs to component values.
- *
- * @throws ValidationException If $formattedName could not be matched.
- */
- public static function parseName($formattedName, $template = null)
- {
- $templateMap = self::getPathTemplateMap();
- if ($template) {
- if (!isset($templateMap[$template])) {
- throw new ValidationException(
- "Template name $template does not exist"
- );
- }
-
- return $templateMap[$template]->match($formattedName);
- }
-
- foreach ($templateMap as $templateName => $pathTemplate) {
- try {
- return $pathTemplate->match($formattedName);
- } catch (ValidationException $ex) {
- // Swallow the exception to continue trying other path templates
- }
- }
-
- throw new ValidationException(
- "Input did not match any known format. Input: $formattedName"
- );
- }
-
- /**
- * Return an OperationsClient object with the same endpoint as $this.
- *
- * @return OperationsClient
- */
- public function getOperationsClient()
- {
- return $this->operationsClient;
- }
-
- /**
- * Resume an existing long running operation that was previously started by a long
- * running API method. If $methodName is not provided, or does not match a long
- * running API method, then the operation can still be resumed, but the
- * OperationResponse object will not deserialize the final response.
- *
- * @param string $operationName The name of the long running operation
- * @param string $methodName The name of the method used to start the operation
- *
- * @return OperationResponse
- */
- public function resumeOperation($operationName, $methodName = null)
- {
- $options = isset($this->descriptors[$methodName]['longRunning'])
- ? $this->descriptors[$methodName]['longRunning']
- : [];
- $operation = new OperationResponse(
- $operationName,
- $this->getOperationsClient(),
- $options
- );
- $operation->reload();
- return $operation;
- }
-
- /**
- * Constructor.
- *
- * @param array $options {
- * Optional. Options for configuring the service API wrapper.
- *
- * @type string $apiEndpoint
- * The address of the API remote host. May optionally include the port, formatted
- * as ":". Default 'texttospeech.googleapis.com:443'.
- * @type string|array|FetchAuthTokenInterface|CredentialsWrapper $credentials
- * The credentials to be used by the client to authorize API calls. This option
- * accepts either a path to a credentials file, or a decoded credentials file as a
- * PHP array.
- * *Advanced usage*: In addition, this option can also accept a pre-constructed
- * {@see \Google\Auth\FetchAuthTokenInterface} object or
- * {@see \Google\ApiCore\CredentialsWrapper} object. Note that when one of these
- * objects are provided, any settings in $credentialsConfig will be ignored.
- * @type array $credentialsConfig
- * Options used to configure credentials, including auth token caching, for the
- * client. For a full list of supporting configuration options, see
- * {@see \Google\ApiCore\CredentialsWrapper::build()} .
- * @type bool $disableRetries
- * Determines whether or not retries defined by the client configuration should be
- * disabled. Defaults to `false`.
- * @type string|array $clientConfig
- * Client method configuration, including retry settings. This option can be either
- * a path to a JSON file, or a PHP array containing the decoded JSON data. By
- * default this settings points to the default client config file, which is
- * provided in the resources folder.
- * @type string|TransportInterface $transport
- * The transport used for executing network requests. May be either the string
- * `rest` or `grpc`. Defaults to `grpc` if gRPC support is detected on the system.
- * *Advanced usage*: Additionally, it is possible to pass in an already
- * instantiated {@see \Google\ApiCore\Transport\TransportInterface} object. Note
- * that when this object is provided, any settings in $transportConfig, and any
- * $apiEndpoint setting, will be ignored.
- * @type array $transportConfig
- * Configuration options that will be used to construct the transport. Options for
- * each supported transport type should be passed in a key for that transport. For
- * example:
- * $transportConfig = [
- * 'grpc' => [...],
- * 'rest' => [...],
- * ];
- * See the {@see \Google\ApiCore\Transport\GrpcTransport::build()} and
- * {@see \Google\ApiCore\Transport\RestTransport::build()} methods for the
- * supported options.
- * @type callable $clientCertSource
- * A callable which returns the client cert as a string. This can be used to
- * provide a certificate and private key to the transport layer for mTLS.
- * }
- *
- * @throws ValidationException
- */
- public function __construct(array $options = [])
- {
- $clientOptions = $this->buildClientOptions($options);
- $this->setClientOptions($clientOptions);
- $this->operationsClient = $this->createOperationsClient($clientOptions);
- }
-
- /**
- * Synthesizes long form text asynchronously.
- *
- * Sample code:
- * ```
- * $textToSpeechLongAudioSynthesizeClient = new TextToSpeechLongAudioSynthesizeClient();
- * try {
- * $input = new SynthesisInput();
- * $audioConfig = new AudioConfig();
- * $operationResponse = $textToSpeechLongAudioSynthesizeClient->synthesizeLongAudio($input, $audioConfig);
- * $operationResponse->pollUntilComplete();
- * if ($operationResponse->operationSucceeded()) {
- * $result = $operationResponse->getResult();
- * // doSomethingWith($result)
- * } else {
- * $error = $operationResponse->getError();
- * // handleError($error)
- * }
- * // Alternatively:
- * // start the operation, keep the operation name, and resume later
- * $operationResponse = $textToSpeechLongAudioSynthesizeClient->synthesizeLongAudio($input, $audioConfig);
- * $operationName = $operationResponse->getName();
- * // ... do other work
- * $newOperationResponse = $textToSpeechLongAudioSynthesizeClient->resumeOperation($operationName, 'synthesizeLongAudio');
- * while (!$newOperationResponse->isDone()) {
- * // ... do other work
- * $newOperationResponse->reload();
- * }
- * if ($newOperationResponse->operationSucceeded()) {
- * $result = $newOperationResponse->getResult();
- * // doSomethingWith($result)
- * } else {
- * $error = $newOperationResponse->getError();
- * // handleError($error)
- * }
- * } finally {
- * $textToSpeechLongAudioSynthesizeClient->close();
- * }
- * ```
- *
- * @param SynthesisInput $input Required. The Synthesizer requires either plain text or SSML as input.
- * @param AudioConfig $audioConfig Required. The configuration of the synthesized audio.
- * @param array $optionalArgs {
- * Optional.
- *
- * @type string $parent
- * The resource states of the request in the form of
- * `projects/*/locations/*`.
- * @type string $outputGcsUri
- * Required. Specifies a Cloud Storage URI for the synthesis results. Must be
- * specified in the format: `gs://bucket_name/object_name`, and the bucket
- * must already exist.
- * @type VoiceSelectionParams $voice
- * Required. The desired voice of the synthesized audio.
- * @type RetrySettings|array $retrySettings
- * Retry settings to use for this call. Can be a {@see RetrySettings} object, or an
- * associative array of retry settings parameters. See the documentation on
- * {@see RetrySettings} for example usage.
- * }
- *
- * @return \Google\ApiCore\OperationResponse
- *
- * @throws ApiException if the remote call fails
- */
- public function synthesizeLongAudio(
- $input,
- $audioConfig,
- array $optionalArgs = []
- ) {
- $request = new SynthesizeLongAudioRequest();
- $requestParamHeaders = [];
- $request->setInput($input);
- $request->setAudioConfig($audioConfig);
- if (isset($optionalArgs['parent'])) {
- $request->setParent($optionalArgs['parent']);
- $requestParamHeaders['parent'] = $optionalArgs['parent'];
- }
-
- if (isset($optionalArgs['outputGcsUri'])) {
- $request->setOutputGcsUri($optionalArgs['outputGcsUri']);
- }
-
- if (isset($optionalArgs['voice'])) {
- $request->setVoice($optionalArgs['voice']);
- }
-
- $requestParams = new RequestParamsHeaderDescriptor(
- $requestParamHeaders
- );
- $optionalArgs['headers'] = isset($optionalArgs['headers'])
- ? array_merge($requestParams->getHeader(), $optionalArgs['headers'])
- : $requestParams->getHeader();
- return $this->startOperationsCall(
- 'SynthesizeLongAudio',
- $optionalArgs,
- $request,
- $this->getOperationsClient()
- )->wait();
- }
-}
diff --git a/TextToSpeech/src/V1/ListVoicesRequest.php b/TextToSpeech/src/V1/ListVoicesRequest.php
index 9e798c977161..a1f5971ee7a9 100644
--- a/TextToSpeech/src/V1/ListVoicesRequest.php
+++ b/TextToSpeech/src/V1/ListVoicesRequest.php
@@ -27,7 +27,7 @@ class ListVoicesRequest extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field string language_code = 1 [(.google.api.field_behavior) = OPTIONAL];
*/
- private $language_code = '';
+ protected $language_code = '';
/**
* @param string $languageCode Optional. Recommended.
diff --git a/TextToSpeech/src/V1/MultiSpeakerMarkup/Turn.php b/TextToSpeech/src/V1/MultiSpeakerMarkup/Turn.php
index 380e3001b4ed..98d51e27a86b 100644
--- a/TextToSpeech/src/V1/MultiSpeakerMarkup/Turn.php
+++ b/TextToSpeech/src/V1/MultiSpeakerMarkup/Turn.php
@@ -21,13 +21,13 @@ class Turn extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field string speaker = 1 [(.google.api.field_behavior) = REQUIRED];
*/
- private $speaker = '';
+ protected $speaker = '';
/**
* Required. The text to speak.
*
* Generated from protobuf field string text = 2 [(.google.api.field_behavior) = REQUIRED];
*/
- private $text = '';
+ protected $text = '';
/**
* Constructor.
@@ -103,6 +103,4 @@ public function setText($var)
}
-// Adding a class alias for backwards compatibility with the previous class name.
-class_alias(Turn::class, \Google\Cloud\TextToSpeech\V1\MultiSpeakerMarkup_Turn::class);
diff --git a/TextToSpeech/src/V1/README.md b/TextToSpeech/src/V1/README.md
deleted file mode 100644
index c553df84b19e..000000000000
--- a/TextToSpeech/src/V1/README.md
+++ /dev/null
@@ -1,25 +0,0 @@
-# Google Cloud Text-to-Speech V1 generated client for PHP
-
-### Sample
-
-```php
-require __DIR__ . '/vendor/autoload.php';
-
-use Google\Cloud\TextToSpeech\V1\AudioConfig;
-use Google\Cloud\TextToSpeech\V1\AudioEncoding;
-use Google\Cloud\TextToSpeech\V1\SynthesisInput;
-use Google\Cloud\TextToSpeech\V1\TextToSpeechClient;
-use Google\Cloud\TextToSpeech\V1\VoiceSelectionParams;
-
-$textToSpeechClient = new TextToSpeechClient();
-
-$input = new SynthesisInput();
-$input->setText('Japan\'s national soccer team won against Colombia!');
-$voice = new VoiceSelectionParams();
-$voice->setLanguageCode('en-US');
-$audioConfig = new AudioConfig();
-$audioConfig->setAudioEncoding(AudioEncoding::MP3);
-
-$resp = $textToSpeechClient->synthesizeSpeech($input, $voice, $audioConfig);
-file_put_contents('test.mp3', $resp->getAudioContent());
-```
diff --git a/TextToSpeech/src/V1/StreamingAudioConfig.php b/TextToSpeech/src/V1/StreamingAudioConfig.php
new file mode 100644
index 000000000000..439bd0937035
--- /dev/null
+++ b/TextToSpeech/src/V1/StreamingAudioConfig.php
@@ -0,0 +1,109 @@
+google.cloud.texttospeech.v1.StreamingAudioConfig
+ */
+class StreamingAudioConfig extends \Google\Protobuf\Internal\Message
+{
+ /**
+ * Required. The format of the audio byte stream.
+ * For now, streaming only supports PCM and OGG_OPUS. All other encodings
+ * will return an error.
+ *
+ * Generated from protobuf field .google.cloud.texttospeech.v1.AudioEncoding audio_encoding = 1 [(.google.api.field_behavior) = REQUIRED];
+ */
+ protected $audio_encoding = 0;
+ /**
+ * Optional. The synthesis sample rate (in hertz) for this audio.
+ *
+ * Generated from protobuf field int32 sample_rate_hertz = 2 [(.google.api.field_behavior) = OPTIONAL];
+ */
+ protected $sample_rate_hertz = 0;
+
+ /**
+ * Constructor.
+ *
+ * @param array $data {
+ * Optional. Data for populating the Message object.
+ *
+ * @type int $audio_encoding
+ * Required. The format of the audio byte stream.
+ * For now, streaming only supports PCM and OGG_OPUS. All other encodings
+ * will return an error.
+ * @type int $sample_rate_hertz
+ * Optional. The synthesis sample rate (in hertz) for this audio.
+ * }
+ */
+ public function __construct($data = NULL) {
+ \GPBMetadata\Google\Cloud\Texttospeech\V1\CloudTts::initOnce();
+ parent::__construct($data);
+ }
+
+ /**
+ * Required. The format of the audio byte stream.
+ * For now, streaming only supports PCM and OGG_OPUS. All other encodings
+ * will return an error.
+ *
+ * Generated from protobuf field .google.cloud.texttospeech.v1.AudioEncoding audio_encoding = 1 [(.google.api.field_behavior) = REQUIRED];
+ * @return int
+ */
+ public function getAudioEncoding()
+ {
+ return $this->audio_encoding;
+ }
+
+ /**
+ * Required. The format of the audio byte stream.
+ * For now, streaming only supports PCM and OGG_OPUS. All other encodings
+ * will return an error.
+ *
+ * Generated from protobuf field .google.cloud.texttospeech.v1.AudioEncoding audio_encoding = 1 [(.google.api.field_behavior) = REQUIRED];
+ * @param int $var
+ * @return $this
+ */
+ public function setAudioEncoding($var)
+ {
+ GPBUtil::checkEnum($var, \Google\Cloud\TextToSpeech\V1\AudioEncoding::class);
+ $this->audio_encoding = $var;
+
+ return $this;
+ }
+
+ /**
+ * Optional. The synthesis sample rate (in hertz) for this audio.
+ *
+ * Generated from protobuf field int32 sample_rate_hertz = 2 [(.google.api.field_behavior) = OPTIONAL];
+ * @return int
+ */
+ public function getSampleRateHertz()
+ {
+ return $this->sample_rate_hertz;
+ }
+
+ /**
+ * Optional. The synthesis sample rate (in hertz) for this audio.
+ *
+ * Generated from protobuf field int32 sample_rate_hertz = 2 [(.google.api.field_behavior) = OPTIONAL];
+ * @param int $var
+ * @return $this
+ */
+ public function setSampleRateHertz($var)
+ {
+ GPBUtil::checkInt32($var);
+ $this->sample_rate_hertz = $var;
+
+ return $this;
+ }
+
+}
+
diff --git a/TextToSpeech/src/V1/StreamingSynthesizeConfig.php b/TextToSpeech/src/V1/StreamingSynthesizeConfig.php
index 5cc55b9ba05f..20be1743cbe3 100644
--- a/TextToSpeech/src/V1/StreamingSynthesizeConfig.php
+++ b/TextToSpeech/src/V1/StreamingSynthesizeConfig.php
@@ -20,7 +20,13 @@ class StreamingSynthesizeConfig extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field .google.cloud.texttospeech.v1.VoiceSelectionParams voice = 1 [(.google.api.field_behavior) = REQUIRED];
*/
- private $voice = null;
+ protected $voice = null;
+ /**
+ * Optional. The configuration of the synthesized audio.
+ *
+ * Generated from protobuf field .google.cloud.texttospeech.v1.StreamingAudioConfig streaming_audio_config = 4 [(.google.api.field_behavior) = OPTIONAL];
+ */
+ protected $streaming_audio_config = null;
/**
* Constructor.
@@ -30,6 +36,8 @@ class StreamingSynthesizeConfig extends \Google\Protobuf\Internal\Message
*
* @type \Google\Cloud\TextToSpeech\V1\VoiceSelectionParams $voice
* Required. The desired voice of the synthesized audio.
+ * @type \Google\Cloud\TextToSpeech\V1\StreamingAudioConfig $streaming_audio_config
+ * Optional. The configuration of the synthesized audio.
* }
*/
public function __construct($data = NULL) {
@@ -73,5 +81,41 @@ public function setVoice($var)
return $this;
}
+ /**
+ * Optional. The configuration of the synthesized audio.
+ *
+ * Generated from protobuf field .google.cloud.texttospeech.v1.StreamingAudioConfig streaming_audio_config = 4 [(.google.api.field_behavior) = OPTIONAL];
+ * @return \Google\Cloud\TextToSpeech\V1\StreamingAudioConfig|null
+ */
+ public function getStreamingAudioConfig()
+ {
+ return $this->streaming_audio_config;
+ }
+
+ public function hasStreamingAudioConfig()
+ {
+ return isset($this->streaming_audio_config);
+ }
+
+ public function clearStreamingAudioConfig()
+ {
+ unset($this->streaming_audio_config);
+ }
+
+ /**
+ * Optional. The configuration of the synthesized audio.
+ *
+ * Generated from protobuf field .google.cloud.texttospeech.v1.StreamingAudioConfig streaming_audio_config = 4 [(.google.api.field_behavior) = OPTIONAL];
+ * @param \Google\Cloud\TextToSpeech\V1\StreamingAudioConfig $var
+ * @return $this
+ */
+ public function setStreamingAudioConfig($var)
+ {
+ GPBUtil::checkMessage($var, \Google\Cloud\TextToSpeech\V1\StreamingAudioConfig::class);
+ $this->streaming_audio_config = $var;
+
+ return $this;
+ }
+
}
diff --git a/TextToSpeech/src/V1/StreamingSynthesizeResponse.php b/TextToSpeech/src/V1/StreamingSynthesizeResponse.php
index fba3170cc07a..34eb029802fd 100644
--- a/TextToSpeech/src/V1/StreamingSynthesizeResponse.php
+++ b/TextToSpeech/src/V1/StreamingSynthesizeResponse.php
@@ -23,7 +23,7 @@ class StreamingSynthesizeResponse extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field bytes audio_content = 1;
*/
- private $audio_content = '';
+ protected $audio_content = '';
/**
* Constructor.
diff --git a/TextToSpeech/src/V1/SynthesisInput.php b/TextToSpeech/src/V1/SynthesisInput.php
index d0cee9b951b4..35aa6a12b35e 100644
--- a/TextToSpeech/src/V1/SynthesisInput.php
+++ b/TextToSpeech/src/V1/SynthesisInput.php
@@ -32,7 +32,7 @@ class SynthesisInput extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field .google.cloud.texttospeech.v1.CustomPronunciations custom_pronunciations = 3 [(.google.api.field_behavior) = OPTIONAL];
*/
- private $custom_pronunciations = null;
+ protected $custom_pronunciations = null;
protected $input_source;
/**
diff --git a/TextToSpeech/src/V1/SynthesizeLongAudioMetadata.php b/TextToSpeech/src/V1/SynthesizeLongAudioMetadata.php
index e19a87f60d32..ab9407b4e614 100644
--- a/TextToSpeech/src/V1/SynthesizeLongAudioMetadata.php
+++ b/TextToSpeech/src/V1/SynthesizeLongAudioMetadata.php
@@ -20,7 +20,7 @@ class SynthesizeLongAudioMetadata extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field .google.protobuf.Timestamp start_time = 1;
*/
- private $start_time = null;
+ protected $start_time = null;
/**
* Deprecated. Do not use.
*
@@ -33,7 +33,7 @@ class SynthesizeLongAudioMetadata extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field double progress_percentage = 3;
*/
- private $progress_percentage = 0.0;
+ protected $progress_percentage = 0.0;
/**
* Constructor.
diff --git a/TextToSpeech/src/V1/SynthesizeLongAudioRequest.php b/TextToSpeech/src/V1/SynthesizeLongAudioRequest.php
index b33d6ad93030..951eaaae4f4d 100644
--- a/TextToSpeech/src/V1/SynthesizeLongAudioRequest.php
+++ b/TextToSpeech/src/V1/SynthesizeLongAudioRequest.php
@@ -22,19 +22,19 @@ class SynthesizeLongAudioRequest extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field string parent = 1;
*/
- private $parent = '';
+ protected $parent = '';
/**
* Required. The Synthesizer requires either plain text or SSML as input.
*
* Generated from protobuf field .google.cloud.texttospeech.v1.SynthesisInput input = 2 [(.google.api.field_behavior) = REQUIRED];
*/
- private $input = null;
+ protected $input = null;
/**
* Required. The configuration of the synthesized audio.
*
* Generated from protobuf field .google.cloud.texttospeech.v1.AudioConfig audio_config = 3 [(.google.api.field_behavior) = REQUIRED];
*/
- private $audio_config = null;
+ protected $audio_config = null;
/**
* Required. Specifies a Cloud Storage URI for the synthesis results. Must be
* specified in the format: `gs://bucket_name/object_name`, and the bucket
@@ -42,13 +42,13 @@ class SynthesizeLongAudioRequest extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field string output_gcs_uri = 4 [(.google.api.field_behavior) = REQUIRED];
*/
- private $output_gcs_uri = '';
+ protected $output_gcs_uri = '';
/**
* Required. The desired voice of the synthesized audio.
*
* Generated from protobuf field .google.cloud.texttospeech.v1.VoiceSelectionParams voice = 5 [(.google.api.field_behavior) = REQUIRED];
*/
- private $voice = null;
+ protected $voice = null;
/**
* Constructor.
diff --git a/TextToSpeech/src/V1/SynthesizeSpeechRequest.php b/TextToSpeech/src/V1/SynthesizeSpeechRequest.php
index 706d3b0e9cb4..ee0e47f31fe5 100644
--- a/TextToSpeech/src/V1/SynthesizeSpeechRequest.php
+++ b/TextToSpeech/src/V1/SynthesizeSpeechRequest.php
@@ -20,25 +20,25 @@ class SynthesizeSpeechRequest extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field .google.cloud.texttospeech.v1.SynthesisInput input = 1 [(.google.api.field_behavior) = REQUIRED];
*/
- private $input = null;
+ protected $input = null;
/**
* Required. The desired voice of the synthesized audio.
*
* Generated from protobuf field .google.cloud.texttospeech.v1.VoiceSelectionParams voice = 2 [(.google.api.field_behavior) = REQUIRED];
*/
- private $voice = null;
+ protected $voice = null;
/**
* Required. The configuration of the synthesized audio.
*
* Generated from protobuf field .google.cloud.texttospeech.v1.AudioConfig audio_config = 3 [(.google.api.field_behavior) = REQUIRED];
*/
- private $audio_config = null;
+ protected $audio_config = null;
/**
* Advanced voice options.
*
* Generated from protobuf field optional .google.cloud.texttospeech.v1.AdvancedVoiceOptions advanced_voice_options = 8;
*/
- private $advanced_voice_options = null;
+ protected $advanced_voice_options = null;
/**
* @param \Google\Cloud\TextToSpeech\V1\SynthesisInput $input Required. The Synthesizer requires either plain text or SSML as input.
diff --git a/TextToSpeech/src/V1/SynthesizeSpeechResponse.php b/TextToSpeech/src/V1/SynthesizeSpeechResponse.php
index b53a96aa3a18..bfe3329eb5e2 100644
--- a/TextToSpeech/src/V1/SynthesizeSpeechResponse.php
+++ b/TextToSpeech/src/V1/SynthesizeSpeechResponse.php
@@ -24,7 +24,7 @@ class SynthesizeSpeechResponse extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field bytes audio_content = 1;
*/
- private $audio_content = '';
+ protected $audio_content = '';
/**
* Constructor.
diff --git a/TextToSpeech/src/V1/TextToSpeechClient.php b/TextToSpeech/src/V1/TextToSpeechClient.php
deleted file mode 100644
index f24c28dac4d1..000000000000
--- a/TextToSpeech/src/V1/TextToSpeechClient.php
+++ /dev/null
@@ -1,34 +0,0 @@
-_simpleRequest('/google.cloud.texttospeech.v1.TextToSpeech/ListVoices',
- $argument,
- ['\Google\Cloud\TextToSpeech\V1\ListVoicesResponse', 'decode'],
- $metadata, $options);
- }
-
- /**
- * Synthesizes speech synchronously: receive results after all text input
- * has been processed.
- * @param \Google\Cloud\TextToSpeech\V1\SynthesizeSpeechRequest $argument input argument
- * @param array $metadata metadata
- * @param array $options call options
- * @return \Grpc\UnaryCall
- */
- public function SynthesizeSpeech(\Google\Cloud\TextToSpeech\V1\SynthesizeSpeechRequest $argument,
- $metadata = [], $options = []) {
- return $this->_simpleRequest('/google.cloud.texttospeech.v1.TextToSpeech/SynthesizeSpeech',
- $argument,
- ['\Google\Cloud\TextToSpeech\V1\SynthesizeSpeechResponse', 'decode'],
- $metadata, $options);
- }
-
-}
diff --git a/TextToSpeech/src/V1/TextToSpeechLongAudioSynthesizeClient.php b/TextToSpeech/src/V1/TextToSpeechLongAudioSynthesizeClient.php
deleted file mode 100644
index 8f5aff29208a..000000000000
--- a/TextToSpeech/src/V1/TextToSpeechLongAudioSynthesizeClient.php
+++ /dev/null
@@ -1,34 +0,0 @@
-_simpleRequest('/google.cloud.texttospeech.v1.TextToSpeechLongAudioSynthesize/SynthesizeLongAudio',
- $argument,
- ['\Google\LongRunning\Operation', 'decode'],
- $metadata, $options);
- }
-
-}
diff --git a/TextToSpeech/src/V1/Voice.php b/TextToSpeech/src/V1/Voice.php
index e79780e350e4..f53642965390 100644
--- a/TextToSpeech/src/V1/Voice.php
+++ b/TextToSpeech/src/V1/Voice.php
@@ -28,19 +28,19 @@ class Voice extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field string name = 2;
*/
- private $name = '';
+ protected $name = '';
/**
* The gender of this voice.
*
* Generated from protobuf field .google.cloud.texttospeech.v1.SsmlVoiceGender ssml_gender = 3;
*/
- private $ssml_gender = 0;
+ protected $ssml_gender = 0;
/**
* The natural sample rate (in hertz) for this voice.
*
* Generated from protobuf field int32 natural_sample_rate_hertz = 4;
*/
- private $natural_sample_rate_hertz = 0;
+ protected $natural_sample_rate_hertz = 0;
/**
* Constructor.
diff --git a/TextToSpeech/src/V1/VoiceCloneParams.php b/TextToSpeech/src/V1/VoiceCloneParams.php
index dcdf28485990..83d52d421f52 100644
--- a/TextToSpeech/src/V1/VoiceCloneParams.php
+++ b/TextToSpeech/src/V1/VoiceCloneParams.php
@@ -20,7 +20,7 @@ class VoiceCloneParams extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field string voice_cloning_key = 1 [(.google.api.field_behavior) = REQUIRED];
*/
- private $voice_cloning_key = '';
+ protected $voice_cloning_key = '';
/**
* Constructor.
diff --git a/TextToSpeech/src/V1/VoiceSelectionParams.php b/TextToSpeech/src/V1/VoiceSelectionParams.php
index 2075fbe1535a..5ccf9c11db9b 100644
--- a/TextToSpeech/src/V1/VoiceSelectionParams.php
+++ b/TextToSpeech/src/V1/VoiceSelectionParams.php
@@ -30,7 +30,7 @@ class VoiceSelectionParams extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field string language_code = 1 [(.google.api.field_behavior) = REQUIRED];
*/
- private $language_code = '';
+ protected $language_code = '';
/**
* The name of the voice. If both the name and the gender are not set,
* the service will choose a voice based on the other parameters such as
@@ -38,7 +38,7 @@ class VoiceSelectionParams extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field string name = 2;
*/
- private $name = '';
+ protected $name = '';
/**
* The preferred gender of the voice. If not set, the service will
* choose a voice based on the other parameters such as language_code and
@@ -48,7 +48,7 @@ class VoiceSelectionParams extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field .google.cloud.texttospeech.v1.SsmlVoiceGender ssml_gender = 3;
*/
- private $ssml_gender = 0;
+ protected $ssml_gender = 0;
/**
* The configuration for a custom voice. If [CustomVoiceParams.model] is set,
* the service will choose the custom voice matching the specified
@@ -56,7 +56,7 @@ class VoiceSelectionParams extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field .google.cloud.texttospeech.v1.CustomVoiceParams custom_voice = 4;
*/
- private $custom_voice = null;
+ protected $custom_voice = null;
/**
* Optional. The configuration for a voice clone. If
* [VoiceCloneParams.voice_clone_key] is set, the service will choose the
@@ -64,7 +64,7 @@ class VoiceSelectionParams extends \Google\Protobuf\Internal\Message
*
* Generated from protobuf field .google.cloud.texttospeech.v1.VoiceCloneParams voice_clone = 5 [(.google.api.field_behavior) = OPTIONAL];
*/
- private $voice_clone = null;
+ protected $voice_clone = null;
/**
* Constructor.
diff --git a/TextToSpeech/src/V1/resources/text_to_speech_descriptor_config.php b/TextToSpeech/src/V1/resources/text_to_speech_descriptor_config.php
index e5fe1bf06556..39aa2b0d64dd 100644
--- a/TextToSpeech/src/V1/resources/text_to_speech_descriptor_config.php
+++ b/TextToSpeech/src/V1/resources/text_to_speech_descriptor_config.php
@@ -1,6 +1,6 @@
setText($text);
- $languageCode = 'en-US';
- $voice = new VoiceSelectionParams();
- $voice->setLanguageCode($languageCode);
- $audioEncoding = AudioEncoding::MP3;
- $audioConfig = new AudioConfig();
- $audioConfig->setAudioEncoding($audioEncoding);
- $textToSpeechClient->synthesizeSpeech($input, $voice, $audioConfig);
- }
-}
diff --git a/TextToSpeech/tests/System/bootstrap.php b/TextToSpeech/tests/System/bootstrap.php
deleted file mode 100644
index 30d98dd46349..000000000000
--- a/TextToSpeech/tests/System/bootstrap.php
+++ /dev/null
@@ -1,10 +0,0 @@
-getMockBuilder(CredentialsWrapper::class)->disableOriginalConstructor()->getMock();
+ return $this->getMockBuilder(CredentialsWrapper::class)
+ ->disableOriginalConstructor()
+ ->getMock();
}
/** @return TextToSpeechClient */
@@ -102,12 +104,15 @@ public function listVoicesExceptionTest()
$status = new stdClass();
$status->code = Code::DATA_LOSS;
$status->details = 'internal error';
- $expectedExceptionMessage = json_encode([
- 'message' => 'internal error',
- 'code' => Code::DATA_LOSS,
- 'status' => 'DATA_LOSS',
- 'details' => [],
- ], JSON_PRETTY_PRINT);
+ $expectedExceptionMessage = json_encode(
+ [
+ 'message' => 'internal error',
+ 'code' => Code::DATA_LOSS,
+ 'status' => 'DATA_LOSS',
+ 'details' => [],
+ ],
+ JSON_PRETTY_PRINT
+ );
$transport->addResponse(null, $status);
$request = new ListVoicesRequest();
try {
@@ -153,10 +158,7 @@ public function streamingSynthesizeTest()
$bidi->write($request);
$responses = [];
$responses[] = $bidi->read();
- $bidi->writeAll([
- $request2,
- $request3,
- ]);
+ $bidi->writeAll([$request2, $request3]);
foreach ($bidi->closeWriteAndReadAll() as $response) {
$responses[] = $response;
}
@@ -194,12 +196,15 @@ public function streamingSynthesizeExceptionTest()
$status = new stdClass();
$status->code = Code::DATA_LOSS;
$status->details = 'internal error';
- $expectedExceptionMessage = json_encode([
- 'message' => 'internal error',
- 'code' => Code::DATA_LOSS,
- 'status' => 'DATA_LOSS',
- 'details' => [],
- ], JSON_PRETTY_PRINT);
+ $expectedExceptionMessage = json_encode(
+ [
+ 'message' => 'internal error',
+ 'code' => Code::DATA_LOSS,
+ 'status' => 'DATA_LOSS',
+ 'details' => [],
+ ],
+ JSON_PRETTY_PRINT
+ );
$transport->setStreamingStatus($status);
$this->assertTrue($transport->isExhausted());
$bidi = $gapicClient->streamingSynthesize();
@@ -269,12 +274,15 @@ public function synthesizeSpeechExceptionTest()
$status = new stdClass();
$status->code = Code::DATA_LOSS;
$status->details = 'internal error';
- $expectedExceptionMessage = json_encode([
- 'message' => 'internal error',
- 'code' => Code::DATA_LOSS,
- 'status' => 'DATA_LOSS',
- 'details' => [],
- ], JSON_PRETTY_PRINT);
+ $expectedExceptionMessage = json_encode(
+ [
+ 'message' => 'internal error',
+ 'code' => Code::DATA_LOSS,
+ 'status' => 'DATA_LOSS',
+ 'details' => [],
+ ],
+ JSON_PRETTY_PRINT
+ );
$transport->addResponse(null, $status);
// Mock request
$input = new SynthesisInput();
diff --git a/TextToSpeech/tests/Unit/V1/Client/TextToSpeechLongAudioSynthesizeClientTest.php b/TextToSpeech/tests/Unit/V1/Client/TextToSpeechLongAudioSynthesizeClientTest.php
index 6ad2ea41bb10..bccc7269afb1 100644
--- a/TextToSpeech/tests/Unit/V1/Client/TextToSpeechLongAudioSynthesizeClientTest.php
+++ b/TextToSpeech/tests/Unit/V1/Client/TextToSpeechLongAudioSynthesizeClientTest.php
@@ -1,6 +1,6 @@
getMockBuilder(CredentialsWrapper::class)->disableOriginalConstructor()->getMock();
+ return $this->getMockBuilder(CredentialsWrapper::class)
+ ->disableOriginalConstructor()
+ ->getMock();
}
/** @return TextToSpeechLongAudioSynthesizeClient */
@@ -101,9 +103,7 @@ public function synthesizeLongAudioTest()
$audioConfig = new AudioConfig();
$audioConfigAudioEncoding = AudioEncoding::AUDIO_ENCODING_UNSPECIFIED;
$audioConfig->setAudioEncoding($audioConfigAudioEncoding);
- $request = (new SynthesizeLongAudioRequest())
- ->setInput($input)
- ->setAudioConfig($audioConfig);
+ $request = (new SynthesizeLongAudioRequest())->setInput($input)->setAudioConfig($audioConfig);
$response = $gapicClient->synthesizeLongAudio($request);
$this->assertFalse($response->isDone());
$this->assertNull($response->getResult());
@@ -113,7 +113,10 @@ public function synthesizeLongAudioTest()
$this->assertSame(0, count($operationsRequestsEmpty));
$actualApiFuncCall = $apiRequests[0]->getFuncCall();
$actualApiRequestObject = $apiRequests[0]->getRequestObject();
- $this->assertSame('/google.cloud.texttospeech.v1.TextToSpeechLongAudioSynthesize/SynthesizeLongAudio', $actualApiFuncCall);
+ $this->assertSame(
+ '/google.cloud.texttospeech.v1.TextToSpeechLongAudioSynthesize/SynthesizeLongAudio',
+ $actualApiFuncCall
+ );
$actualValue = $actualApiRequestObject->getInput();
$this->assertProtobufEquals($input, $actualValue);
$actualValue = $actualApiRequestObject->getAudioConfig();
@@ -161,21 +164,22 @@ public function synthesizeLongAudioExceptionTest()
$status = new stdClass();
$status->code = Code::DATA_LOSS;
$status->details = 'internal error';
- $expectedExceptionMessage = json_encode([
- 'message' => 'internal error',
- 'code' => Code::DATA_LOSS,
- 'status' => 'DATA_LOSS',
- 'details' => [],
- ], JSON_PRETTY_PRINT);
+ $expectedExceptionMessage = json_encode(
+ [
+ 'message' => 'internal error',
+ 'code' => Code::DATA_LOSS,
+ 'status' => 'DATA_LOSS',
+ 'details' => [],
+ ],
+ JSON_PRETTY_PRINT
+ );
$operationsTransport->addResponse(null, $status);
// Mock request
$input = new SynthesisInput();
$audioConfig = new AudioConfig();
$audioConfigAudioEncoding = AudioEncoding::AUDIO_ENCODING_UNSPECIFIED;
$audioConfig->setAudioEncoding($audioConfigAudioEncoding);
- $request = (new SynthesizeLongAudioRequest())
- ->setInput($input)
- ->setAudioConfig($audioConfig);
+ $request = (new SynthesizeLongAudioRequest())->setInput($input)->setAudioConfig($audioConfig);
$response = $gapicClient->synthesizeLongAudio($request);
$this->assertFalse($response->isDone());
$this->assertNull($response->getResult());
@@ -232,9 +236,7 @@ public function synthesizeLongAudioAsyncTest()
$audioConfig = new AudioConfig();
$audioConfigAudioEncoding = AudioEncoding::AUDIO_ENCODING_UNSPECIFIED;
$audioConfig->setAudioEncoding($audioConfigAudioEncoding);
- $request = (new SynthesizeLongAudioRequest())
- ->setInput($input)
- ->setAudioConfig($audioConfig);
+ $request = (new SynthesizeLongAudioRequest())->setInput($input)->setAudioConfig($audioConfig);
$response = $gapicClient->synthesizeLongAudioAsync($request)->wait();
$this->assertFalse($response->isDone());
$this->assertNull($response->getResult());
@@ -244,7 +246,10 @@ public function synthesizeLongAudioAsyncTest()
$this->assertSame(0, count($operationsRequestsEmpty));
$actualApiFuncCall = $apiRequests[0]->getFuncCall();
$actualApiRequestObject = $apiRequests[0]->getRequestObject();
- $this->assertSame('/google.cloud.texttospeech.v1.TextToSpeechLongAudioSynthesize/SynthesizeLongAudio', $actualApiFuncCall);
+ $this->assertSame(
+ '/google.cloud.texttospeech.v1.TextToSpeechLongAudioSynthesize/SynthesizeLongAudio',
+ $actualApiFuncCall
+ );
$actualValue = $actualApiRequestObject->getInput();
$this->assertProtobufEquals($input, $actualValue);
$actualValue = $actualApiRequestObject->getAudioConfig();
diff --git a/TextToSpeech/tests/Unit/V1/TextToSpeechClientTest.php b/TextToSpeech/tests/Unit/V1/TextToSpeechClientTest.php
deleted file mode 100644
index 7b53cfef4a1f..000000000000
--- a/TextToSpeech/tests/Unit/V1/TextToSpeechClientTest.php
+++ /dev/null
@@ -1,291 +0,0 @@
-getMockBuilder(CredentialsWrapper::class)->disableOriginalConstructor()->getMock();
- }
-
- /** @return TextToSpeechClient */
- private function createClient(array $options = [])
- {
- $options += [
- 'credentials' => $this->createCredentials(),
- ];
- return new TextToSpeechClient($options);
- }
-
- /** @test */
- public function listVoicesTest()
- {
- $transport = $this->createTransport();
- $gapicClient = $this->createClient([
- 'transport' => $transport,
- ]);
- $this->assertTrue($transport->isExhausted());
- // Mock response
- $expectedResponse = new ListVoicesResponse();
- $transport->addResponse($expectedResponse);
- $response = $gapicClient->listVoices();
- $this->assertEquals($expectedResponse, $response);
- $actualRequests = $transport->popReceivedCalls();
- $this->assertSame(1, count($actualRequests));
- $actualFuncCall = $actualRequests[0]->getFuncCall();
- $actualRequestObject = $actualRequests[0]->getRequestObject();
- $this->assertSame('/google.cloud.texttospeech.v1.TextToSpeech/ListVoices', $actualFuncCall);
- $this->assertTrue($transport->isExhausted());
- }
-
- /** @test */
- public function listVoicesExceptionTest()
- {
- $transport = $this->createTransport();
- $gapicClient = $this->createClient([
- 'transport' => $transport,
- ]);
- $this->assertTrue($transport->isExhausted());
- $status = new stdClass();
- $status->code = Code::DATA_LOSS;
- $status->details = 'internal error';
- $expectedExceptionMessage = json_encode([
- 'message' => 'internal error',
- 'code' => Code::DATA_LOSS,
- 'status' => 'DATA_LOSS',
- 'details' => [],
- ], JSON_PRETTY_PRINT);
- $transport->addResponse(null, $status);
- try {
- $gapicClient->listVoices();
- // If the $gapicClient method call did not throw, fail the test
- $this->fail('Expected an ApiException, but no exception was thrown.');
- } catch (ApiException $ex) {
- $this->assertEquals($status->code, $ex->getCode());
- $this->assertEquals($expectedExceptionMessage, $ex->getMessage());
- }
- // Call popReceivedCalls to ensure the stub is exhausted
- $transport->popReceivedCalls();
- $this->assertTrue($transport->isExhausted());
- }
-
- /** @test */
- public function streamingSynthesizeTest()
- {
- $transport = $this->createTransport();
- $gapicClient = $this->createClient([
- 'transport' => $transport,
- ]);
- $this->assertTrue($transport->isExhausted());
- // Mock response
- $audioContent = '16';
- $expectedResponse = new StreamingSynthesizeResponse();
- $expectedResponse->setAudioContent($audioContent);
- $transport->addResponse($expectedResponse);
- $audioContent2 = '-61';
- $expectedResponse2 = new StreamingSynthesizeResponse();
- $expectedResponse2->setAudioContent($audioContent2);
- $transport->addResponse($expectedResponse2);
- $audioContent3 = '-60';
- $expectedResponse3 = new StreamingSynthesizeResponse();
- $expectedResponse3->setAudioContent($audioContent3);
- $transport->addResponse($expectedResponse3);
- // Mock request
- $request = new StreamingSynthesizeRequest();
- $request2 = new StreamingSynthesizeRequest();
- $request3 = new StreamingSynthesizeRequest();
- $bidi = $gapicClient->streamingSynthesize();
- $this->assertInstanceOf(BidiStream::class, $bidi);
- $bidi->write($request);
- $responses = [];
- $responses[] = $bidi->read();
- $bidi->writeAll([
- $request2,
- $request3,
- ]);
- foreach ($bidi->closeWriteAndReadAll() as $response) {
- $responses[] = $response;
- }
-
- $expectedResponses = [];
- $expectedResponses[] = $expectedResponse;
- $expectedResponses[] = $expectedResponse2;
- $expectedResponses[] = $expectedResponse3;
- $this->assertEquals($expectedResponses, $responses);
- $createStreamRequests = $transport->popReceivedCalls();
- $this->assertSame(1, count($createStreamRequests));
- $streamFuncCall = $createStreamRequests[0]->getFuncCall();
- $streamRequestObject = $createStreamRequests[0]->getRequestObject();
- $this->assertSame('/google.cloud.texttospeech.v1.TextToSpeech/StreamingSynthesize', $streamFuncCall);
- $this->assertNull($streamRequestObject);
- $callObjects = $transport->popCallObjects();
- $this->assertSame(1, count($callObjects));
- $bidiCall = $callObjects[0];
- $writeRequests = $bidiCall->popReceivedCalls();
- $expectedRequests = [];
- $expectedRequests[] = $request;
- $expectedRequests[] = $request2;
- $expectedRequests[] = $request3;
- $this->assertEquals($expectedRequests, $writeRequests);
- $this->assertTrue($transport->isExhausted());
- }
-
- /** @test */
- public function streamingSynthesizeExceptionTest()
- {
- $transport = $this->createTransport();
- $gapicClient = $this->createClient([
- 'transport' => $transport,
- ]);
- $status = new stdClass();
- $status->code = Code::DATA_LOSS;
- $status->details = 'internal error';
- $expectedExceptionMessage = json_encode([
- 'message' => 'internal error',
- 'code' => Code::DATA_LOSS,
- 'status' => 'DATA_LOSS',
- 'details' => [],
- ], JSON_PRETTY_PRINT);
- $transport->setStreamingStatus($status);
- $this->assertTrue($transport->isExhausted());
- $bidi = $gapicClient->streamingSynthesize();
- $results = $bidi->closeWriteAndReadAll();
- try {
- iterator_to_array($results);
- // If the close stream method call did not throw, fail the test
- $this->fail('Expected an ApiException, but no exception was thrown.');
- } catch (ApiException $ex) {
- $this->assertEquals($status->code, $ex->getCode());
- $this->assertEquals($expectedExceptionMessage, $ex->getMessage());
- }
- // Call popReceivedCalls to ensure the stub is exhausted
- $transport->popReceivedCalls();
- $this->assertTrue($transport->isExhausted());
- }
-
- /** @test */
- public function synthesizeSpeechTest()
- {
- $transport = $this->createTransport();
- $gapicClient = $this->createClient([
- 'transport' => $transport,
- ]);
- $this->assertTrue($transport->isExhausted());
- // Mock response
- $audioContent = '16';
- $expectedResponse = new SynthesizeSpeechResponse();
- $expectedResponse->setAudioContent($audioContent);
- $transport->addResponse($expectedResponse);
- // Mock request
- $input = new SynthesisInput();
- $voice = new VoiceSelectionParams();
- $voiceLanguageCode = 'voiceLanguageCode-686472265';
- $voice->setLanguageCode($voiceLanguageCode);
- $audioConfig = new AudioConfig();
- $audioConfigAudioEncoding = AudioEncoding::AUDIO_ENCODING_UNSPECIFIED;
- $audioConfig->setAudioEncoding($audioConfigAudioEncoding);
- $response = $gapicClient->synthesizeSpeech($input, $voice, $audioConfig);
- $this->assertEquals($expectedResponse, $response);
- $actualRequests = $transport->popReceivedCalls();
- $this->assertSame(1, count($actualRequests));
- $actualFuncCall = $actualRequests[0]->getFuncCall();
- $actualRequestObject = $actualRequests[0]->getRequestObject();
- $this->assertSame('/google.cloud.texttospeech.v1.TextToSpeech/SynthesizeSpeech', $actualFuncCall);
- $actualValue = $actualRequestObject->getInput();
- $this->assertProtobufEquals($input, $actualValue);
- $actualValue = $actualRequestObject->getVoice();
- $this->assertProtobufEquals($voice, $actualValue);
- $actualValue = $actualRequestObject->getAudioConfig();
- $this->assertProtobufEquals($audioConfig, $actualValue);
- $this->assertTrue($transport->isExhausted());
- }
-
- /** @test */
- public function synthesizeSpeechExceptionTest()
- {
- $transport = $this->createTransport();
- $gapicClient = $this->createClient([
- 'transport' => $transport,
- ]);
- $this->assertTrue($transport->isExhausted());
- $status = new stdClass();
- $status->code = Code::DATA_LOSS;
- $status->details = 'internal error';
- $expectedExceptionMessage = json_encode([
- 'message' => 'internal error',
- 'code' => Code::DATA_LOSS,
- 'status' => 'DATA_LOSS',
- 'details' => [],
- ], JSON_PRETTY_PRINT);
- $transport->addResponse(null, $status);
- // Mock request
- $input = new SynthesisInput();
- $voice = new VoiceSelectionParams();
- $voiceLanguageCode = 'voiceLanguageCode-686472265';
- $voice->setLanguageCode($voiceLanguageCode);
- $audioConfig = new AudioConfig();
- $audioConfigAudioEncoding = AudioEncoding::AUDIO_ENCODING_UNSPECIFIED;
- $audioConfig->setAudioEncoding($audioConfigAudioEncoding);
- try {
- $gapicClient->synthesizeSpeech($input, $voice, $audioConfig);
- // If the $gapicClient method call did not throw, fail the test
- $this->fail('Expected an ApiException, but no exception was thrown.');
- } catch (ApiException $ex) {
- $this->assertEquals($status->code, $ex->getCode());
- $this->assertEquals($expectedExceptionMessage, $ex->getMessage());
- }
- // Call popReceivedCalls to ensure the stub is exhausted
- $transport->popReceivedCalls();
- $this->assertTrue($transport->isExhausted());
- }
-}
diff --git a/TextToSpeech/tests/Unit/V1/TextToSpeechLongAudioSynthesizeClientTest.php b/TextToSpeech/tests/Unit/V1/TextToSpeechLongAudioSynthesizeClientTest.php
deleted file mode 100644
index c691205c1191..000000000000
--- a/TextToSpeech/tests/Unit/V1/TextToSpeechLongAudioSynthesizeClientTest.php
+++ /dev/null
@@ -1,193 +0,0 @@
-getMockBuilder(CredentialsWrapper::class)->disableOriginalConstructor()->getMock();
- }
-
- /** @return TextToSpeechLongAudioSynthesizeClient */
- private function createClient(array $options = [])
- {
- $options += [
- 'credentials' => $this->createCredentials(),
- ];
- return new TextToSpeechLongAudioSynthesizeClient($options);
- }
-
- /** @test */
- public function synthesizeLongAudioTest()
- {
- $operationsTransport = $this->createTransport();
- $operationsClient = new OperationsClient([
- 'apiEndpoint' => '',
- 'transport' => $operationsTransport,
- 'credentials' => $this->createCredentials(),
- ]);
- $transport = $this->createTransport();
- $gapicClient = $this->createClient([
- 'transport' => $transport,
- 'operationsClient' => $operationsClient,
- ]);
- $this->assertTrue($transport->isExhausted());
- $this->assertTrue($operationsTransport->isExhausted());
- // Mock response
- $incompleteOperation = new Operation();
- $incompleteOperation->setName('operations/synthesizeLongAudioTest');
- $incompleteOperation->setDone(false);
- $transport->addResponse($incompleteOperation);
- $expectedResponse = new SynthesizeLongAudioResponse();
- $anyResponse = new Any();
- $anyResponse->setValue($expectedResponse->serializeToString());
- $completeOperation = new Operation();
- $completeOperation->setName('operations/synthesizeLongAudioTest');
- $completeOperation->setDone(true);
- $completeOperation->setResponse($anyResponse);
- $operationsTransport->addResponse($completeOperation);
- // Mock request
- $input = new SynthesisInput();
- $audioConfig = new AudioConfig();
- $audioConfigAudioEncoding = AudioEncoding::AUDIO_ENCODING_UNSPECIFIED;
- $audioConfig->setAudioEncoding($audioConfigAudioEncoding);
- $response = $gapicClient->synthesizeLongAudio($input, $audioConfig);
- $this->assertFalse($response->isDone());
- $this->assertNull($response->getResult());
- $apiRequests = $transport->popReceivedCalls();
- $this->assertSame(1, count($apiRequests));
- $operationsRequestsEmpty = $operationsTransport->popReceivedCalls();
- $this->assertSame(0, count($operationsRequestsEmpty));
- $actualApiFuncCall = $apiRequests[0]->getFuncCall();
- $actualApiRequestObject = $apiRequests[0]->getRequestObject();
- $this->assertSame('/google.cloud.texttospeech.v1.TextToSpeechLongAudioSynthesize/SynthesizeLongAudio', $actualApiFuncCall);
- $actualValue = $actualApiRequestObject->getInput();
- $this->assertProtobufEquals($input, $actualValue);
- $actualValue = $actualApiRequestObject->getAudioConfig();
- $this->assertProtobufEquals($audioConfig, $actualValue);
- $expectedOperationsRequestObject = new GetOperationRequest();
- $expectedOperationsRequestObject->setName('operations/synthesizeLongAudioTest');
- $response->pollUntilComplete([
- 'initialPollDelayMillis' => 1,
- ]);
- $this->assertTrue($response->isDone());
- $this->assertEquals($expectedResponse, $response->getResult());
- $apiRequestsEmpty = $transport->popReceivedCalls();
- $this->assertSame(0, count($apiRequestsEmpty));
- $operationsRequests = $operationsTransport->popReceivedCalls();
- $this->assertSame(1, count($operationsRequests));
- $actualOperationsFuncCall = $operationsRequests[0]->getFuncCall();
- $actualOperationsRequestObject = $operationsRequests[0]->getRequestObject();
- $this->assertSame('/google.longrunning.Operations/GetOperation', $actualOperationsFuncCall);
- $this->assertEquals($expectedOperationsRequestObject, $actualOperationsRequestObject);
- $this->assertTrue($transport->isExhausted());
- $this->assertTrue($operationsTransport->isExhausted());
- }
-
- /** @test */
- public function synthesizeLongAudioExceptionTest()
- {
- $operationsTransport = $this->createTransport();
- $operationsClient = new OperationsClient([
- 'apiEndpoint' => '',
- 'transport' => $operationsTransport,
- 'credentials' => $this->createCredentials(),
- ]);
- $transport = $this->createTransport();
- $gapicClient = $this->createClient([
- 'transport' => $transport,
- 'operationsClient' => $operationsClient,
- ]);
- $this->assertTrue($transport->isExhausted());
- $this->assertTrue($operationsTransport->isExhausted());
- // Mock response
- $incompleteOperation = new Operation();
- $incompleteOperation->setName('operations/synthesizeLongAudioTest');
- $incompleteOperation->setDone(false);
- $transport->addResponse($incompleteOperation);
- $status = new stdClass();
- $status->code = Code::DATA_LOSS;
- $status->details = 'internal error';
- $expectedExceptionMessage = json_encode([
- 'message' => 'internal error',
- 'code' => Code::DATA_LOSS,
- 'status' => 'DATA_LOSS',
- 'details' => [],
- ], JSON_PRETTY_PRINT);
- $operationsTransport->addResponse(null, $status);
- // Mock request
- $input = new SynthesisInput();
- $audioConfig = new AudioConfig();
- $audioConfigAudioEncoding = AudioEncoding::AUDIO_ENCODING_UNSPECIFIED;
- $audioConfig->setAudioEncoding($audioConfigAudioEncoding);
- $response = $gapicClient->synthesizeLongAudio($input, $audioConfig);
- $this->assertFalse($response->isDone());
- $this->assertNull($response->getResult());
- $expectedOperationsRequestObject = new GetOperationRequest();
- $expectedOperationsRequestObject->setName('operations/synthesizeLongAudioTest');
- try {
- $response->pollUntilComplete([
- 'initialPollDelayMillis' => 1,
- ]);
- // If the pollUntilComplete() method call did not throw, fail the test
- $this->fail('Expected an ApiException, but no exception was thrown.');
- } catch (ApiException $ex) {
- $this->assertEquals($status->code, $ex->getCode());
- $this->assertEquals($expectedExceptionMessage, $ex->getMessage());
- }
- // Call popReceivedCalls to ensure the stubs are exhausted
- $transport->popReceivedCalls();
- $operationsTransport->popReceivedCalls();
- $this->assertTrue($transport->isExhausted());
- $this->assertTrue($operationsTransport->isExhausted());
- }
-}