(t *testing.T)
| 120 | } |
| 121 | |
| 122 | func TestTraceToParquet(t *testing.T) { |
| 123 | strPtr := func(s string) *string { return &s } |
| 124 | intPtr := func(i int64) *int64 { return &i } |
| 125 | |
| 126 | meta := backend.BlockMeta{DedicatedColumns: test.MakeDedicatedColumns()} |
| 127 | traceID := common.ID{0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F} |
| 128 | |
| 129 | tsc := []struct { |
| 130 | name string |
| 131 | id common.ID |
| 132 | trace tempopb.Trace |
| 133 | expected Trace |
| 134 | }{ |
| 135 | { |
| 136 | name: "span and resource attributes", |
| 137 | id: traceID, |
| 138 | trace: tempopb.Trace{ |
| 139 | ResourceSpans: []*v1_trace.ResourceSpans{{ |
| 140 | Resource: &v1_resource.Resource{ |
| 141 | Attributes: []*v1.KeyValue{ |
| 142 | {Key: "res.attr", Value: &v1.AnyValue{Value: &v1.AnyValue_IntValue{IntValue: 123}}}, |
| 143 | {Key: "service.name", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "service-a"}}}, |
| 144 | {Key: "cluster", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "cluster-a"}}}, |
| 145 | {Key: "namespace", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "namespace-a"}}}, |
| 146 | {Key: "pod", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "pod-a"}}}, |
| 147 | {Key: "container", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "container-a"}}}, |
| 148 | {Key: "k8s.cluster.name", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "k8s-cluster-a"}}}, |
| 149 | {Key: "k8s.namespace.name", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "k8s-namespace-a"}}}, |
| 150 | {Key: "k8s.pod.name", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "k8s-pod-a"}}}, |
| 151 | {Key: "k8s.container.name", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "k8s-container-a"}}}, |
| 152 | {Key: "dedicated.resource.1", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "dedicated-resource-attr-value-1"}}}, |
| 153 | {Key: "dedicated.resource.2", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "dedicated-resource-attr-value-2"}}}, |
| 154 | {Key: "dedicated.resource.3", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "dedicated-resource-attr-value-3"}}}, |
| 155 | {Key: "dedicated.resource.4", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "dedicated-resource-attr-value-4"}}}, |
| 156 | {Key: "dedicated.resource.5", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "dedicated-resource-attr-value-5"}}}, |
| 157 | }, |
| 158 | }, |
| 159 | ScopeSpans: []*v1_trace.ScopeSpans{{ |
| 160 | Scope: &v1.InstrumentationScope{}, |
| 161 | Spans: []*v1_trace.Span{{ |
| 162 | Name: "span-a", |
| 163 | SpanId: common.ID{0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01}, |
| 164 | Attributes: []*v1.KeyValue{ |
| 165 | {Key: "span.attr", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "aaa"}}}, |
| 166 | {Key: "http.method", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "POST"}}}, |
| 167 | {Key: "http.url", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "https://example.com"}}}, |
| 168 | {Key: "http.status_code", Value: &v1.AnyValue{Value: &v1.AnyValue_IntValue{IntValue: 201}}}, |
| 169 | {Key: "dedicated.span.1", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "dedicated-span-attr-value-1"}}}, |
| 170 | {Key: "dedicated.span.2", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "dedicated-span-attr-value-2"}}}, |
| 171 | {Key: "dedicated.span.3", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "dedicated-span-attr-value-3"}}}, |
| 172 | {Key: "dedicated.span.4", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: "dedicated-span-attr-value-4"}}}, |
| 173 | {Key: "dedicated.span.5", Value: &v1.AnyValue{Value: &v1.AnyValue_StringValue{StringValue: test.DedicatedBlobTestString()}}}, |
| 174 | }, |
| 175 | }}, |
| 176 | }}, |
| 177 | }}, |
| 178 | }, |
| 179 | expected: Trace{ |
nothing calls this directly
no test coverage detected