Fix Err fallout for graph/iterator.Or iterator
This commit is contained in:
parent
40cbbfcc1b
commit
aaa3f27754
2 changed files with 54 additions and 0 deletions
|
|
@ -15,6 +15,7 @@
|
|||
package iterator
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"reflect"
|
||||
"testing"
|
||||
|
||||
|
|
@ -148,3 +149,46 @@ func TestShortCircuitingOrBasics(t *testing.T) {
|
|||
t.Errorf("Failed to iterate optimized Or correctly, got:%v expect:%v", got, expect)
|
||||
}
|
||||
}
|
||||
|
||||
func TestOrIteratorErr(t *testing.T) {
|
||||
retErr := errors.New("unique")
|
||||
orErr := newTestIterator(false, retErr)
|
||||
|
||||
fix1 := NewFixed(Identity)
|
||||
fix1.Add(1)
|
||||
|
||||
or := NewOr()
|
||||
or.AddSubIterator(fix1)
|
||||
or.AddSubIterator(orErr)
|
||||
or.AddSubIterator(NewInt64(1, 5))
|
||||
|
||||
if !or.Next() {
|
||||
t.Errorf("Failed to iterate Or correctly")
|
||||
}
|
||||
if got := or.Result(); got != 1 {
|
||||
t.Errorf("Failed to iterate Or correctly, got:%v expect:1", got)
|
||||
}
|
||||
|
||||
if or.Next() != false {
|
||||
t.Errorf("Or iterator did not pass through underlying 'false'")
|
||||
}
|
||||
if or.Err() != retErr {
|
||||
t.Errorf("Or iterator did not pass through underlying Err")
|
||||
}
|
||||
}
|
||||
|
||||
func TestShortCircuitOrIteratorErr(t *testing.T) {
|
||||
retErr := errors.New("unique")
|
||||
orErr := newTestIterator(false, retErr)
|
||||
|
||||
or := NewOr()
|
||||
or.AddSubIterator(orErr)
|
||||
or.AddSubIterator(NewInt64(1, 5))
|
||||
|
||||
if or.Next() != false {
|
||||
t.Errorf("Or iterator did not pass through underlying 'false'")
|
||||
}
|
||||
if or.Err() != retErr {
|
||||
t.Errorf("Or iterator did not pass through underlying Err")
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue