Skip to content

Commit

Permalink
Run tests on Github Actions
Browse files Browse the repository at this point in the history
  • Loading branch information
conradev committed Aug 5, 2023
1 parent 86b53c9 commit d6d490c
Show file tree
Hide file tree
Showing 6 changed files with 38 additions and 44 deletions.
15 changes: 9 additions & 6 deletions .github/workflows/build-rust.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,21 +17,24 @@ jobs:
platform: Linux
packages:
- gcc-aarch64-linux-gnu
targets:
test-targets:
- x86_64-unknown-linux-gnu
targets:
- aarch64-unknown-linux-gnu
- os: macos-12
platform: macOS
targets:
test-targets:
- x86_64-apple-darwin
targets:
- aarch64-apple-darwin
- aarch64-apple-ios
- aarch64-apple-ios-sim
- x86_64-apple-ios
- os: windows-2022
platform: Windows
targets:
test-targets:
- x86_64-pc-windows-msvc
targets:
- aarch64-pc-windows-msvc
runs-on: ${{ matrix.os }}
env:
Expand Down Expand Up @@ -59,7 +62,7 @@ jobs:
targets: ${{ join(matrix.targets, ', ') }}
- name: Build
shell: bash
run: cargo build --verbose --workspace --all-features --target ${{ join(matrix.targets, ' --target ') }}
- name: Post-Build Tests
run: cargo build --verbose --workspace --all-features --target ${{ join(matrix.targets, ' --target ') }} --target ${{ join(matrix.test-targets, ' --target ') }}
- name: Test
shell: bash
run: cargo test
run: cargo test --verbose --workspace --all-features --target ${{ join(matrix.test-targets, ' --target ') }}
9 changes: 0 additions & 9 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,15 +8,6 @@
"editor.acceptSuggestionOnEnter": "on",
"rust-analyzer.restartServerOnConfigChange": true,
"rust-analyzer.cargo.features": "all",
"rust-analyzer.check.overrideCommand": [
"cargo",
"clippy",
"--fix",
"--workspace",
"--message-format=json",
"--all-targets",
"--allow-dirty"
],
"[rust]": {
"editor.defaultFormatter": "rust-lang.rust-analyzer",
}
Expand Down
24 changes: 0 additions & 24 deletions tun/src/tokio/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,27 +32,3 @@ impl TunInterface {
}
}
}

#[cfg(test)]
mod tests {
use std::net::Ipv4Addr;

use super::*;
#[tokio::test]
async fn test_create() {
let tun = crate::TunInterface::new().unwrap();
let _async_tun = TunInterface::new(tun).unwrap();
}

#[tokio::test]
async fn test_write() {
let tun = crate::TunInterface::new().unwrap();
tun.set_ipv4_addr(Ipv4Addr::from([192, 168, 1, 10]))
.unwrap();
let async_tun = TunInterface::new(tun).unwrap();
let mut buf = [0u8; 1500];
buf[0] = 6 << 4;
let bytes_written = async_tun.write(&buf).await.unwrap();
assert!(bytes_written > 0);
}
}
4 changes: 3 additions & 1 deletion tun/tests/configure.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use fehler::throws;
use std::io::Error;
use std::net::{Ipv4Addr};
use std::net::Ipv4Addr;
use tun::TunInterface;

#[test]
Expand All @@ -26,6 +26,8 @@ fn test_set_get_ipv4() {
#[throws]
#[cfg(not(any(target_os = "windows", target_vendor = "apple")))]
fn test_set_get_ipv6() {
use std::net::Ipv6Addr;

let tun = TunInterface::new()?;

let addr = Ipv6Addr::new(1, 1, 1, 1, 1, 1, 1, 1);
Expand Down
8 changes: 4 additions & 4 deletions tun/tests/packets.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use fehler::throws;
use std::io::Error;
use std::io::Write;

use std::net::Ipv4Addr;
use tun::TunInterface;

Expand All @@ -18,7 +18,7 @@ fn tst_read() {
println!("tun ip: {:?}", tun.ipv4_addr()?);
println!("Waiting for a packet...");
let buf = &mut [0u8; 1500];
let res = tun.read(buf);
let res = tun.recv(buf);
println!("Received!");
assert!(res.is_ok());
}
Expand All @@ -28,9 +28,9 @@ fn tst_read() {
#[ignore = "requires interactivity"]
#[cfg(not(target_os = "windows"))]
fn write_packets() {
let mut tun = TunInterface::new()?;
let tun = TunInterface::new()?;
let mut buf = [0u8; 1500];
buf[0] = 6 << 4;
let bytes_written = tun.write(&buf)?;
let bytes_written = tun.send(&buf)?;
assert_eq!(bytes_written, 1504);
}
22 changes: 22 additions & 0 deletions tun/tests/tokio.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
use std::net::Ipv4Addr;

#[tokio::test]
#[cfg(feature = "tokio")]
async fn test_create() {
let tun = tun::TunInterface::new().unwrap();
let async_tun = tun::tokio::TunInterface::new(tun).unwrap();
}

#[tokio::test]
#[ignore = "It hangs when run"]
#[cfg(feature = "tokio")]
async fn test_write() {
let tun = tun::TunInterface::new().unwrap();
tun.set_ipv4_addr(Ipv4Addr::from([192, 168, 1, 10]))
.unwrap();
let async_tun = tun::tokio::TunInterface::new(tun).unwrap();
let mut buf = [0u8; 1500];
buf[0] = 6 << 4;
let bytes_written = async_tun.write(&buf).await.unwrap();
assert!(bytes_written > 0);
}

0 comments on commit d6d490c

Please sign in to comment.