|
6 | 6 | import threading |
7 | 7 |
|
8 | 8 | from ddtrace.tracer import Tracer |
9 | | -from ddtrace.sampler import RateSampler, ThroughputSampler |
| 9 | +from ddtrace.sampler import RateSampler, ThroughputSampler, SAMPLE_RATE_METRIC_KEY |
10 | 10 | from .test_tracer import DummyWriter |
11 | 11 | from .util import patch_time |
12 | 12 |
|
13 | 13 |
|
14 | 14 | class RateSamplerTest(unittest.TestCase): |
15 | 15 |
|
16 | | - def test_random_sequence(self): |
| 16 | + def test_sample_rate_deviation(self): |
17 | 17 | writer = DummyWriter() |
18 | | - tracer = Tracer() |
19 | | - tracer.writer = writer |
20 | | - tracer.sampler = RateSampler(0.5) |
21 | | - |
22 | | - # Set the seed so that the choice of sampled traces |
23 | | - # is deterministic, then write tests accordingly |
24 | | - random.seed(4012) |
25 | | - |
26 | | - # First trace, sampled |
27 | | - with tracer.trace("foo") as s: |
28 | | - assert s.sampled |
29 | | - assert s.weight == 2 |
30 | | - assert writer.pop() |
31 | | - |
32 | | - # Second trace, not sampled |
33 | | - with tracer.trace("figh") as s: |
34 | | - assert not s.sampled |
35 | | - s2 = tracer.trace("what") |
36 | | - assert not s2.sampled |
37 | | - s2.finish() |
38 | | - with tracer.trace("ever") as s3: |
39 | | - assert not s3.sampled |
40 | | - s4 = tracer.trace("!") |
41 | | - assert not s4.sampled |
42 | | - s4.finish() |
43 | | - spans = writer.pop() |
44 | | - assert not spans, spans |
45 | | - |
46 | | - # Third trace, not sampled |
47 | | - with tracer.trace("ters") as s: |
48 | | - assert s.sampled |
49 | | - assert writer.pop() |
| 18 | + |
| 19 | + for sample_rate in [0.1, 0.25, 0.5, 1]: |
| 20 | + tracer = Tracer() |
| 21 | + tracer.writer = writer |
| 22 | + |
| 23 | + sample_rate = 0.5 |
| 24 | + tracer.sampler = RateSampler(sample_rate) |
| 25 | + |
| 26 | + random.seed(1234) |
| 27 | + |
| 28 | + iterations = int(2e4) |
| 29 | + |
| 30 | + for i in range(iterations): |
| 31 | + span = tracer.trace(i) |
| 32 | + span.finish() |
| 33 | + |
| 34 | + samples = writer.pop() |
| 35 | + |
| 36 | + # We must have at least 1 sample, check that it has its sample rate properly assigned |
| 37 | + assert samples[0].get_metric(SAMPLE_RATE_METRIC_KEY) == 0.5 |
| 38 | + |
| 39 | + # Less than 1% deviation when "enough" iterations (arbitrary, just check if it converges) |
| 40 | + deviation = abs(len(samples) - (iterations * sample_rate)) / (iterations * sample_rate) |
| 41 | + assert deviation < 0.01, "Deviation too high %f with sample_rate %f" % (deviation, sample_rate) |
50 | 42 |
|
51 | 43 |
|
52 | 44 | class ThroughputSamplerTest(unittest.TestCase): |
|
0 commit comments