+/*
+GoVPN -- simple secure free software virtual private network daemon
+Copyright (C) 2014-2016 Sergey Matveev <stargrave@stargrave.org>
+
+This program is free software: you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation, either version 3 of the License, or
+(at your option) any later version.
+
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program. If not, see <http://www.gnu.org/licenses/>.
+*/
+
package govpn
import (
"testing"
+ "testing/quick"
"time"
)
}
func init() {
- MTU = 1500
- peerId, _ = IDDecode("ffffffffffffffffffffffffffffffff")
+ id := new([IDSize]byte)
+ peerId := PeerId(*id)
conf = &PeerConf{
- Id: peerId,
- Timeout: time.Second * time.Duration(TimeoutDefault),
- NoiseEnable: false,
- CPR: 0,
+ Id: &peerId,
+ MTU: MTUDefault,
+ Timeout: time.Second * time.Duration(TimeoutDefault),
}
peer = newPeer(true, "foo", Dummy{&ciphertext}, conf, new([SSize]byte))
plaintext = make([]byte, 789)
}
+func TestSymmetric(t *testing.T) {
+ peerd := newPeer(true, "foo", Dummy{nil}, conf, new([SSize]byte))
+ f := func(payload []byte) bool {
+ if len(payload) == 0 {
+ return true
+ }
+ peer.EthProcess(payload)
+ return peerd.PktProcess(ciphertext, Dummy{nil}, true)
+ }
+ if err := quick.Check(f, nil); err != nil {
+ t.Error(err)
+ }
+}
+
+func TestSymmetricNoise(t *testing.T) {
+ peerd := newPeer(true, "foo", Dummy{nil}, conf, new([SSize]byte))
+ peer.NoiseEnable = true
+ peerd.NoiseEnable = true
+ f := func(payload []byte) bool {
+ if len(payload) == 0 {
+ return true
+ }
+ peer.EthProcess(payload)
+ return peerd.PktProcess(ciphertext, Dummy{nil}, true)
+ }
+ if err := quick.Check(f, nil); err != nil {
+ t.Error(err)
+ }
+ peer.NoiseEnable = true
+}
+
+func TestSymmetricEncLess(t *testing.T) {
+ peerd := newPeer(true, "foo", Dummy{nil}, conf, new([SSize]byte))
+ peer.EncLess = true
+ peer.NoiseEnable = true
+ peerd.EncLess = true
+ peerd.NoiseEnable = true
+ f := func(payload []byte) bool {
+ if len(payload) == 0 {
+ return true
+ }
+ peer.EthProcess(payload)
+ return peerd.PktProcess(ciphertext, Dummy{nil}, true)
+ }
+ if err := quick.Check(f, nil); err != nil {
+ t.Error(err)
+ }
+ peer.NoiseEnable = false
+ peer.EncLess = false
+}
+
func BenchmarkEnc(b *testing.B) {
b.ResetTimer()
for i := 0; i < b.N; i++ {