|
3 | 3 |
|
4 | 4 | #include <gtest/gtest.h> |
5 | 5 | #include <stdint.h> |
| 6 | +#include <stdlib.h> |
6 | 7 | #include <atomic> |
7 | 8 | #include <chrono> |
8 | 9 | #include <cstddef> |
|
21 | 22 | #include "opentelemetry/nostd/variant.h" |
22 | 23 | #include "opentelemetry/sdk/common/exporter_utils.h" |
23 | 24 | #include "opentelemetry/sdk/logs/batch_log_record_processor.h" |
| 25 | +#include "opentelemetry/sdk/logs/batch_log_record_processor_options.h" |
24 | 26 | #include "opentelemetry/sdk/logs/exporter.h" |
25 | 27 | #include "opentelemetry/sdk/logs/processor.h" |
26 | 28 | #include "opentelemetry/sdk/logs/recordable.h" |
27 | 29 |
|
| 30 | +#if defined(_MSC_VER) |
| 31 | +# include "opentelemetry/sdk/common/env_variables.h" |
| 32 | +using opentelemetry::sdk::common::setenv; |
| 33 | +using opentelemetry::sdk::common::unsetenv; |
| 34 | +#endif |
| 35 | + |
28 | 36 | using namespace opentelemetry::sdk::logs; |
29 | 37 | using namespace opentelemetry::sdk::common; |
30 | 38 |
|
@@ -355,3 +363,77 @@ TEST_F(BatchLogRecordProcessorTest, TestScheduledDelayMillis) |
355 | 363 | EXPECT_EQ("Log" + std::to_string(i), logs_received->at(i)->GetBody()); |
356 | 364 | } |
357 | 365 | } |
| 366 | + |
| 367 | +TEST_F(BatchLogRecordProcessorTest, TestDefaultValues) |
| 368 | +{ |
| 369 | + BatchLogRecordProcessorOptions options; |
| 370 | + |
| 371 | + EXPECT_EQ(options.max_queue_size, static_cast<size_t>(2048)); |
| 372 | + EXPECT_EQ(options.schedule_delay_millis, std::chrono::milliseconds(1000)); |
| 373 | + EXPECT_EQ(options.export_timeout_millis, std::chrono::milliseconds(30000)); |
| 374 | + EXPECT_EQ(options.max_export_batch_size, static_cast<size_t>(512)); |
| 375 | +} |
| 376 | + |
| 377 | +TEST_F(BatchLogRecordProcessorTest, TestMaxQueueSizeFromEnv) |
| 378 | +{ |
| 379 | + setenv("OTEL_BLRP_MAX_QUEUE_SIZE", "1234", 1); |
| 380 | + |
| 381 | + BatchLogRecordProcessorOptions options; |
| 382 | + |
| 383 | + EXPECT_EQ(options.max_queue_size, static_cast<size_t>(1234)); |
| 384 | + |
| 385 | + unsetenv("OTEL_BLRP_MAX_QUEUE_SIZE"); |
| 386 | +} |
| 387 | + |
| 388 | +TEST_F(BatchLogRecordProcessorTest, TestScheduleDelayFromEnv) |
| 389 | +{ |
| 390 | + setenv("OTEL_BLRP_SCHEDULE_DELAY", "7s", 1); |
| 391 | + |
| 392 | + BatchLogRecordProcessorOptions options; |
| 393 | + |
| 394 | + EXPECT_EQ(options.schedule_delay_millis, std::chrono::milliseconds(7000)); |
| 395 | + |
| 396 | + unsetenv("OTEL_BLRP_SCHEDULE_DELAY"); |
| 397 | +} |
| 398 | + |
| 399 | +TEST_F(BatchLogRecordProcessorTest, TestExportTimeoutFromEnv) |
| 400 | +{ |
| 401 | + setenv("OTEL_BLRP_EXPORT_TIMEOUT", "250ms", 1); |
| 402 | + |
| 403 | + BatchLogRecordProcessorOptions options; |
| 404 | + |
| 405 | + EXPECT_EQ(options.export_timeout_millis, std::chrono::milliseconds(250)); |
| 406 | + |
| 407 | + unsetenv("OTEL_BLRP_EXPORT_TIMEOUT"); |
| 408 | +} |
| 409 | + |
| 410 | +TEST_F(BatchLogRecordProcessorTest, TestMaxExportBatchSizeFromEnv) |
| 411 | +{ |
| 412 | + setenv("OTEL_BLRP_MAX_EXPORT_BATCH_SIZE", "42", 1); |
| 413 | + |
| 414 | + BatchLogRecordProcessorOptions options; |
| 415 | + |
| 416 | + EXPECT_EQ(options.max_export_batch_size, static_cast<size_t>(42)); |
| 417 | + |
| 418 | + unsetenv("OTEL_BLRP_MAX_EXPORT_BATCH_SIZE"); |
| 419 | +} |
| 420 | + |
| 421 | +TEST_F(BatchLogRecordProcessorTest, TestOptionsReadFromMultipleEnvVars) |
| 422 | +{ |
| 423 | + setenv("OTEL_BLRP_MAX_QUEUE_SIZE", "3000", 1); |
| 424 | + setenv("OTEL_BLRP_SCHEDULE_DELAY", "2s", 1); |
| 425 | + setenv("OTEL_BLRP_EXPORT_TIMEOUT", "1s", 1); |
| 426 | + setenv("OTEL_BLRP_MAX_EXPORT_BATCH_SIZE", "256", 1); |
| 427 | + |
| 428 | + BatchLogRecordProcessorOptions options; |
| 429 | + |
| 430 | + EXPECT_EQ(options.max_queue_size, static_cast<size_t>(3000)); |
| 431 | + EXPECT_EQ(options.schedule_delay_millis, std::chrono::milliseconds(2000)); |
| 432 | + EXPECT_EQ(options.export_timeout_millis, std::chrono::milliseconds(1000)); |
| 433 | + EXPECT_EQ(options.max_export_batch_size, static_cast<size_t>(256)); |
| 434 | + |
| 435 | + unsetenv("OTEL_BLRP_MAX_QUEUE_SIZE"); |
| 436 | + unsetenv("OTEL_BLRP_SCHEDULE_DELAY"); |
| 437 | + unsetenv("OTEL_BLRP_EXPORT_TIMEOUT"); |
| 438 | + unsetenv("OTEL_BLRP_MAX_EXPORT_BATCH_SIZE"); |
| 439 | +} |
0 commit comments