208 lines
5.3 KiB
Go
208 lines
5.3 KiB
Go
// Copyright (C) MongoDB, Inc. 2017-present.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
// not use this file except in compliance with the License. You may obtain
|
|
// a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
package bson
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"reflect"
|
|
"testing"
|
|
|
|
"gitea.psichedelico.com/go/bson/internal/assert"
|
|
"gitea.psichedelico.com/go/bson/x/bsonx/bsoncore"
|
|
)
|
|
|
|
func TestRawValue(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("Unmarshal", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("Uses registry attached to value", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
reg := newTestRegistry()
|
|
val := RawValue{Type: TypeString, Value: bsoncore.AppendString(nil, "foobar"), r: reg}
|
|
var s string
|
|
want := errNoDecoder{Type: reflect.TypeOf(s)}
|
|
got := val.Unmarshal(&s)
|
|
if !assert.CompareErrors(got, want) {
|
|
t.Errorf("Expected errors to match. got %v; want %v", got, want)
|
|
}
|
|
})
|
|
t.Run("Uses default registry if no registry attached", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
want := "foobar"
|
|
val := RawValue{Type: TypeString, Value: bsoncore.AppendString(nil, want)}
|
|
var got string
|
|
err := val.Unmarshal(&got)
|
|
noerr(t, err)
|
|
if got != want {
|
|
t.Errorf("Expected strings to match. got %s; want %s", got, want)
|
|
}
|
|
})
|
|
})
|
|
t.Run("UnmarshalWithRegistry", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("Returns error when registry is nil", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
want := ErrNilRegistry
|
|
var val RawValue
|
|
got := val.UnmarshalWithRegistry(nil, &D{})
|
|
if !errors.Is(got, want) {
|
|
t.Errorf("Expected errors to match. got %v; want %v", got, want)
|
|
}
|
|
})
|
|
t.Run("Returns lookup error", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
reg := newTestRegistry()
|
|
var val RawValue
|
|
var s string
|
|
want := errNoDecoder{Type: reflect.TypeOf(s)}
|
|
got := val.UnmarshalWithRegistry(reg, &s)
|
|
if !assert.CompareErrors(got, want) {
|
|
t.Errorf("Expected errors to match. got %v; want %v", got, want)
|
|
}
|
|
})
|
|
t.Run("Returns DecodeValue error", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
reg := NewRegistry()
|
|
val := RawValue{Type: TypeDouble, Value: bsoncore.AppendDouble(nil, 3.14159)}
|
|
var s string
|
|
want := fmt.Errorf("cannot decode %v into a string type", TypeDouble)
|
|
got := val.UnmarshalWithRegistry(reg, &s)
|
|
if !assert.CompareErrors(got, want) {
|
|
t.Errorf("Expected errors to match. got %v; want %v", got, want)
|
|
}
|
|
})
|
|
t.Run("Success", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
reg := NewRegistry()
|
|
want := float64(3.14159)
|
|
val := RawValue{Type: TypeDouble, Value: bsoncore.AppendDouble(nil, want)}
|
|
var got float64
|
|
err := val.UnmarshalWithRegistry(reg, &got)
|
|
noerr(t, err)
|
|
if got != want {
|
|
t.Errorf("Expected results to match. got %g; want %g", got, want)
|
|
}
|
|
})
|
|
})
|
|
t.Run("UnmarshalWithContext", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("Returns error when DecodeContext is nil", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
want := ErrNilContext
|
|
var val RawValue
|
|
got := val.UnmarshalWithContext(nil, &D{})
|
|
if !errors.Is(got, want) {
|
|
t.Errorf("Expected errors to match. got %v; want %v", got, want)
|
|
}
|
|
})
|
|
t.Run("Returns lookup error", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
dc := DecodeContext{Registry: newTestRegistry()}
|
|
var val RawValue
|
|
var s string
|
|
want := errNoDecoder{Type: reflect.TypeOf(s)}
|
|
got := val.UnmarshalWithContext(&dc, &s)
|
|
if !assert.CompareErrors(got, want) {
|
|
t.Errorf("Expected errors to match. got %v; want %v", got, want)
|
|
}
|
|
})
|
|
t.Run("Returns DecodeValue error", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
dc := DecodeContext{Registry: NewRegistry()}
|
|
val := RawValue{Type: TypeDouble, Value: bsoncore.AppendDouble(nil, 3.14159)}
|
|
var s string
|
|
want := fmt.Errorf("cannot decode %v into a string type", TypeDouble)
|
|
got := val.UnmarshalWithContext(&dc, &s)
|
|
if !assert.CompareErrors(got, want) {
|
|
t.Errorf("Expected errors to match. got %v; want %v", got, want)
|
|
}
|
|
})
|
|
t.Run("Success", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
dc := DecodeContext{Registry: NewRegistry()}
|
|
want := float64(3.14159)
|
|
val := RawValue{Type: TypeDouble, Value: bsoncore.AppendDouble(nil, want)}
|
|
var got float64
|
|
err := val.UnmarshalWithContext(&dc, &got)
|
|
noerr(t, err)
|
|
if got != want {
|
|
t.Errorf("Expected results to match. got %g; want %g", got, want)
|
|
}
|
|
})
|
|
})
|
|
|
|
t.Run("IsZero", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
tests := []struct {
|
|
name string
|
|
val RawValue
|
|
want bool
|
|
}{
|
|
{
|
|
name: "empty",
|
|
val: RawValue{},
|
|
want: true,
|
|
},
|
|
{
|
|
name: "zero type but non-zero value",
|
|
val: RawValue{
|
|
Type: 0x00,
|
|
Value: bsoncore.AppendInt32(nil, 0),
|
|
},
|
|
want: false,
|
|
},
|
|
{
|
|
name: "zero type and zero value",
|
|
val: RawValue{
|
|
Type: 0x00,
|
|
Value: bsoncore.AppendInt32(nil, 0),
|
|
},
|
|
},
|
|
{
|
|
name: "non-zero type and non-zero value",
|
|
val: RawValue{
|
|
Type: TypeString,
|
|
Value: bsoncore.AppendString(nil, "foobar"),
|
|
},
|
|
want: false,
|
|
},
|
|
{
|
|
name: "non-zero type and zero value",
|
|
val: RawValue{
|
|
Type: TypeString,
|
|
Value: bsoncore.AppendString(nil, "foobar"),
|
|
},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
tt := tt // Capture the range variable
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
assert.Equal(t, tt.want, tt.val.IsZero())
|
|
})
|
|
}
|
|
})
|
|
}
|