Skip to content

Commit

Permalink
test cpp
Browse files Browse the repository at this point in the history
  • Loading branch information
kennykerr committed May 17, 2024
1 parent 10bf66b commit f474ad8
Show file tree
Hide file tree
Showing 6 changed files with 84 additions and 4 deletions.
2 changes: 2 additions & 0 deletions .github/workflows/clippy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@ jobs:
run: cargo clippy -p sample_component_hello_world
- name: Clippy sample_component_json_validator
run: cargo clippy -p sample_component_json_validator
- name: Clippy sample_component_json_validator_client
run: cargo clippy -p sample_component_json_validator_client
- name: Clippy sample_component_json_validator_winrt
run: cargo clippy -p sample_component_json_validator_winrt
- name: Clippy sample_component_json_validator_winrt_client
Expand Down
10 changes: 6 additions & 4 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,8 @@ jobs:
run: cargo test -p sample_component_hello_world --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test sample_component_json_validator
run: cargo test -p sample_component_json_validator --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test sample_component_json_validator_client
run: cargo test -p sample_component_json_validator_client --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test sample_component_json_validator_winrt
run: cargo test -p sample_component_json_validator_winrt --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test sample_component_json_validator_winrt_client
Expand Down Expand Up @@ -154,10 +156,10 @@ jobs:
run: cargo test -p test_array --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test test_bcrypt
run: cargo test -p test_bcrypt --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test test_bstr
run: cargo test -p test_bstr --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Clean
run: cargo clean
- name: Test test_bstr
run: cargo test -p test_bstr --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test test_calling_convention
run: cargo test -p test_calling_convention --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test test_cfg_generic
Expand Down Expand Up @@ -256,10 +258,10 @@ jobs:
run: cargo test -p test_targets --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test test_unions
run: cargo test -p test_unions --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test test_variant
run: cargo test -p test_variant --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Clean
run: cargo clean
- name: Test test_variant
run: cargo test -p test_variant --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test test_wdk
run: cargo test -p test_wdk --target ${{ matrix.target }} ${{ matrix.etc }}
- name: Test test_weak
Expand Down
13 changes: 13 additions & 0 deletions crates/samples/components/json_validator_client/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
[package]
name = "sample_component_json_validator_client"
version = "0.0.0"
edition = "2021"
publish = false

[build-dependencies]
cc = "1.0"

# TODO: this causes a warning about lack of linkage target. The point is to ensure that this binary dependency is built first but
# Cargo doesn't respect cdylib targets. https://github.com/rust-lang/cargo/issues/7825
[dependencies.sample_component_json_validator]
path = "../json_validator"
9 changes: 9 additions & 0 deletions crates/samples/components/json_validator_client/build.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
fn main() {
println!("cargo:rerun-if-changed=src/client.cpp");

cc::Build::new()
.cpp(true)
.std("c++20")
.file("src/client.cpp")
.compile("client");
}
45 changes: 45 additions & 0 deletions crates/samples/components/json_validator_client/src/client.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
#include <stdint.h>
#include <assert.h>
#include <windows.h>
#include <string_view>
#pragma comment(lib, "ole32")

typedef HRESULT (__stdcall *CreateJsonValidator)(char const* schema, size_t schema_len, uintptr_t* handle);

typedef HRESULT (__stdcall *ValidateJson)(uintptr_t handle, char const* value, size_t value_len, char** sanitized_value, size_t* sanitized_value_len);

typedef void (__stdcall *CloseJsonValidator)(uintptr_t handle);

extern "C" {
void __stdcall client() {
auto library = LoadLibraryExW(L"sample_component_json_validator.dll", 0, LOAD_LIBRARY_SEARCH_DEFAULT_DIRS);
assert(library != 0);

auto create = reinterpret_cast<CreateJsonValidator>(GetProcAddress(library, "CreateJsonValidator"));
assert(create);

auto validate = reinterpret_cast<ValidateJson>(GetProcAddress(library, "ValidateJson"));
assert(validate);

auto close = reinterpret_cast<CloseJsonValidator>(GetProcAddress(library, "CloseJsonValidator"));
assert(close);

std::string_view schema = "{\"maxLength\": 5}";
std::string_view json = "\"Hello\" "; // trailing space will be removed from sanitized result
std::string_view json_invalid = "\"Hello world\""; // this json is too long

uintptr_t validator = 0;
assert(S_OK == create(schema.data(), schema.size(), &validator));

char* sanitized_value = nullptr;
size_t sanitized_value_len = 0;
assert(S_OK == validate(validator, json.data(), json.size(), &sanitized_value, &sanitized_value_len));
std::string_view sanitized(sanitized_value, sanitized_value_len);
assert(sanitized == "\"Hello\"");
CoTaskMemFree(sanitized_value);

assert(E_INVALIDARG == validate(validator, json_invalid.data(), json_invalid.size(), &sanitized_value, &sanitized_value_len));

close(validator);
}
}
9 changes: 9 additions & 0 deletions crates/samples/components/json_validator_client/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#[test]
fn test() {
extern "system" {
fn client();
}
unsafe {
client();
}
}

0 comments on commit f474ad8

Please sign in to comment.