mirror of
https://github.com/cloudflare/cloudflared.git
synced 2025-06-04 12:16:59 +00:00
124 lines
2.6 KiB
Go
124 lines
2.6 KiB
Go
package fulfiller
|
|
|
|
import (
|
|
"errors"
|
|
"testing"
|
|
|
|
"zombiezen.com/go/capnproto2"
|
|
)
|
|
|
|
func TestFulfiller_NewShouldBeUnresolved(t *testing.T) {
|
|
f := new(Fulfiller)
|
|
|
|
if a := f.Peek(); a != nil {
|
|
t.Errorf("f.Peek() = %v; want nil", a)
|
|
}
|
|
select {
|
|
case <-f.Done():
|
|
t.Error("Done closed early")
|
|
default:
|
|
// success
|
|
}
|
|
}
|
|
|
|
func TestFulfiller_FulfillShouldResolve(t *testing.T) {
|
|
f := new(Fulfiller)
|
|
st := newStruct(t, capnp.ObjectSize{})
|
|
|
|
f.Fulfill(st)
|
|
|
|
select {
|
|
case <-f.Done():
|
|
default:
|
|
t.Error("Done still closed after Fulfill")
|
|
}
|
|
ret, err := f.Struct()
|
|
if err != nil {
|
|
t.Errorf("f.Struct() error: %v", err)
|
|
}
|
|
if ret != st {
|
|
t.Errorf("f.Struct() = %v; want %v", ret, st)
|
|
}
|
|
}
|
|
|
|
func TestFulfiller_RejectShouldResolve(t *testing.T) {
|
|
f := new(Fulfiller)
|
|
e := errors.New("failure and rejection")
|
|
|
|
f.Reject(e)
|
|
|
|
select {
|
|
case <-f.Done():
|
|
default:
|
|
t.Error("Done still closed after Reject")
|
|
}
|
|
ret, err := f.Struct()
|
|
if err != e {
|
|
t.Errorf("f.Struct() error = %v; want %v", err, e)
|
|
}
|
|
if capnp.IsValid(ret) {
|
|
t.Errorf("f.Struct() = %v; want null", ret)
|
|
}
|
|
}
|
|
|
|
func TestFulfiller_QueuedCallsDeliveredInOrder(t *testing.T) {
|
|
f := new(Fulfiller)
|
|
oc := new(orderClient)
|
|
result := newStruct(t, capnp.ObjectSize{PointerCount: 1})
|
|
in := result.Segment().Message().AddCap(oc)
|
|
result.SetPointer(0, capnp.NewInterface(result.Segment(), in))
|
|
|
|
ans1 := f.PipelineCall([]capnp.PipelineOp{{Field: 0}}, new(capnp.Call))
|
|
ans2 := f.PipelineCall([]capnp.PipelineOp{{Field: 0}}, new(capnp.Call))
|
|
f.Fulfill(result)
|
|
ans3 := f.PipelineCall([]capnp.PipelineOp{{Field: 0}}, new(capnp.Call))
|
|
ans3.Struct()
|
|
ans4 := f.PipelineCall([]capnp.PipelineOp{{Field: 0}}, new(capnp.Call))
|
|
|
|
check := func(a capnp.Answer, n uint64) {
|
|
r, err := a.Struct()
|
|
if r.Uint64(0) != n {
|
|
t.Errorf("r%d = %d; want %d", n+1, r.Uint64(0), n)
|
|
}
|
|
if err != nil {
|
|
t.Errorf("err%d = %v", n+1, err)
|
|
}
|
|
}
|
|
check(ans1, 0)
|
|
check(ans2, 1)
|
|
check(ans3, 2)
|
|
check(ans4, 3)
|
|
}
|
|
|
|
func newStruct(t *testing.T, sz capnp.ObjectSize) capnp.Struct {
|
|
_, s, err := capnp.NewMessage(capnp.SingleSegment(nil))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
st, err := capnp.NewStruct(s, sz)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
return st
|
|
}
|
|
|
|
type orderClient int
|
|
|
|
func (oc *orderClient) Call(cl *capnp.Call) capnp.Answer {
|
|
_, s, err := capnp.NewMessage(capnp.SingleSegment(nil))
|
|
if err != nil {
|
|
return capnp.ErrorAnswer(err)
|
|
}
|
|
st, err := capnp.NewStruct(s, capnp.ObjectSize{DataSize: 8})
|
|
if err != nil {
|
|
return capnp.ErrorAnswer(err)
|
|
}
|
|
st.SetUint64(0, uint64(*oc))
|
|
*oc++
|
|
return capnp.ImmediateAnswer(st)
|
|
}
|
|
|
|
func (oc *orderClient) Close() error {
|
|
return nil
|
|
}
|