summaryrefslogtreecommitdiff
path: root/vendor/jonahgeorge/jaeger-client-php/tests/Jaeger/Sender/JaegerThriftSenderTest.php
blob: 5bd6d0a7b6c90f1eaadc5390cd8561ffafb1629a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
<?php


namespace Jaeger\Tests\Sender;

use Jaeger\Sender\JaegerSender;
use Jaeger\Sender\UdpSender;
use Jaeger\Span;
use Jaeger\SpanContext;
use Jaeger\Thrift\Agent\AgentClient;
use Jaeger\Thrift\Batch;
use Jaeger\Tracer;
use PHPUnit\Framework\TestCase;

class JaegerThriftSenderTest extends TestCase
{
    /** @var Tracer|\PHPUnit\Framework\MockObject\MockObject  */
    private $tracer;

    /** @var SpanContext|\PHPUnit\Framework\MockObject\MockObject  */
    private $context;

    public function setUp(): void
    {
        $tracer = $this->createMock(Tracer::class);
        $tracer->method('getIpAddress')->willReturn('');
        $tracer->method('getServiceName')->willReturn('');

        $this->tracer = $tracer;

        $context = $this->createMock(SpanContext::class);
        $this->context = $context;
    }

    public function testFlush(): void
    {

        $span = $this->createMock(Span::class);
        $span->method('getOperationName')->willReturn('dummy-operation');
        $span->method('getTracer')->willReturn($this->tracer);
        $span->method('getContext')->willReturn($this->context);

        $client = $this->createMock(AgentClient::class);
        $sender = new JaegerSender($client);
        $sender->setMaxBufferLength(64000);

        $client
            ->expects(self::exactly(1))
            ->method('emitBatch');

        $sender->append($span);
        $sender->append($span);
        $sender->append($span);

        self::assertEquals(3, $sender->flush());
    }

    public function testEmitBatch() {
        $client = $this->createMock(AgentClient::class);
        $sender = new JaegerSender($client);
        $sender->setMaxBufferLength(64000);

        $span = $this->createMock(Span::class);
        $span->method('getOperationName')->willReturn('dummy-operation');
        $span->method('getTracer')->willReturn($this->tracer);
        $span->method('getContext')->willReturn($this->context);

        $client
            ->expects($this->once())
            ->method('emitBatch')
            ->with($this->callback(function ($batch) {
                /** @var Batch $batch */
                $this->assertInstanceOf(Batch::class, $batch);
                $this->assertCount(1, $batch->spans);

                /** @var \Jaeger\Thrift\Span $span */
                $span = $batch->spans[0];
                $this->assertInstanceOf(\Jaeger\Thrift\Span::class, $span);
                $this->assertSame("dummy-operation", $span->operationName);

                return true;

            }));

        $sender->append($span);
        $this->assertEquals(1, $sender->flush());
    }

    public function testMaxBufferLength() {
        $tracer = $this->createMock(Tracer::class);
        $tracer->method('getIpAddress')->willReturn('');
        $tracer->method('getServiceName')->willReturn('');

        $context = $this->createMock(SpanContext::class);

        $span = $this->createMock(Span::class);
        $span->method('getOperationName')->willReturn('dummy-operation');
        $span->method('getTracer')->willReturn($tracer);
        $span->method('getContext')->willReturn($context);

        $client = $this->createMock(AgentClient::class);

        $mockBuilder = $this->getMockBuilder(JaegerSender::class);
        $mockMethods = ['emitJaegerBatch'];
        if (method_exists($mockBuilder, "onlyMethods")) {
            $mockBuilder = $mockBuilder->onlyMethods($mockMethods);
        } else {
            $mockBuilder = $mockBuilder->setMethods($mockMethods);
        }
        $sender = $mockBuilder->setConstructorArgs([$client])->getMock();
        $sender->setMaxBufferLength(800);
        $sender->expects(self::exactly(2))
            ->method('emitJaegerBatch')
            ->withConsecutive(
                [self::countOf(2)],
                [self::countOf(1)]
            );

        // jaeger batch overhead parameter = 512
        $sender->append($span); // 512 + 143 < 800 - chunk 1
        $sender->append($span); // 512 + 143*2 => 798 < 800 - chunk 1
        $sender->append($span); // 512 + 143*3 > 800 - chunk 2

        self::assertEquals(3, $sender->flush());
    }
}