Move tests into a separate directory
Also run these tests on Github Actions as part of the PR request flow.
This commit is contained in:
parent
a2e93278c1
commit
1907b11545
6 changed files with 68 additions and 95 deletions
3
.github/workflows/build-rust.yml
vendored
3
.github/workflows/build-rust.yml
vendored
|
|
@ -60,3 +60,6 @@ jobs:
|
||||||
- name: Build
|
- name: Build
|
||||||
shell: bash
|
shell: bash
|
||||||
run: cargo build --verbose --workspace --all-features --target ${{ join(matrix.targets, ' --target ') }}
|
run: cargo build --verbose --workspace --all-features --target ${{ join(matrix.targets, ' --target ') }}
|
||||||
|
- name: Post-Build Tests
|
||||||
|
shell: bash
|
||||||
|
run: cargo test
|
||||||
|
|
|
||||||
|
|
@ -156,32 +156,3 @@ impl TunInterface {
|
||||||
.map_err(|_| Error::new(ErrorKind::Other, "Conversion error"))?
|
.map_err(|_| Error::new(ErrorKind::Other, "Conversion error"))?
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
|
||||||
mod test {
|
|
||||||
use super::*;
|
|
||||||
use std::net::Ipv4Addr;
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn mtu() {
|
|
||||||
let interf = TunInterface::new().unwrap();
|
|
||||||
|
|
||||||
interf.set_mtu(500).unwrap();
|
|
||||||
|
|
||||||
assert_eq!(interf.mtu().unwrap(), 500);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
#[throws]
|
|
||||||
fn netmask() {
|
|
||||||
let interf = TunInterface::new()?;
|
|
||||||
|
|
||||||
let netmask = Ipv4Addr::new(255, 0, 0, 0);
|
|
||||||
let addr = Ipv4Addr::new(192, 168, 1, 1);
|
|
||||||
|
|
||||||
interf.set_ipv4_addr(addr)?;
|
|
||||||
interf.set_netmask(netmask)?;
|
|
||||||
|
|
||||||
assert_eq!(interf.netmask()?, netmask);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -172,32 +172,3 @@ impl TunInterface {
|
||||||
self.socket.send(buf)?
|
self.socket.send(buf)?
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
|
||||||
mod test {
|
|
||||||
use super::TunInterface;
|
|
||||||
use std::net::Ipv4Addr;
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn mtu() {
|
|
||||||
let interf = TunInterface::new().unwrap();
|
|
||||||
|
|
||||||
interf.set_mtu(500).unwrap();
|
|
||||||
|
|
||||||
assert_eq!(interf.mtu().unwrap(), 500);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
#[throws]
|
|
||||||
fn netmask() {
|
|
||||||
let interf = TunInterface::new()?;
|
|
||||||
|
|
||||||
let netmask = Ipv4Addr::new(255, 0, 0, 0);
|
|
||||||
let addr = Ipv4Addr::new(192, 168, 1, 1);
|
|
||||||
|
|
||||||
interf.set_ipv4_addr(addr)?;
|
|
||||||
interf.set_netmask(netmask)?;
|
|
||||||
|
|
||||||
assert_eq!(interf.netmask()?, netmask);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -62,38 +62,3 @@ pub fn string_to_ifname(name: &str) -> [libc::c_char; libc::IFNAMSIZ] {
|
||||||
buf[..len].copy_from_slice(unsafe { &*(name.as_bytes() as *const _ as *const [libc::c_char]) });
|
buf[..len].copy_from_slice(unsafe { &*(name.as_bytes() as *const _ as *const [libc::c_char]) });
|
||||||
buf
|
buf
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
|
||||||
mod test {
|
|
||||||
|
|
||||||
use super::*;
|
|
||||||
|
|
||||||
use std::net::Ipv4Addr;
|
|
||||||
|
|
||||||
#[throws]
|
|
||||||
#[test]
|
|
||||||
fn tst_read() {
|
|
||||||
// This test is interactive, you need to send a packet to any server through 192.168.1.10
|
|
||||||
// EG. `sudo route add 8.8.8.8 192.168.1.10`,
|
|
||||||
//`dig @8.8.8.8 hackclub.com`
|
|
||||||
let mut tun = TunInterface::new()?;
|
|
||||||
println!("tun name: {:?}", tun.name()?);
|
|
||||||
tun.set_ipv4_addr(Ipv4Addr::from([192, 168, 1, 10]))?;
|
|
||||||
println!("tun ip: {:?}", tun.ipv4_addr()?);
|
|
||||||
println!("Waiting for a packet...");
|
|
||||||
let buf = &mut [0u8; 1500];
|
|
||||||
let res = tun.recv(buf);
|
|
||||||
println!("Received!");
|
|
||||||
assert!(res.is_ok());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
#[throws]
|
|
||||||
fn write_packets() {
|
|
||||||
let tun = TunInterface::new()?;
|
|
||||||
let mut buf = [0u8; 1500];
|
|
||||||
buf[0] = 6 << 4;
|
|
||||||
let bytes_written = tun.send(&buf)?;
|
|
||||||
assert_eq!(bytes_written, 1504);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -11,6 +11,7 @@ fn test_create() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[throws]
|
#[throws]
|
||||||
|
#[cfg(not(target_os = "windows"))]
|
||||||
fn test_set_get_ipv4() {
|
fn test_set_get_ipv4() {
|
||||||
let tun = TunInterface::new()?;
|
let tun = TunInterface::new()?;
|
||||||
|
|
||||||
|
|
@ -23,7 +24,7 @@ fn test_set_get_ipv4() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[throws]
|
#[throws]
|
||||||
#[cfg(target_os = "linux")]
|
#[cfg(not(any(target_os = "windows", target_vendor = "apple")))]
|
||||||
fn test_set_get_ipv6() {
|
fn test_set_get_ipv6() {
|
||||||
let tun = TunInterface::new()?;
|
let tun = TunInterface::new()?;
|
||||||
|
|
||||||
|
|
@ -33,3 +34,29 @@ fn test_set_get_ipv6() {
|
||||||
// let result = tun.ipv6_addr()?;
|
// let result = tun.ipv6_addr()?;
|
||||||
// assert_eq!(addr, result);
|
// assert_eq!(addr, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
#[throws]
|
||||||
|
#[cfg(not(target_os = "windows"))]
|
||||||
|
fn test_set_get_mtu() {
|
||||||
|
let interf = TunInterface::new()?;
|
||||||
|
|
||||||
|
interf.set_mtu(500)?;
|
||||||
|
|
||||||
|
assert_eq!(interf.mtu().unwrap(), 500);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
#[throws]
|
||||||
|
#[cfg(not(target_os = "windows"))]
|
||||||
|
fn test_set_get_netmask() {
|
||||||
|
let interf = TunInterface::new()?;
|
||||||
|
|
||||||
|
let netmask = Ipv4Addr::new(255, 0, 0, 0);
|
||||||
|
let addr = Ipv4Addr::new(192, 168, 1, 1);
|
||||||
|
|
||||||
|
interf.set_ipv4_addr(addr)?;
|
||||||
|
interf.set_netmask(netmask)?;
|
||||||
|
|
||||||
|
assert_eq!(interf.netmask()?, netmask);
|
||||||
|
}
|
||||||
|
|
|
||||||
36
tun/tests/packets.rs
Normal file
36
tun/tests/packets.rs
Normal file
|
|
@ -0,0 +1,36 @@
|
||||||
|
use fehler::throws;
|
||||||
|
use std::io::Error;
|
||||||
|
use std::io::Write;
|
||||||
|
use std::net::Ipv4Addr;
|
||||||
|
use tun::TunInterface;
|
||||||
|
|
||||||
|
#[throws]
|
||||||
|
#[test]
|
||||||
|
#[ignore = "requires interactivity"]
|
||||||
|
#[cfg(not(target_os = "windows"))]
|
||||||
|
fn tst_read() {
|
||||||
|
// This test is interactive, you need to send a packet to any server through 192.168.1.10
|
||||||
|
// EG. `sudo route add 8.8.8.8 192.168.1.10`,
|
||||||
|
//`dig @8.8.8.8 hackclub.com`
|
||||||
|
let mut tun = TunInterface::new()?;
|
||||||
|
println!("tun name: {:?}", tun.name()?);
|
||||||
|
tun.set_ipv4_addr(Ipv4Addr::from([192, 168, 1, 10]))?;
|
||||||
|
println!("tun ip: {:?}", tun.ipv4_addr()?);
|
||||||
|
println!("Waiting for a packet...");
|
||||||
|
let buf = &mut [0u8; 1500];
|
||||||
|
let res = tun.read(buf);
|
||||||
|
println!("Received!");
|
||||||
|
assert!(res.is_ok());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
#[throws]
|
||||||
|
#[ignore = "requires interactivity"]
|
||||||
|
#[cfg(not(target_os = "windows"))]
|
||||||
|
fn write_packets() {
|
||||||
|
let mut tun = TunInterface::new()?;
|
||||||
|
let mut buf = [0u8; 1500];
|
||||||
|
buf[0] = 6 << 4;
|
||||||
|
let bytes_written = tun.write(&buf)?;
|
||||||
|
assert_eq!(bytes_written, 1504);
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue