2019-02-25 22:44:14 +00:00
|
|
|
package stall
|
|
|
|
|
|
|
|
import (
|
2019-02-26 17:28:38 +00:00
|
|
|
"sync"
|
2019-02-25 22:44:14 +00:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
|
|
|
"github.com/CityOfZion/neo-go/pkg/wire/command"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestAddRemoveMessage(t *testing.T) {
|
|
|
|
|
VM: Add basic vm (#166)
* VM:Add abstract stack item
* VM: Add stackItems; Array, Boolean, Int and ByteArray
* VM: Add tests for stack item
* VM: first pass at Random Access Stack object
* VM: Add Sub, Mul, Mod LSH, RSH
* VM: moved test helper functions into separate file
* VM: removed helper functions from stack_test.go
* Add conversions for bytearray and Int stack items
* Add instructions file for vm
* - Add guide to stack readme
- Add testReadInt64
* Add Builder
* Refactor Int, Boolean, ByteArray conversion
* Add Context stack Item
* Add Invocation stack - convenience RAS
* rename testhelper to test_helper
* Move opcode file
* - Add `Add` OpCode
- Add Opcode Function map
* - Add test for math `Add` opcode
- basic opcode execution
* Add popTwoIntegers convenience func
* Add `SUB` Opcode
* Export Context Read methods
- Return errors where failable
* - Add `Op` to handleOP func signature
- Add PushNBytes OPcode
* remove error on NewBoolean
- Expose underlying with Getter on Boolean StackItem
- Add Equals method for ByteArray
* Make Next() method on Context failable, refactor peekContext and Peek
* Add ExecuteOp, Step and Run methods on the VM
* Add Equal Opcode
* Add THROWIFNOT Opcode
* Add RET Opcode
* Refactor PushNBytes Opcode
* refactor Add, Sub to return VMSTATE
add popTwoByteArrays helper function
* Add basic tests for vm
* clarify vm states
* Add astack
* [VM]
Pass ResultStack to the opcode handlers
* [VM]
refactor handlers to have rstack as argument
* [Stack]
- Change RemoveCurrentContext for PopCurrentContext
- Add CopTo method to stack
* [VM]
Add Result stack Len check in simple run test
* [VM] fix typo
* [Peer/Stall]
Change seconds to milliseconds in test
2019-03-18 21:40:21 +00:00
|
|
|
responseTime := 2 * time.Millisecond
|
|
|
|
tickerInterval := 1 * time.Millisecond
|
2019-02-25 22:44:14 +00:00
|
|
|
|
|
|
|
d := NewDetector(responseTime, tickerInterval)
|
|
|
|
d.AddMessage(command.GetAddr)
|
|
|
|
mp := d.GetMessages()
|
|
|
|
|
|
|
|
assert.Equal(t, 1, len(mp))
|
|
|
|
assert.IsType(t, time.Time{}, mp[command.GetAddr])
|
|
|
|
|
2019-03-28 19:09:55 +00:00
|
|
|
d.RemoveMessage(command.Addr)
|
2019-02-25 22:44:14 +00:00
|
|
|
mp = d.GetMessages()
|
|
|
|
|
|
|
|
assert.Equal(t, 0, len(mp))
|
|
|
|
assert.Empty(t, mp[command.GetAddr])
|
|
|
|
}
|
|
|
|
|
|
|
|
type mockPeer struct {
|
2019-02-26 17:28:38 +00:00
|
|
|
lock *sync.RWMutex
|
2019-02-25 22:44:14 +00:00
|
|
|
online bool
|
|
|
|
detector *Detector
|
|
|
|
}
|
|
|
|
|
|
|
|
func (mp *mockPeer) loop() {
|
|
|
|
loop:
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case <-mp.detector.Quitch:
|
|
|
|
|
|
|
|
break loop
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// cleanup
|
2019-02-26 17:28:38 +00:00
|
|
|
mp.lock.Lock()
|
2019-02-25 22:44:14 +00:00
|
|
|
mp.online = false
|
2019-02-26 17:28:38 +00:00
|
|
|
mp.lock.Unlock()
|
2019-02-25 22:44:14 +00:00
|
|
|
}
|
|
|
|
func TestDeadlineWorks(t *testing.T) {
|
|
|
|
|
VM: Add basic vm (#166)
* VM:Add abstract stack item
* VM: Add stackItems; Array, Boolean, Int and ByteArray
* VM: Add tests for stack item
* VM: first pass at Random Access Stack object
* VM: Add Sub, Mul, Mod LSH, RSH
* VM: moved test helper functions into separate file
* VM: removed helper functions from stack_test.go
* Add conversions for bytearray and Int stack items
* Add instructions file for vm
* - Add guide to stack readme
- Add testReadInt64
* Add Builder
* Refactor Int, Boolean, ByteArray conversion
* Add Context stack Item
* Add Invocation stack - convenience RAS
* rename testhelper to test_helper
* Move opcode file
* - Add `Add` OpCode
- Add Opcode Function map
* - Add test for math `Add` opcode
- basic opcode execution
* Add popTwoIntegers convenience func
* Add `SUB` Opcode
* Export Context Read methods
- Return errors where failable
* - Add `Op` to handleOP func signature
- Add PushNBytes OPcode
* remove error on NewBoolean
- Expose underlying with Getter on Boolean StackItem
- Add Equals method for ByteArray
* Make Next() method on Context failable, refactor peekContext and Peek
* Add ExecuteOp, Step and Run methods on the VM
* Add Equal Opcode
* Add THROWIFNOT Opcode
* Add RET Opcode
* Refactor PushNBytes Opcode
* refactor Add, Sub to return VMSTATE
add popTwoByteArrays helper function
* Add basic tests for vm
* clarify vm states
* Add astack
* [VM]
Pass ResultStack to the opcode handlers
* [VM]
refactor handlers to have rstack as argument
* [Stack]
- Change RemoveCurrentContext for PopCurrentContext
- Add CopTo method to stack
* [VM]
Add Result stack Len check in simple run test
* [VM] fix typo
* [Peer/Stall]
Change seconds to milliseconds in test
2019-03-18 21:40:21 +00:00
|
|
|
responseTime := 2 * time.Millisecond
|
|
|
|
tickerInterval := 1 * time.Millisecond
|
2019-02-25 22:44:14 +00:00
|
|
|
|
|
|
|
d := NewDetector(responseTime, tickerInterval)
|
2019-02-26 17:28:38 +00:00
|
|
|
mp := mockPeer{online: true, detector: d, lock: new(sync.RWMutex)}
|
2019-02-25 22:44:14 +00:00
|
|
|
go mp.loop()
|
|
|
|
|
|
|
|
d.AddMessage(command.GetAddr)
|
VM: Add basic vm (#166)
* VM:Add abstract stack item
* VM: Add stackItems; Array, Boolean, Int and ByteArray
* VM: Add tests for stack item
* VM: first pass at Random Access Stack object
* VM: Add Sub, Mul, Mod LSH, RSH
* VM: moved test helper functions into separate file
* VM: removed helper functions from stack_test.go
* Add conversions for bytearray and Int stack items
* Add instructions file for vm
* - Add guide to stack readme
- Add testReadInt64
* Add Builder
* Refactor Int, Boolean, ByteArray conversion
* Add Context stack Item
* Add Invocation stack - convenience RAS
* rename testhelper to test_helper
* Move opcode file
* - Add `Add` OpCode
- Add Opcode Function map
* - Add test for math `Add` opcode
- basic opcode execution
* Add popTwoIntegers convenience func
* Add `SUB` Opcode
* Export Context Read methods
- Return errors where failable
* - Add `Op` to handleOP func signature
- Add PushNBytes OPcode
* remove error on NewBoolean
- Expose underlying with Getter on Boolean StackItem
- Add Equals method for ByteArray
* Make Next() method on Context failable, refactor peekContext and Peek
* Add ExecuteOp, Step and Run methods on the VM
* Add Equal Opcode
* Add THROWIFNOT Opcode
* Add RET Opcode
* Refactor PushNBytes Opcode
* refactor Add, Sub to return VMSTATE
add popTwoByteArrays helper function
* Add basic tests for vm
* clarify vm states
* Add astack
* [VM]
Pass ResultStack to the opcode handlers
* [VM]
refactor handlers to have rstack as argument
* [Stack]
- Change RemoveCurrentContext for PopCurrentContext
- Add CopTo method to stack
* [VM]
Add Result stack Len check in simple run test
* [VM] fix typo
* [Peer/Stall]
Change seconds to milliseconds in test
2019-03-18 21:40:21 +00:00
|
|
|
time.Sleep(responseTime + 1*time.Millisecond)
|
2019-02-25 22:44:14 +00:00
|
|
|
|
|
|
|
k := make(map[command.Type]time.Time)
|
2019-02-26 17:28:38 +00:00
|
|
|
d.lock.RLock()
|
2019-02-25 22:44:14 +00:00
|
|
|
assert.Equal(t, k, d.responses)
|
2019-02-26 17:28:38 +00:00
|
|
|
d.lock.RUnlock()
|
|
|
|
mp.lock.RLock()
|
2019-02-25 22:44:14 +00:00
|
|
|
assert.Equal(t, false, mp.online)
|
2019-02-26 17:28:38 +00:00
|
|
|
mp.lock.RUnlock()
|
2019-02-25 22:44:14 +00:00
|
|
|
}
|
|
|
|
func TestDeadlineShouldNotBeEmpty(t *testing.T) {
|
VM: Add basic vm (#166)
* VM:Add abstract stack item
* VM: Add stackItems; Array, Boolean, Int and ByteArray
* VM: Add tests for stack item
* VM: first pass at Random Access Stack object
* VM: Add Sub, Mul, Mod LSH, RSH
* VM: moved test helper functions into separate file
* VM: removed helper functions from stack_test.go
* Add conversions for bytearray and Int stack items
* Add instructions file for vm
* - Add guide to stack readme
- Add testReadInt64
* Add Builder
* Refactor Int, Boolean, ByteArray conversion
* Add Context stack Item
* Add Invocation stack - convenience RAS
* rename testhelper to test_helper
* Move opcode file
* - Add `Add` OpCode
- Add Opcode Function map
* - Add test for math `Add` opcode
- basic opcode execution
* Add popTwoIntegers convenience func
* Add `SUB` Opcode
* Export Context Read methods
- Return errors where failable
* - Add `Op` to handleOP func signature
- Add PushNBytes OPcode
* remove error on NewBoolean
- Expose underlying with Getter on Boolean StackItem
- Add Equals method for ByteArray
* Make Next() method on Context failable, refactor peekContext and Peek
* Add ExecuteOp, Step and Run methods on the VM
* Add Equal Opcode
* Add THROWIFNOT Opcode
* Add RET Opcode
* Refactor PushNBytes Opcode
* refactor Add, Sub to return VMSTATE
add popTwoByteArrays helper function
* Add basic tests for vm
* clarify vm states
* Add astack
* [VM]
Pass ResultStack to the opcode handlers
* [VM]
refactor handlers to have rstack as argument
* [Stack]
- Change RemoveCurrentContext for PopCurrentContext
- Add CopTo method to stack
* [VM]
Add Result stack Len check in simple run test
* [VM] fix typo
* [Peer/Stall]
Change seconds to milliseconds in test
2019-03-18 21:40:21 +00:00
|
|
|
responseTime := 10 * time.Millisecond
|
|
|
|
tickerInterval := 1 * time.Millisecond
|
2019-02-25 22:44:14 +00:00
|
|
|
|
|
|
|
d := NewDetector(responseTime, tickerInterval)
|
|
|
|
d.AddMessage(command.GetAddr)
|
VM: Add basic vm (#166)
* VM:Add abstract stack item
* VM: Add stackItems; Array, Boolean, Int and ByteArray
* VM: Add tests for stack item
* VM: first pass at Random Access Stack object
* VM: Add Sub, Mul, Mod LSH, RSH
* VM: moved test helper functions into separate file
* VM: removed helper functions from stack_test.go
* Add conversions for bytearray and Int stack items
* Add instructions file for vm
* - Add guide to stack readme
- Add testReadInt64
* Add Builder
* Refactor Int, Boolean, ByteArray conversion
* Add Context stack Item
* Add Invocation stack - convenience RAS
* rename testhelper to test_helper
* Move opcode file
* - Add `Add` OpCode
- Add Opcode Function map
* - Add test for math `Add` opcode
- basic opcode execution
* Add popTwoIntegers convenience func
* Add `SUB` Opcode
* Export Context Read methods
- Return errors where failable
* - Add `Op` to handleOP func signature
- Add PushNBytes OPcode
* remove error on NewBoolean
- Expose underlying with Getter on Boolean StackItem
- Add Equals method for ByteArray
* Make Next() method on Context failable, refactor peekContext and Peek
* Add ExecuteOp, Step and Run methods on the VM
* Add Equal Opcode
* Add THROWIFNOT Opcode
* Add RET Opcode
* Refactor PushNBytes Opcode
* refactor Add, Sub to return VMSTATE
add popTwoByteArrays helper function
* Add basic tests for vm
* clarify vm states
* Add astack
* [VM]
Pass ResultStack to the opcode handlers
* [VM]
refactor handlers to have rstack as argument
* [Stack]
- Change RemoveCurrentContext for PopCurrentContext
- Add CopTo method to stack
* [VM]
Add Result stack Len check in simple run test
* [VM] fix typo
* [Peer/Stall]
Change seconds to milliseconds in test
2019-03-18 21:40:21 +00:00
|
|
|
time.Sleep(1 * time.Millisecond)
|
2019-02-25 22:44:14 +00:00
|
|
|
|
|
|
|
k := make(map[command.Type]time.Time)
|
2019-02-26 17:28:38 +00:00
|
|
|
d.lock.RLock()
|
2019-02-25 22:44:14 +00:00
|
|
|
assert.NotEqual(t, k, d.responses)
|
2019-02-26 17:28:38 +00:00
|
|
|
d.lock.RUnlock()
|
2019-02-25 22:44:14 +00:00
|
|
|
}
|