From 1c8f90259d82207143be94e220ec5cd51039ca52 Mon Sep 17 00:00:00 2001 From: Brett McBride Date: Thu, 18 Apr 2024 16:06:19 +1000 Subject: [PATCH] fixing warnings from local build A couple of warnings have popped up recently: - docker compose 'version' is deprecated - BSD host id test was running a command that doesn't exist, which was visible in test output (removed test case) - synchronous metric stream test was triggering a warnings which was visible in test output (changed to use LogsMessagesTrait) - resource merging with different schema URLs was triggering a warnings from Config test (updated yaml schema_url and documented) --- docker-compose.yaml | 1 - script/semantic-conventions/README.md | 5 +++++ src/SDK/Metrics/Stream/SynchronousMetricStream.php | 7 ++++--- src/SDK/Resource/Detectors/Host.php | 6 +++--- .../Integration/Config/configurations/kitchen-sink.yaml | 2 +- tests/Unit/SDK/Resource/Detectors/HostTest.php | 9 ++++----- 6 files changed, 17 insertions(+), 13 deletions(-) diff --git a/docker-compose.yaml b/docker-compose.yaml index c42349ea1..fe5b35647 100644 --- a/docker-compose.yaml +++ b/docker-compose.yaml @@ -1,4 +1,3 @@ -version: '3.7' services: php: image: ghcr.io/open-telemetry/opentelemetry-php/opentelemetry-php-base:${PHP_VERSION:-8.1} diff --git a/script/semantic-conventions/README.md b/script/semantic-conventions/README.md index 2166b3833..98b9bf13b 100644 --- a/script/semantic-conventions/README.md +++ b/script/semantic-conventions/README.md @@ -31,3 +31,8 @@ diff <(grep "public const" src/SemConv/TraceAttributes.php | sort -u) \ ``` Use this output as a basis for updating the relevant deprecations file and generate a second time to include them in the final output. + +## Update tests + +Update `tests/Integration/Config/configurations/kitchen-sink.yaml`'s `resource.schema_url` value to the latest, as merging resources +with different schema URLs is a merging error, per spec. \ No newline at end of file diff --git a/src/SDK/Metrics/Stream/SynchronousMetricStream.php b/src/SDK/Metrics/Stream/SynchronousMetricStream.php index 80bbdc7dc..2e1290402 100644 --- a/src/SDK/Metrics/Stream/SynchronousMetricStream.php +++ b/src/SDK/Metrics/Stream/SynchronousMetricStream.php @@ -5,18 +5,17 @@ namespace OpenTelemetry\SDK\Metrics\Stream; use function assert; -use const E_USER_WARNING; use function extension_loaded; use GMP; use function gmp_init; use function is_int; +use OpenTelemetry\API\Behavior\LogsMessagesTrait; use OpenTelemetry\SDK\Metrics\AggregationInterface; use OpenTelemetry\SDK\Metrics\Data\DataInterface; use OpenTelemetry\SDK\Metrics\Data\Exemplar; use OpenTelemetry\SDK\Metrics\Data\Temporality; use const PHP_INT_SIZE; use function sprintf; -use function trigger_error; /** * @internal @@ -24,6 +23,8 @@ */ final class SynchronousMetricStream implements MetricStreamInterface { + use LogsMessagesTrait; + private readonly DeltaStorage $delta; private int|GMP $readers = 0; private int|GMP $cumulative = 0; @@ -62,7 +63,7 @@ public function register($temporality): int if ($reader === (PHP_INT_SIZE << 3) - 1 && is_int($this->readers)) { if (!extension_loaded('gmp')) { - trigger_error(sprintf('GMP extension required to register over %d readers', (PHP_INT_SIZE << 3) - 1), E_USER_WARNING); + self::logWarning(sprintf('GMP extension required to register over %d readers', (PHP_INT_SIZE << 3) - 1)); $reader = PHP_INT_SIZE << 3; } else { assert(is_int($this->cumulative)); diff --git a/src/SDK/Resource/Detectors/Host.php b/src/SDK/Resource/Detectors/Host.php index af5082778..6024c44e2 100644 --- a/src/SDK/Resource/Detectors/Host.php +++ b/src/SDK/Resource/Detectors/Host.php @@ -68,7 +68,7 @@ private function getBsdId(): ?string $out = exec('kenv -q smbios.system.uuid'); - if ($out != false) { + if ($out !== false) { return $out; } @@ -79,7 +79,7 @@ private function getMacOsId(): ?string { $out = exec('ioreg -rd1 -c IOPlatformExpertDevice | awk \'/IOPlatformUUID/ { split($0, line, "\""); printf("%s\n", line[4]); }\''); - if ($out != false) { + if ($out !== false) { return $out; } @@ -90,7 +90,7 @@ private function getWindowsId(): ?string { $out = exec('powershell.exe -Command "Get-ItemPropertyValue -Path HKLM:\SOFTWARE\Microsoft\Cryptography -Name MachineGuid"'); - if ($out != false) { + if ($out !== false) { return $out; } diff --git a/tests/Integration/Config/configurations/kitchen-sink.yaml b/tests/Integration/Config/configurations/kitchen-sink.yaml index c331f6891..cb82e3862 100644 --- a/tests/Integration/Config/configurations/kitchen-sink.yaml +++ b/tests/Integration/Config/configurations/kitchen-sink.yaml @@ -349,4 +349,4 @@ resource: # Environment variable: OTEL_SERVICE_NAME service.name: !!str "unknown_service" # Configure the resource schema URL. - schema_url: https://opentelemetry.io/schemas/1.23.1 + schema_url: https://opentelemetry.io/schemas/1.25.0 diff --git a/tests/Unit/SDK/Resource/Detectors/HostTest.php b/tests/Unit/SDK/Resource/Detectors/HostTest.php index 2bcddfddd..589a48453 100644 --- a/tests/Unit/SDK/Resource/Detectors/HostTest.php +++ b/tests/Unit/SDK/Resource/Detectors/HostTest.php @@ -16,8 +16,8 @@ class HostTest extends TestCase { public function test_host_get_resource(): void { - $resouceDetector = new Detectors\Host(); - $resource = $resouceDetector->getResource(); + $resourceDetector = new Detectors\Host(); + $resource = $resourceDetector->getResource(); $this->assertSame(ResourceAttributes::SCHEMA_URL, $resource->getSchemaUrl()); $this->assertIsString($resource->getAttributes()->get(ResourceAttributes::HOST_NAME)); @@ -30,8 +30,8 @@ public function test_host_get_resource(): void public function test_host_id_filesystem(string $os, array $files, ?string $expectedId): void { $root = vfsStream::setup('/', null, $files); - $resouceDetector = new Detectors\Host($root->url(), $os); - $resource = $resouceDetector->getResource(); + $resourceDetector = new Detectors\Host($root->url(), $os); + $resource = $resourceDetector->getResource(); if ($expectedId === null) { $this->assertFalse($resource->getAttributes()->has(ResourceAttributes::HOST_ID)); @@ -71,7 +71,6 @@ public static function hostIdData(): array ['Linux', $etc_machineid, '1234567890'], ['Linux', array_merge($etc_machineid, $varLibDbus), '1234567890'], ['Linux', $etc_machineid, '1234567890'], - ['BSD', [], null], ['BSD', $etc_hostid, '1234567890'], ]; }