From b0e9c89287bb01b173e7e732c9011f34e6370442 Mon Sep 17 00:00:00 2001 From: klawr Date: Sat, 23 Apr 2022 12:26:44 +0200 Subject: [PATCH] Add libraries to use for C# testing --- .../visual_studio_create_unit_tests.png | Bin 0 -> 33821 bytes ..._studio_create_unit_tests_context_menu.png | Bin 0 -> 45196 bytes guidelines/cs.rst | 50 ++++++++++++++++++ index.rst | 2 + 4 files changed, 52 insertions(+) create mode 100644 _static/images/visual_studio_create_unit_tests.png create mode 100644 _static/images/visual_studio_create_unit_tests_context_menu.png create mode 100644 guidelines/cs.rst diff --git a/_static/images/visual_studio_create_unit_tests.png b/_static/images/visual_studio_create_unit_tests.png new file mode 100644 index 0000000000000000000000000000000000000000..85774a67066352ed575db423031bed279e993036 GIT binary patch literal 33821 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 a_x6v0=W&$cCyNKmyqb#k-3p}#A^!{Ps*2kH literal 0 HcmV?d00001 diff --git a/_static/images/visual_studio_create_unit_tests_context_menu.png b/_static/images/visual_studio_create_unit_tests_context_menu.png new file mode 100644 index 0000000000000000000000000000000000000000..81b41fb7c1102ed71209dbc07cbe242130fe8d15 GIT binary patch literal 45196 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 +Feel free to add directories for a more concise structure of your project. + +--------------- + Documentation +--------------- + +Since projects are not created using `copier` templates the documentation has to be added using the `copier-documentation <../copier-documentation>`_ template. + +Inline documentation can be added using `sphinx-autoapi `_. + +.. TODO + +--------- + Testing +--------- + +Testing is mandatory and has to be included in every commit. +For *C#* `xUnit `_ is to be used. +It is recommended to you `this extension `_ to be able to easily add tests to your project. + + +.. image:: /_static/images/visual_studio_create_unit_tests_context_menu.png + :align: left + :width: 40 % + +.. image:: /_static/images/visual_studio_create_unit_tests.png + :align: right + :width: 50 % + + +The settings in :code:`Create Unit Tests` should not be changed. +If a test project already exists for your respective code you should select it. + +For better readability of your tests use `FluentAssertions `_. + +Mocks are created using `FakeItEasy `_. + +Code coverage can not be checked using the Visual Studio Community edition, as this feature is only enabled for the `Visual Studio Enterprise `_ edition. + +.. TODO Maybe code coverage can be checked using github actions? diff --git a/index.rst b/index.rst index fc11ef9..a64c659 100644 --- a/index.rst +++ b/index.rst @@ -7,6 +7,8 @@ :maxdepth: 2 :caption: Contents: + guidelines/cs.rst + ---------- Projects