responsecollector_test.go 2.18 KB
Newer Older
1 2 3 4
package requestmanager

import (
	"context"
5 6
	"fmt"
	"reflect"
7 8 9
	"testing"
	"time"

10 11 12 13
	"github.com/ipfs/go-graphsync/testbridge"
	ipld "github.com/ipld/go-ipld-prime"
	"github.com/ipld/go-ipld-prime/linking/cid"

14 15 16 17 18 19 20 21 22 23 24
	"github.com/ipfs/go-graphsync/testutil"
)

func TestBufferingResponseProgress(t *testing.T) {
	backgroundCtx := context.Background()
	ctx, cancel := context.WithTimeout(backgroundCtx, time.Second)
	defer cancel()
	rc := newResponseCollector(ctx)
	requestCtx, requestCancel := context.WithCancel(backgroundCtx)
	defer requestCancel()
	incomingResponses := make(chan ResponseProgress)
25
	incomingErrors := make(chan error)
26 27
	cancelRequest := func() {}

28 29
	outgoingResponses, outgoingErrors := rc.collectResponses(
		requestCtx, incomingResponses, incomingErrors, cancelRequest)
30 31 32 33 34 35 36

	blocks := testutil.GenerateBlocksOfSize(10, 100)

	for _, block := range blocks {
		select {
		case <-ctx.Done():
			t.Fatal("should have written to channel but couldn't")
37 38 39 40 41 42 43
		case incomingResponses <- ResponseProgress{
			Node: testbridge.NewMockBlockNode(block.RawData()),
			LastBlock: struct {
				ipld.Path
				ipld.Link
			}{ipld.Path{}, cidlink.Link{Cid: block.Cid()}},
		}:
44 45 46
		}
	}

47 48
	interimError := fmt.Errorf("A block was missing")
	terminalError := fmt.Errorf("Something terrible happened")
49 50 51 52 53 54 55 56 57 58 59
	select {
	case <-ctx.Done():
		t.Fatal("should have written error to channel but didn't")
	case incomingErrors <- interimError:
	}
	select {
	case <-ctx.Done():
		t.Fatal("should have written error to channel but didn't")
	case incomingErrors <- terminalError:
	}

60 61 62 63
	for _, block := range blocks {
		select {
		case <-ctx.Done():
			t.Fatal("should have read from channel but couldn't")
64 65
		case testResponse := <-outgoingResponses:
			if testResponse.LastBlock.Link.(cidlink.Link).Cid != block.Cid() {
66 67 68 69
				t.Fatal("stored blocks incorrectly")
			}
		}
	}
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86

	for i := 0; i < 2; i++ {
		select {
		case <-ctx.Done():
			t.Fatal("should have read from channel but couldn't")
		case testErr := <-outgoingErrors:
			if i == 0 {
				if !reflect.DeepEqual(testErr, interimError) {
					t.Fatal("incorrect error message sent")
				}
			} else {
				if !reflect.DeepEqual(testErr, terminalError) {
					t.Fatal("incorrect error message sent")
				}
			}
		}
	}
87
}