unwrap: perform consistency check in SessionIterator
C# servers with SessionEnabled=false will return iterator IDs and no session IDs which can be reported as an error immediately because the iterator can't be traversed.
This commit is contained in:
parent
37619743ad
commit
689331b960
2 changed files with 7 additions and 1 deletions
|
@ -155,6 +155,9 @@ func SessionIterator(r *result.Invoke, err error) (uuid.UUID, result.Iterator, e
|
||||||
if !ok {
|
if !ok {
|
||||||
return uuid.UUID{}, result.Iterator{}, errors.New("the item is InteropInterface, but not an Iterator")
|
return uuid.UUID{}, result.Iterator{}, errors.New("the item is InteropInterface, but not an Iterator")
|
||||||
}
|
}
|
||||||
|
if (r.Session == uuid.UUID{}) && iter.ID != nil {
|
||||||
|
return uuid.UUID{}, result.Iterator{}, errors.New("server returned iterator ID, but no session ID")
|
||||||
|
}
|
||||||
return r.Session, iter, nil
|
return r.Session, iter, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -197,8 +197,11 @@ func TestSessionIterator(t *testing.T) {
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
|
|
||||||
iid := uuid.New()
|
iid := uuid.New()
|
||||||
sid := uuid.New()
|
|
||||||
iter := result.Iterator{ID: &iid}
|
iter := result.Iterator{ID: &iid}
|
||||||
|
_, _, err = SessionIterator(&result.Invoke{State: "HALT", Stack: []stackitem.Item{stackitem.NewInterop(iter)}}, nil)
|
||||||
|
require.Error(t, err)
|
||||||
|
|
||||||
|
sid := uuid.New()
|
||||||
rs, ri, err := SessionIterator(&result.Invoke{Session: sid, State: "HALT", Stack: []stackitem.Item{stackitem.NewInterop(iter)}}, nil)
|
rs, ri, err := SessionIterator(&result.Invoke{Session: sid, State: "HALT", Stack: []stackitem.Item{stackitem.NewInterop(iter)}}, nil)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, sid, rs)
|
require.Equal(t, sid, rs)
|
||||||
|
|
Loading…
Reference in a new issue