From 215877fbceb49d8edabe433955aace010a965389 Mon Sep 17 00:00:00 2001 From: Brett McBride Date: Wed, 9 Aug 2023 10:56:11 +1000 Subject: [PATCH] adding PushMetricExporterInterface /~https://github.com/open-telemetry/opentelemetry-specification/pull/3563 clarifies the behaviour of forceFlush with push/non-push metric exporters. Break forceFlush out into a PushMetricExporterInterface, and update ExportingReader to only collect/flush if exporter is a push metric exporter. --- examples/metrics/getting_started.php | 4 ++-- examples/metrics/weak-reference-observables.php | 4 ++-- src/Contrib/Otlp/MetricExporter.php | 4 ++-- ...ricsExporter.php => ConsoleMetricExporter.php} | 4 ++-- .../ConsoleMetricExporterFactory.php | 2 +- .../Metrics/MetricExporter/InMemoryExporter.php | 5 ----- .../Metrics/MetricExporter/NoopMetricExporter.php | 5 ----- src/SDK/Metrics/MetricExporterInterface.php | 2 -- src/SDK/Metrics/MetricReader/ExportingReader.php | 10 +++++++--- src/SDK/Metrics/PushMetricExporterInterface.php | 12 ++++++++++++ .../Metrics/MetricReader/ExportingReaderTest.php | 15 ++++++++++++--- 11 files changed, 40 insertions(+), 27 deletions(-) rename src/SDK/Metrics/MetricExporter/{ConsoleMetricsExporter.php => ConsoleMetricExporter.php} (95%) create mode 100644 src/SDK/Metrics/PushMetricExporterInterface.php diff --git a/examples/metrics/getting_started.php b/examples/metrics/getting_started.php index 1d534d582..6ba39ec08 100644 --- a/examples/metrics/getting_started.php +++ b/examples/metrics/getting_started.php @@ -5,7 +5,7 @@ use OpenTelemetry\API\Metrics\ObserverInterface; use OpenTelemetry\SDK\Metrics\Data\Temporality; use OpenTelemetry\SDK\Metrics\MeterProvider; -use OpenTelemetry\SDK\Metrics\MetricExporter\ConsoleMetricsExporter; +use OpenTelemetry\SDK\Metrics\MetricExporter\ConsoleMetricExporter; use OpenTelemetry\SDK\Metrics\MetricReader\ExportingReader; use OpenTelemetry\SDK\Resource\ResourceInfoFactory; @@ -18,7 +18,7 @@ */ $reader = new ExportingReader( - new ConsoleMetricsExporter(Temporality::DELTA) + new ConsoleMetricExporter(Temporality::DELTA) ); $meterProvider = MeterProvider::builder() diff --git a/examples/metrics/weak-reference-observables.php b/examples/metrics/weak-reference-observables.php index b44da0126..f53428f78 100644 --- a/examples/metrics/weak-reference-observables.php +++ b/examples/metrics/weak-reference-observables.php @@ -5,7 +5,7 @@ use OpenTelemetry\API\Metrics\ObserverInterface; use OpenTelemetry\SDK\Metrics\Data\Temporality; use OpenTelemetry\SDK\Metrics\MeterProvider; -use OpenTelemetry\SDK\Metrics\MetricExporter\ConsoleMetricsExporter; +use OpenTelemetry\SDK\Metrics\MetricExporter\ConsoleMetricExporter; use OpenTelemetry\SDK\Metrics\MetricReader\ExportingReader; use OpenTelemetry\SDK\Resource\ResourceInfoFactory; @@ -19,7 +19,7 @@ */ $reader = new ExportingReader( - new ConsoleMetricsExporter(Temporality::DELTA) + new ConsoleMetricExporter(Temporality::DELTA) ); $meterProvider = MeterProvider::builder() diff --git a/src/Contrib/Otlp/MetricExporter.php b/src/Contrib/Otlp/MetricExporter.php index d9f26fd58..d2ca9c27d 100644 --- a/src/Contrib/Otlp/MetricExporter.php +++ b/src/Contrib/Otlp/MetricExporter.php @@ -8,8 +8,8 @@ use Opentelemetry\Proto\Collector\Metrics\V1\ExportMetricsServiceResponse; use OpenTelemetry\SDK\Common\Export\TransportInterface; use OpenTelemetry\SDK\Metrics\Data\Temporality; -use OpenTelemetry\SDK\Metrics\MetricExporterInterface; use OpenTelemetry\SDK\Metrics\MetricMetadataInterface; +use OpenTelemetry\SDK\Metrics\PushMetricExporterInterface; use RuntimeException; use Throwable; @@ -18,7 +18,7 @@ * @see /~https://github.com/open-telemetry/opentelemetry-specification/blob/main/experimental/serialization/json.md#json-file-serialization * @psalm-import-type SUPPORTED_CONTENT_TYPES from ProtobufSerializer */ -final class MetricExporter implements MetricExporterInterface +final class MetricExporter implements PushMetricExporterInterface { use LogsMessagesTrait; diff --git a/src/SDK/Metrics/MetricExporter/ConsoleMetricsExporter.php b/src/SDK/Metrics/MetricExporter/ConsoleMetricExporter.php similarity index 95% rename from src/SDK/Metrics/MetricExporter/ConsoleMetricsExporter.php rename to src/SDK/Metrics/MetricExporter/ConsoleMetricExporter.php index 6afdd4f26..b9330a112 100644 --- a/src/SDK/Metrics/MetricExporter/ConsoleMetricsExporter.php +++ b/src/SDK/Metrics/MetricExporter/ConsoleMetricExporter.php @@ -7,15 +7,15 @@ use OpenTelemetry\SDK\Common\Instrumentation\InstrumentationScopeInterface; use OpenTelemetry\SDK\Metrics\Data\Metric; use OpenTelemetry\SDK\Metrics\Data\Temporality; -use OpenTelemetry\SDK\Metrics\MetricExporterInterface; use OpenTelemetry\SDK\Metrics\MetricMetadataInterface; +use OpenTelemetry\SDK\Metrics\PushMetricExporterInterface; use OpenTelemetry\SDK\Resource\ResourceInfo; /** * Console metrics exporter. * Note that the output is human-readable JSON, not compatible with OTLP. */ -class ConsoleMetricsExporter implements MetricExporterInterface +class ConsoleMetricExporter implements PushMetricExporterInterface { /** * @var string|Temporality|null diff --git a/src/SDK/Metrics/MetricExporter/ConsoleMetricExporterFactory.php b/src/SDK/Metrics/MetricExporter/ConsoleMetricExporterFactory.php index b83a7757e..19088738d 100644 --- a/src/SDK/Metrics/MetricExporter/ConsoleMetricExporterFactory.php +++ b/src/SDK/Metrics/MetricExporter/ConsoleMetricExporterFactory.php @@ -11,6 +11,6 @@ class ConsoleMetricExporterFactory implements MetricExporterFactoryInterface { public function create(): MetricExporterInterface { - return new ConsoleMetricsExporter(); + return new ConsoleMetricExporter(); } } diff --git a/src/SDK/Metrics/MetricExporter/InMemoryExporter.php b/src/SDK/Metrics/MetricExporter/InMemoryExporter.php index cd81ba399..208e956f5 100644 --- a/src/SDK/Metrics/MetricExporter/InMemoryExporter.php +++ b/src/SDK/Metrics/MetricExporter/InMemoryExporter.php @@ -74,9 +74,4 @@ public function shutdown(): bool return true; } - - public function forceFlush(): bool - { - return !$this->closed; - } } diff --git a/src/SDK/Metrics/MetricExporter/NoopMetricExporter.php b/src/SDK/Metrics/MetricExporter/NoopMetricExporter.php index d1a1594a3..4d3c070a5 100644 --- a/src/SDK/Metrics/MetricExporter/NoopMetricExporter.php +++ b/src/SDK/Metrics/MetricExporter/NoopMetricExporter.php @@ -30,9 +30,4 @@ public function shutdown(): bool { return true; } - - public function forceFlush(): bool - { - return true; - } } diff --git a/src/SDK/Metrics/MetricExporterInterface.php b/src/SDK/Metrics/MetricExporterInterface.php index 6b4618b5b..f5964a9f6 100644 --- a/src/SDK/Metrics/MetricExporterInterface.php +++ b/src/SDK/Metrics/MetricExporterInterface.php @@ -26,6 +26,4 @@ public function temporality(MetricMetadataInterface $metric); public function export(iterable $batch): bool; public function shutdown(): bool; - - public function forceFlush(): bool; } diff --git a/src/SDK/Metrics/MetricReader/ExportingReader.php b/src/SDK/Metrics/MetricReader/ExportingReader.php index ad1f860ad..561cfd404 100644 --- a/src/SDK/Metrics/MetricReader/ExportingReader.php +++ b/src/SDK/Metrics/MetricReader/ExportingReader.php @@ -16,6 +16,7 @@ use OpenTelemetry\SDK\Metrics\MetricSourceInterface; use OpenTelemetry\SDK\Metrics\MetricSourceProviderInterface; use OpenTelemetry\SDK\Metrics\MetricSourceRegistryInterface; +use OpenTelemetry\SDK\Metrics\PushMetricExporterInterface; use OpenTelemetry\SDK\Metrics\StalenessHandlerInterface; use function spl_object_id; @@ -139,10 +140,13 @@ public function forceFlush(): bool if ($this->closed) { return false; } + if ($this->exporter instanceof PushMetricExporterInterface) { + $collect = $this->doCollect(); + $forceFlush = $this->exporter->forceFlush(); - $collect = $this->doCollect(); - $forceFlush = $this->exporter->forceFlush(); + return $collect && $forceFlush; + } - return $collect && $forceFlush; + return true; } } diff --git a/src/SDK/Metrics/PushMetricExporterInterface.php b/src/SDK/Metrics/PushMetricExporterInterface.php new file mode 100644 index 000000000..d24b0e396 --- /dev/null +++ b/src/SDK/Metrics/PushMetricExporterInterface.php @@ -0,0 +1,12 @@ +assertTrue($reader->shutdown()); } - public function test_force_flush_calls_exporter_force_flush(): void + public function test_force_flush_calls_push_exporter_force_flush(): void { - $exporter = $this->createMock(MetricExporterInterface::class); + $exporter = $this->createMock(PushMetricExporterInterface::class); $exporter->expects($this->once())->method('forceFlush')->willReturn(true); $reader = new ExportingReader($exporter); $this->assertTrue($reader->forceFlush()); } - public function test_closed_reader_does_not_call_exporter_methods(): void + public function test_force_flush_with_non_push_exporter(): void { $exporter = $this->createMock(MetricExporterInterface::class); $reader = new ExportingReader($exporter); + $this->assertTrue($reader->forceFlush()); + } + + public function test_closed_reader_does_not_call_exporter_methods(): void + { + $exporter = $this->createMock(PushMetricExporterInterface::class); + $reader = new ExportingReader($exporter); + $reader->shutdown(); $exporter->expects($this->never())->method('export');