Skip to content

Commit

Permalink
ci: GitHub actions add windows-latest test build
Browse files Browse the repository at this point in the history
  • Loading branch information
3c7 authored and MatejKastak committed Jan 9, 2024
1 parent d1ff982 commit c6e7835
Show file tree
Hide file tree
Showing 5 changed files with 100 additions and 25 deletions.
76 changes: 65 additions & 11 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,15 +20,19 @@ jobs:
- name: Install YARA deps
run: sudo apt-get install -y automake libtool make gcc pkg-config libssl-dev libjansson-dev libmagic-dev
- name: Build YARA
run: cd yari-sys/yara && ./bootstrap.sh && CFLAGS="-fPIC" ./configure --enable-debug --disable-shared --enable-static --enable-cuckoo --enable-magic --enable-dotnet --with-crypto && make
run: |
cd yari-sys/yara
./bootstrap.sh
CFLAGS="-fPIC" ./configure --enable-debug --disable-shared --enable-static --enable-cuckoo --enable-magic --enable-dotnet --with-crypto
make
- name: Build
run: cargo build --verbose
run: cargo build
- name: Run Rust tests
run: cargo test --verbose
run: cargo test
- name: Run tests with yari using bundled bindings
run: |
cargo clean
YARI_USE_BUNDLED_BINDINGS=1 cargo test --verbose
YARI_USE_BUNDLED_BINDINGS=1 cargo test
- uses: actions/setup-python@v4
with:
python-version: '3.10'
Expand All @@ -48,19 +52,69 @@ jobs:
uses: actions/checkout@v3
with:
submodules: 'true'
- name: Install (Yara) Dependencies
- name: Install YARA deps
run: brew install autoconf automake libtool pkg-config jansson libmagic openssl [email protected] [email protected] [email protected]
- name: Build Yara
run: cd yari-sys/yara && ./bootstrap.sh && CFLAGS="-fPIC -I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" ./configure --enable-debug --disable-shared --enable-static --enable-cuckoo --enable-magic --enable-dotnet --with-crypto && make
run: |
cd yari-sys/yara
./bootstrap.sh
CFLAGS="-fPIC -I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" ./configure --enable-debug --disable-shared --enable-static --enable-cuckoo --enable-magic --enable-dotnet --with-crypto
make
- name: Build Yari (yari-sys)
run: cd yari-sys && CFLAGS="-I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" cargo build --release
- name: Build Yari (yari-cli)
run: cd yari-cli && CFLAGS="-I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" cargo build --release
- name: Build Yari (yari-py)
run: cd yari-py && python3.12 -mvenv .venv && .venv/bin/pip install maturin pytest && CFLAGS="-I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" .venv/bin/maturin build --release -i python3.10 -i python3.11 -i python3.12
- name: Run Rust tests
run: CFLAGS="-I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" cargo test --verbose
run: CFLAGS="-I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" cargo test
- name: Run Rust tests with bundled bindings
run: cargo clean && YARI_USE_BUNDLED_BINDINGS=1 CFLAGS="-I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" cargo test --verbose
run: |
cargo clean
YARI_USE_BUNDLED_BINDINGS=1 CFLAGS="-I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" cargo test
- name: Run Python tests
run: cd yari-py && .venv/bin/maturin develop && .venv/bin/pytest
run: |
cd yari-py
python3.12 -m venv .venv
.venv/bin/pip install maturin pytest
CFLAGS="-I$(brew --prefix)/include" LDFLAGS="-L$(brew --prefix)/lib $LDFLAGS" LIBRARY_PATH="$(brew --prefix)/lib:$LIBRARY_PATH" .venv/bin/maturin build -i python3.10 -i python3.11 -i python3.12
.venv/bin/maturin build
.venv/bin/maturin develop
.venv/bin/pytest
build-windows:
runs-on: windows-latest
defaults:
run:
shell: bash
steps:
- uses: actions/checkout@v3
with:
submodules: 'recursive'
- uses: actions/setup-python@v3
with:
python-version: '3.10'
- name: Setup Nuget.exe
uses: nuget/setup-nuget@v1
with:
nuget-version: 'latest'
- name: Setup msbuild
uses: microsoft/[email protected]
- name: Install YARA Dependencies
run: nuget.exe restore windows/vs2017/yara.sln
working-directory: ./yari-sys/yara
- name: Build YARA
run: msbuild /m /p:Platform=x64 /p:Configuration=Release /p:PlatformToolset="v142" /p:WindowsTargetPlatformVersion="10.0.19041.0" windows/vs2017/yara.sln
working-directory: ./yari-sys/yara
shell: cmd
- name: Build yari-sys
run: |
cargo build
RUST_LOG=debug cargo test -- --nocapture --show-output --test-threads 1
working-directory: ./yari-sys
- name: Build Python wheels
run: |
pip install --upgrade pip
python -m venv env
. env/Scripts/activate
pip install maturin pytest
maturin develop
pytest tests
working-directory: ./yari-py
2 changes: 2 additions & 0 deletions yari-sys/build.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,8 @@ fn link_lib(name: &str) {
#[cfg(target_os = "windows")]
fn link_windows() {
link_lib("libyara64");
link_lib("crypt32");
link_lib("user32");
}

#[cfg(any(target_os = "linux", target_os = "macos"))]
Expand Down
35 changes: 21 additions & 14 deletions yari-sys/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -640,8 +640,7 @@ impl Context {
&mut res.context.matches_notebook,
);

res.context.entry_point =
yr_get_entry_point_offset(data, (*block).size);
res.context.entry_point = yr_get_entry_point_offset(data, (*block).size);
_yr_scanner_scan_mem_block(&mut **res.context, data, block);
}
}
Expand Down Expand Up @@ -738,7 +737,11 @@ impl Context {
debug!("Importing module {:?}", module);

let module_name = CString::new(module.as_ref()).expect("Invalid string");
let _res = unsafe { yr_modules_load(module_name.as_ptr(), &mut **self.context) };
let res = unsafe { yr_modules_load(module_name.as_ptr(), &mut **self.context) };
debug!("Loaded module {:?} with result {}", module, res);
if res != ERROR_SUCCESS as i32 {
return Err(YariError::UnknownModule(module.to_string()));
}

let new_module: *mut YR_OBJECT_STRUCTURE = unsafe {
yr_hash_table_lookup(
Expand All @@ -748,9 +751,9 @@ impl Context {
)
}
.cast();

debug!("Module {:?} has pointer {:?}", module, new_module);
if new_module.is_null() {
return Err(YariError::SymbolNotFound(module.to_string()));
return Err(YariError::UnknownModule(module.to_string()));
}

self.modules.insert(module, new_module);
Expand Down Expand Up @@ -1336,6 +1339,7 @@ impl Context {
}

pub fn dump_module(&mut self, module: Module) -> Result<(), YariError> {
debug!("Dumping module {:?}", module);
self.import_module(module)?;
match self.modules.get(&module) {
Some(module) => {
Expand Down Expand Up @@ -1464,41 +1468,44 @@ impl Drop for Context {
debug!("Dropping context");

unsafe { yr_modules_unload_all(&mut **self.context) };
debug!("Unloaded modules");

let rules = self.context.rules;

if !self.context.matches_notebook.is_null() {
unsafe {
yr_notebook_destroy(self.context.matches_notebook);
}
debug!("Destroyed matches notebook");
}

// Drop all created filemaps (this should close all opened FDs)
for file in self.yr_mapped_files.iter_mut() {
unsafe { yr_filemap_unmap(file) };
}
debug!("Freed filemaps");

unsafe { yr_compiler_destroy(self.compiler) };
debug!("Destroyed compiler");

if !self.fallback_scanner.is_null() {
unsafe { yr_scanner_destroy(self.fallback_scanner) };
debug!("Destroyed fallback scanner");
}

#[allow(clippy::if_same_then_else)]
if self.use_fallback_eval {
#[cfg(not(target_os = "windows"))]
unsafe {
yr_scanner_destroy(&mut **self.context)
};
} else {
unsafe { yr_scanner_destroy(&mut **self.context) };
}
#[cfg(not(target_os = "windows"))]
unsafe {
yr_scanner_destroy(&mut **self.context)
};
debug!("Destroyed scanner");

if !rules.is_null() {
unsafe { yr_rules_destroy(rules) };
debug!("Destroyed rules");
}

unsafe { yr_finalize() };
debug!("DONE dropping context");
}
}

Expand Down
7 changes: 7 additions & 0 deletions yari-sys/tests/common.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,12 @@ use yari_sys::Module;
use yari_sys::{Context, ContextBuilder};

pub fn context() -> Context {
let _ = env_logger::builder().is_test(true).try_init();
ContextBuilder::default().build().unwrap()
}

pub fn context_with_cuckoo() -> Context {
let _ = env_logger::builder().is_test(true).try_init();
let test_root = Path::new(env!("CARGO_MANIFEST_DIR"));
let cuckoo_report = test_root.join("tests/assets/cuckoo.json");

Expand All @@ -18,6 +20,7 @@ pub fn context_with_cuckoo() -> Context {
}

fn context_with_sample(path: &str, rule: Option<&str>) -> Context {
let _ = env_logger::builder().is_test(true).try_init();
let test_root = Path::new(env!("CARGO_MANIFEST_DIR"));
let file = test_root.join(path);

Expand All @@ -29,14 +32,17 @@ fn context_with_sample(path: &str, rule: Option<&str>) -> Context {
}

pub fn context_with_elf_sample() -> Context {
let _ = env_logger::builder().is_test(true).try_init();
context_with_sample("tests/assets/elf_hello_world", None)
}

pub fn context_with_pe_signed_sample() -> Context {
let _ = env_logger::builder().is_test(true).try_init();
context_with_sample("tests/assets/pe_signed", None)
}

pub fn context_with_pe_sample_and_rule() -> Context {
let _ = env_logger::builder().is_test(true).try_init();
context_with_sample(
"tests/assets/pe_hello_world",
Some(
Expand All @@ -58,6 +64,7 @@ rule r {
}

pub fn context_with_elf_sample_and_rule() -> Context {
let _ = env_logger::builder().is_test(true).try_init();
context_with_sample(
"tests/assets/elf_hello_world",
Some(
Expand Down
5 changes: 5 additions & 0 deletions yari-sys/tests/tests_dump_module.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
use log::debug;
use yari_sys::MODULES;

mod common;

#[test]
fn test_function_dump_plain() {
let mut context = common::context();
debug!("test_function_dump_plain");

for module in MODULES {
context.dump_module(*module).unwrap();
Expand All @@ -14,6 +16,7 @@ fn test_function_dump_plain() {
#[test]
fn test_function_dump_cuckoo() {
let mut context = common::context_with_cuckoo();
debug!("test_function_dump_cuckoo");

for module in MODULES {
context.dump_module(*module).unwrap();
Expand All @@ -23,6 +26,7 @@ fn test_function_dump_cuckoo() {
#[test]
fn test_function_dump_pe() {
let mut context = common::context_with_pe_sample_and_rule();
debug!("test_function_dump_pe");

for module in MODULES {
context.dump_module(*module).unwrap();
Expand All @@ -32,6 +36,7 @@ fn test_function_dump_pe() {
#[test]
fn test_function_dump_elf() {
let mut context = common::context_with_elf_sample();
debug!("test_function_dump_elf");

for module in MODULES {
context.dump_module(*module).unwrap();
Expand Down

0 comments on commit c6e7835

Please sign in to comment.