blob: 8f9af7b02def30d23278fbdfe60631dda21ef547 (
plain) (
blame)
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
|
package kamon.trace
import kamon.trace.IdentityProvider.Identifier
import org.scalatest.{Matchers, OptionValues, WordSpecLike}
import org.scalactic.TimesOnInt._
class DefaultIdentityGeneratorSpec extends WordSpecLike with Matchers with OptionValues {
val idProvider = IdentityProvider.Default()
val traceGenerator = idProvider.traceIdGenerator()
val spanGenerator = idProvider.spanIdGenerator()
validateGenerator("TraceID Generator", traceGenerator)
validateGenerator("SpanID Generator", spanGenerator)
def validateGenerator(generatorName: String, generator: IdentityProvider.Generator) = {
s"The $generatorName" should {
"generate random longs (8 byte) identifiers" in {
100 times {
val Identifier(string, bytes) = generator.generate()
string.length should be(16)
bytes.length should be(8)
}
}
"decode the string representation back into a identifier" in {
100 times {
val identifier = generator.generate()
val decodedIdentifier = generator.from(identifier.string)
identifier.string should equal(decodedIdentifier.string)
identifier.bytes should equal(decodedIdentifier.bytes)
}
}
"decode the bytes representation back into a identifier" in {
100 times {
val identifier = generator.generate()
val decodedIdentifier = generator.from(identifier.bytes)
identifier.string should equal(decodedIdentifier.string)
identifier.bytes should equal(decodedIdentifier.bytes)
}
}
"return IdentityProvider.NoIdentifier if the provided input cannot be decoded into a Identifier" in {
generator.from("zzzz") shouldBe(IdentityProvider.NoIdentifier)
generator.from(Array[Byte](1)) shouldBe(IdentityProvider.NoIdentifier)
}
}
}
}
|