2019-05-29 16:18:20 +00:00
|
|
|
/* SPDX-License-Identifier: MIT
|
|
|
|
*
|
2020-05-02 08:08:26 +00:00
|
|
|
* Copyright (C) 2017-2020 WireGuard LLC. All Rights Reserved.
|
2019-05-29 16:18:20 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
package device
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"golang.zx2c4.com/wireguard/tun"
|
|
|
|
)
|
|
|
|
|
|
|
|
// newDummyTUN creates a dummy TUN device with the specified name.
|
2019-06-10 21:33:40 +00:00
|
|
|
func newDummyTUN(name string) tun.Device {
|
2019-05-29 16:18:20 +00:00
|
|
|
return &dummyTUN{
|
|
|
|
name: name,
|
|
|
|
packets: make(chan []byte, 100),
|
2019-06-10 21:33:40 +00:00
|
|
|
events: make(chan tun.Event, 10),
|
2019-05-29 16:18:20 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-10 21:33:40 +00:00
|
|
|
// A dummyTUN is a tun.Device which is used in unit tests.
|
2019-05-29 16:18:20 +00:00
|
|
|
type dummyTUN struct {
|
|
|
|
name string
|
|
|
|
mtu int
|
|
|
|
packets chan []byte
|
2019-06-10 21:33:40 +00:00
|
|
|
events chan tun.Event
|
2019-05-29 16:18:20 +00:00
|
|
|
}
|
|
|
|
|
2019-06-10 21:33:40 +00:00
|
|
|
func (d *dummyTUN) Events() chan tun.Event { return d.events }
|
|
|
|
func (*dummyTUN) File() *os.File { return nil }
|
|
|
|
func (*dummyTUN) Flush() error { return nil }
|
|
|
|
func (d *dummyTUN) MTU() (int, error) { return d.mtu, nil }
|
|
|
|
func (d *dummyTUN) Name() (string, error) { return d.name, nil }
|
2019-05-29 16:18:20 +00:00
|
|
|
|
|
|
|
func (d *dummyTUN) Close() error {
|
|
|
|
close(d.events)
|
|
|
|
close(d.packets)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (d *dummyTUN) Read(b []byte, offset int) (int, error) {
|
|
|
|
buf, ok := <-d.packets
|
|
|
|
if !ok {
|
|
|
|
return 0, errors.New("device closed")
|
|
|
|
}
|
|
|
|
copy(b[offset:], buf)
|
|
|
|
return len(buf), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (d *dummyTUN) Write(b []byte, offset int) (int, error) {
|
|
|
|
d.packets <- b[offset:]
|
|
|
|
return len(b), nil
|
|
|
|
}
|