/* Copyright 2014 The Camlistore Authors 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 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ package blobserver_test import ( "errors" "strconv" "testing" "camlistore.org/pkg/blob" "camlistore.org/pkg/blobserver" "camlistore.org/pkg/blobserver/storagetest" "camlistore.org/pkg/test" "golang.org/x/net/context" ) type staticStreamer []*blob.Blob func (s staticStreamer) StreamBlobs(ctx context.Context, dest chan<- blobserver.BlobAndToken, contToken string) error { defer close(dest) var pos int if contToken != "" { var err error pos, err = strconv.Atoi(contToken) if err != nil || pos < 0 || pos >= len(s) { return errors.New("invalid token") } s = s[pos:] } for len(s) > 0 { select { case dest <- blobserver.BlobAndToken{Blob: s[0], Token: strconv.Itoa(pos)}: pos++ s = s[1:] case <-ctx.Done(): return ctx.Err() } } return nil } func TestStaticStreamer(t *testing.T) { var blobs []*blob.Blob var want []blob.SizedRef for i := 0; i < 5; i++ { tb := &test.Blob{strconv.Itoa(i)} b := tb.Blob() blobs = append(blobs, b) want = append(want, b.SizedRef()) } bs := staticStreamer(blobs) storagetest.TestStreamer(t, bs, storagetest.WantSizedRefs(want)) } func TestMultiStreamer(t *testing.T) { var streamers []blobserver.BlobStreamer var want []blob.SizedRef n := 0 for st := 0; st < 3; st++ { var blobs []*blob.Blob for i := 0; i < 3; i++ { n++ tb := &test.Blob{strconv.Itoa(n)} b := tb.Blob() want = append(want, b.SizedRef()) // overall blobs = append(blobs, b) // this sub-streamer } streamers = append(streamers, staticStreamer(blobs)) } storagetest.TestStreamer(t, blobserver.NewMultiBlobStreamer(streamers...), storagetest.WantSizedRefs(want)) }