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
|
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package ai.vespa.metricsproxy.metric.model.json;
import ai.vespa.metricsproxy.metric.model.MetricsPacket;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.node.ArrayNode;
import org.junit.Test;
import java.io.IOException;
import java.util.List;
import java.util.Set;
import static ai.vespa.metricsproxy.core.VespaMetrics.vespaMetricsConsumerId;
import static ai.vespa.metricsproxy.http.ValuesFetcher.defaultMetricsConsumerId;
import static ai.vespa.metricsproxy.metric.model.ServiceId.toServiceId;
import static ai.vespa.metricsproxy.metric.model.json.JacksonUtil.objectMapper;
import static ai.vespa.metricsproxy.metric.model.json.YamasJsonUtil.YAMAS_ROUTING;
import static ai.vespa.metricsproxy.metric.model.json.YamasJsonUtil.toMetricsPackets;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
/**
* @author gjoranv
*/
public class YamasJsonUtilTest {
private static JsonNode metrics(MetricsPacket packet, boolean addStatus) throws IOException {
return metrics(List.of(packet), addStatus).get(0);
}
private static ArrayNode metrics(List<MetricsPacket> packets, boolean addStatus) throws IOException {
return (ArrayNode) objectMapper().readTree(YamasJsonUtil.toJson(packets, addStatus)).get("metrics");
}
@Test
public void status_is_included_in_json_model_when_explicitly_asked_for() throws IOException {
ArrayNode json = metrics(List.of(new MetricsPacket.Builder(toServiceId("foo")).build(),
new MetricsPacket.Builder(toServiceId("bar")).build()), true);
assertTrue(json.get(0).has("status_code"));
assertTrue(json.get(0).has("status_msg"));
assertTrue(json.get(1).has("status_code"));
assertTrue(json.get(1).has("status_msg"));
}
@Test
public void timestamp_0_in_packet_is_translated_to_null_in_json_model() throws IOException {
MetricsPacket packet = new MetricsPacket.Builder(toServiceId("foo")).timestamp(0L).build();
JsonNode json = metrics(packet, true);
assertFalse(json.has("timestamp"));
}
@Test
public void empty_consumers_is_translated_to_null_routing_in_json_model() throws IOException {
MetricsPacket packet = new MetricsPacket.Builder(toServiceId("foo")).build();
JsonNode json = metrics(packet, true);
assertFalse(json.has("routing"));
}
@Test
public void default_public_consumer_is_filtered_from_yamas_routing() throws IOException {
MetricsPacket packet = new MetricsPacket.Builder(toServiceId("foo"))
.addConsumers(Set.of(vespaMetricsConsumerId, defaultMetricsConsumerId))
.build();
JsonNode json = metrics(packet, false);
JsonNode routing = json.get("routing");
JsonNode yamas = routing.get(YAMAS_ROUTING);
ArrayNode namespaces = (ArrayNode) yamas.get("namespaces");
assertEquals(1, namespaces.size());
assertEquals(vespaMetricsConsumerId.id, namespaces.get(0).asText());
}
@Test
public void only_default_public_consumer_yields_null_routing_in_json_model() throws IOException {
MetricsPacket packet = new MetricsPacket.Builder(toServiceId("foo"))
.addConsumers(Set.of(defaultMetricsConsumerId))
.build();
JsonNode json = metrics(packet, false);
assertFalse(json.has(YAMAS_ROUTING));
}
@Test
public void empty_json_string_yields_empty_packet_list() {
List<MetricsPacket.Builder> builders = toMetricsPackets("");
assertTrue(builders.isEmpty());
}
}
|