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

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

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

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()
25
	incomingResponses := make(chan types.ResponseProgress)
26
	incomingErrors := make(chan error)
27 28
	cancelRequest := func() {}

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

	blocks := testutil.GenerateBlocksOfSize(10, 100)

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

48 49
	interimError := fmt.Errorf("A block was missing")
	terminalError := fmt.Errorf("Something terrible happened")
50 51 52 53 54 55 56 57 58 59 60
	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:
	}

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

	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")
				}
			}
		}
	}
88
}