forked from open-telemetry/opentelemetry-collector-contrib
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
processor/deltatocumulative: golden tests (open-telemetry#35562)
**Description:** <Describe what has changed.> <!--Ex. Fixing a bug - Describe the bug and how this fixes the issue. Ex. Adding a feature - Explain what this achieves.--> Rewrites most tests to use a pkg/golden like approach: - tests are directories under `testdata/` - tests consist of multiple stages, ran in series - each stage is a [txtar](https://pkg.go.dev/golang.org/x/tools/txtar), containing: - `in`: pmetric yaml of the `ConsumeMetrics` input - `out`: expected output on the sink after calling `ConsumeMetrics` The multi-stage setup allows to exercise multiple Requests in one test. Using txtar allows to co-locate common yaml easily. I plan to add metric assertions in there later too. **Link to tracking Issue:** none **Testing:** Tests were rewritten **Documentation:** not needed
- Loading branch information
1 parent
fa57c84
commit 4c9cf7b
Showing
15 changed files
with
841 additions
and
329 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
112 changes: 112 additions & 0 deletions
112
processor/deltatocumulativeprocessor/internal/testar/decode.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,112 @@ | ||
// Copyright The OpenTelemetry Authors | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
// testar is a textual archive (based on [golang.org/x/tools/txtar]) to define | ||
// test fixtures. | ||
// | ||
// Archive data is read into struct fields, optionally calling parsers for field | ||
// types other than string or []byte: | ||
// | ||
// type T struct { | ||
// Literal string `testar:"file1"` | ||
// Parsed int `testar:"file2,myparser"` | ||
// } | ||
// | ||
// var into T | ||
// err := Read(data, &into) | ||
// | ||
// See [Read] and [Parser] for examples. | ||
package testar // import "github.com/open-telemetry/opentelemetry-collector-contrib/processor/deltatocumulativeprocessor/internal/testar" | ||
|
||
import ( | ||
"fmt" | ||
"io/fs" | ||
"reflect" | ||
"strings" | ||
|
||
"golang.org/x/tools/txtar" | ||
) | ||
|
||
// Read archive data into the fields of struct *T | ||
func Read[T any](data []byte, into *T, parsers ...Format) error { | ||
ar := txtar.Parse(data) | ||
return Decode(ar, into, parsers...) | ||
} | ||
|
||
func ReadFile[T any](file string, into *T, parsers ...Format) error { | ||
ar, err := txtar.ParseFile(file) | ||
if err != nil { | ||
return err | ||
} | ||
return Decode(ar, into, parsers...) | ||
} | ||
|
||
func Decode[T any](ar *txtar.Archive, into *T, parsers ...Format) error { | ||
arfs, err := txtar.FS(ar) | ||
if err != nil { | ||
return err | ||
} | ||
|
||
pv := reflect.ValueOf(into) | ||
if pv.Kind() != reflect.Pointer { | ||
return fmt.Errorf("into must be pointer") | ||
} | ||
sv := pv.Elem() | ||
|
||
for i := range sv.NumField() { | ||
f := sv.Type().Field(i) | ||
tag := f.Tag.Get("testar") | ||
if tag == "" { | ||
continue | ||
} | ||
|
||
name, format, _ := strings.Cut(tag, ",") | ||
data, err := fs.ReadFile(arfs, name) | ||
if err != nil { | ||
return fmt.Errorf("%s: %w", name, err) | ||
} | ||
|
||
err = formats(parsers).Parse(format, data, sv.Field(i).Addr().Interface()) | ||
if err != nil { | ||
return fmt.Errorf("%s: %w", name, err) | ||
} | ||
} | ||
return nil | ||
} | ||
|
||
type formats []Format | ||
|
||
func (fmts formats) Parse(name string, data []byte, into any) error { | ||
if name == "" { | ||
return LiteralParser(data, into) | ||
} | ||
|
||
for _, f := range fmts { | ||
if f.name == name { | ||
return f.parse(data, into) | ||
} | ||
} | ||
return fmt.Errorf("no such format: %q", name) | ||
} | ||
|
||
type Format struct { | ||
name string | ||
parse func(file []byte, into any) error | ||
} | ||
|
||
func Parser(name string, fn func(data []byte, into any) error) Format { | ||
return Format{name: name, parse: fn} | ||
} | ||
|
||
// LiteralParser sets data unaltered into a []byte or string | ||
func LiteralParser(data []byte, into any) error { | ||
switch ptr := into.(type) { | ||
case *[]byte: | ||
*ptr = append([]byte(nil), data...) | ||
case *string: | ||
*ptr = string(data) | ||
default: | ||
return fmt.Errorf("pass *[]byte, *string or use a parser. got %T", into) | ||
} | ||
return nil | ||
} |
58 changes: 58 additions & 0 deletions
58
processor/deltatocumulativeprocessor/internal/testar/read_test.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
// Copyright The OpenTelemetry Authors | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
package testar | ||
|
||
import ( | ||
"fmt" | ||
"strconv" | ||
"strings" | ||
) | ||
|
||
func ExampleRead() { | ||
data := []byte(` | ||
-- foo -- | ||
hello | ||
-- bar -- | ||
world | ||
`) | ||
|
||
var into struct { | ||
Foo string `testar:"foo"` | ||
Bar []byte `testar:"bar"` | ||
} | ||
|
||
_ = Read(data, &into) | ||
fmt.Printf("foo: %T(%q)\n", into.Foo, into.Foo) | ||
fmt.Printf("bar: %T(%q)\n", into.Bar, into.Bar) | ||
|
||
// Output: | ||
// foo: string("hello\n\n") | ||
// bar: []uint8("world\n") | ||
} | ||
|
||
func ExampleParser() { | ||
data := []byte(` | ||
-- foobar -- | ||
377927 | ||
`) | ||
|
||
var into struct { | ||
Foobar int `testar:"foobar,atoi"` | ||
} | ||
|
||
_ = Read(data, &into, Parser("atoi", func(file []byte, into any) error { | ||
n, err := strconv.Atoi(strings.TrimSpace(string(file))) | ||
if err != nil { | ||
return err | ||
} | ||
*(into.(*int)) = n | ||
return nil | ||
})) | ||
|
||
fmt.Printf("foobar: %T(%d)\n", into.Foobar, into.Foobar) | ||
|
||
// Output: | ||
// foobar: int(377927) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.