Skip to content

Latest commit

 

History

History
71 lines (49 loc) · 2.39 KB

CONTRIBUTING.md

File metadata and controls

71 lines (49 loc) · 2.39 KB

How to submit changes

Pull requests are welcome!

How to report issues/bugs?

Create an issue on Github, we will try to get back to you ASAP.

Checkout the code

git clone https://github.com/NordSecurity/uniffi-bindgen-cs.git
cd uniffi-bindgen-cs
git submodule update --init --recursive

Committing rules

DCO sign off is enforced for all commits. Be sure to use the -s option to add a Signed-off-by line to your commit messages.

git commit -s -m 'This is my commit message'

Run tests

To run tests, dotnet installation is required. Unlike uniffi-rs, there is no integration with cargo test. Tests are written using xunit.

  • Build uniffi-bindgen-cs executable, and libuniffi_fixtures.so shared library.

    ./build.sh
    
  • Generate test bindings using uniffi-bindgen-cs, and run dotnet test command.

    ./test_bindings.sh
    

Run tests in Docker

Running tests in Docker containers is easier, because manual dotnet installation is not required.

./docker_build.sh
./docker_test_bindings.sh

Hanging tests

To print test case names when a test starts, update diagnosticMessages to true in xunit.runner.json. Xunit, the test framework used by this project, does not provide functionality to print test case names when a test starts, making it difficult to debug hanging tests without using a debugger. CustomTestFramework.cs plugs into Xunit to print test case names when the tests start.

Directory structure

Directory Description
3rd-party/uniffi-rs/ fork of uniffi-rs, used for tests
dotnet-tests/UniffiCS/gen/ generated test bindings
dotnet-tests/UniffiCS.binding_tests/ C# tests for bindings
fixtures/ additional test fixtures specific to C# bindings
src/gen_cs/ generator CLI code
templates/ generator C# templates

Thank you!