Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devpro/withywoods
Shared .NET libraries to do more with less code!
https://github.com/devpro/withywoods
dal dotnet-core mongodb nuget rabbitmq selenium swagger testing
Last synced: 3 months ago
JSON representation
Shared .NET libraries to do more with less code!
- Host: GitHub
- URL: https://github.com/devpro/withywoods
- Owner: devpro
- License: apache-2.0
- Created: 2018-08-20T19:03:26.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-03-08T04:58:47.000Z (almost 2 years ago)
- Last Synced: 2024-11-03T08:37:46.126Z (4 months ago)
- Topics: dal, dotnet-core, mongodb, nuget, rabbitmq, selenium, swagger, testing
- Language: C#
- Homepage:
- Size: 1.09 MB
- Stars: 10
- Watchers: 5
- Forks: 1
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Devpro Withywoods - Shared .NET libraries
[data:image/s3,"s3://crabby-images/dfb58/dfb584723688409b199264e3149208cf4813ec0d" alt="Build Status"](https://dev.azure.com/devprofr/open-source/_build/latest?definitionId=31&branchName=master)
[data:image/s3,"s3://crabby-images/a1480/a1480e1e382c1c975cfafa6dccbd969dd97699ea" alt="Quality Gate Status"](https://sonarcloud.io/dashboard?id=withywoods)
[data:image/s3,"s3://crabby-images/686a3/686a31b6f6b9b2c7b141b6ec322bb8cfc7f16e33" alt="Coverage"](https://sonarcloud.io/dashboard?id=withywoods)Whithywoods is a set of small independant .NET libraries (Standard/Core). The goal is to do better with less code and capitalize on best practices (#KISS #DRY).
All libraries are available on [nuget.org](https://www.nuget.org/). Feel free to report any issue or ask for a change. You can also contribute with Pull Requests on GitHub!
NB: The name _Whithywoods_ comes from [Robin Hobb](https://twitter.com/robinhobb)'s incredible writing.
## How to use
### Common / Configuration library
[data:image/s3,"s3://crabby-images/06e3e/06e3e9c509ff55b5ed7f25e8c5fc2bd3c26f04d7" alt="Version"](https://www.nuget.org/packages/Withywoods.Configuration/)
[data:image/s3,"s3://crabby-images/2a641/2a641ae2f1d2298e7be89e86303699607d139f0e" alt="Downloads"](https://www.nuget.org/packages/Withywoods.Configuration/)_tl;dr_ New extension method to access configuration: `configuration.TryGetSection()`
[More information](./src/Configuration/README.md)
### Common / Net HTTP library
[data:image/s3,"s3://crabby-images/1792b/1792b247c3f0b6336f019a127fc61be0da08d8a5" alt="Version"](https://www.nuget.org/packages/Withywoods.Net.Http/)
[data:image/s3,"s3://crabby-images/7cc8b/7cc8b8ca26a8cdc146938f9102e96e16a543b934" alt="Downloads"](https://www.nuget.org/packages/Withywoods.Net.Http/)_tl;dr_ New exception: `ConnectivityException`
[More information](./src/Net.Http/README.md)
### Common / Serialization library
[data:image/s3,"s3://crabby-images/91316/913162c503a658212363af18d6019aef3a12c502" alt="Version"](https://www.nuget.org/packages/Withywoods.Serialization/)
[data:image/s3,"s3://crabby-images/1801c/1801c7c4342d196833fc945aad0c7f1cc9bdc79c" alt="Downloads"](https://www.nuget.org/packages/Withywoods.Serialization/)_tl;dr_ New extension methods to serialize/deserialize from Json: `myObject.ToJson()` and `myString.FromJson()`
[More information](./src/Serialization/README.md)
### Common / System library
[data:image/s3,"s3://crabby-images/c8cb1/c8cb1045116fc61591fc9e87a0b8b608b0ae8949" alt="Version"](https://www.nuget.org/packages/Withywoods.System/)
[data:image/s3,"s3://crabby-images/dcec9/dcec9c153b86546a0719368c278387dca8e914dd" alt="Downloads"](https://www.nuget.org/packages/Withywoods.System/)_tl;dr_ New string extensions: `myString.FirstCharToUpper()`
[More information](./src/System/README.md)
### Common / Unit testing
[data:image/s3,"s3://crabby-images/d7ac1/d7ac1c53a36cb606d0fbfc2dd6959e311bfe5162" alt="Version"](https://www.nuget.org/packages/Withywoods.UnitTesting/)
[data:image/s3,"s3://crabby-images/eaf0b/eaf0b03ffe7b0b1d6b9c47baa887eaf6be8e2804" alt="Downloads"](https://www.nuget.org/packages/Withywoods.UnitTesting/)_tl;dr_ Enable unit testing on HTTP calls: `HttpRepositoryTestBase` abstract class with `BuildHttpClientFactory()` method
[More information](./src/UnitTesting/README.md)
### Data Access / MongoDB library
[data:image/s3,"s3://crabby-images/93152/93152b73b5da60e22fc037cfb0b354d501af54b3" alt="Version"](https://www.nuget.org/packages/Withywoods.Dal.MongoDb/)
[data:image/s3,"s3://crabby-images/116b9/116b9f5a635853235dd5ff9afd3168c608a72996" alt="Downloads"](https://www.nuget.org/packages/Withywoods.Dal.MongoDb/)_tl;dr_ Get access to a MongoDB database in a few lines by using best practices.
[More information](./src/Dal.MongoDb/README.md)
### Message Broker / RabbitMQ library
[data:image/s3,"s3://crabby-images/b7911/b7911f4b2b70d29a41a5a27f4632a75411a8b5b0" alt="Version"](https://www.nuget.org/packages/Withywoods.RabbitMq/)
[data:image/s3,"s3://crabby-images/3ec8d/3ec8de9bd6492f18e704443970b69f9482b92ff6" alt="Downloads"](https://www.nuget.org/packages/Withywoods.RabbitMq/)_tl;dr_ Clean channel factory to ease the use of RabbitMQ as well as enabling decoupling through interfaces.
[More information](./src/RabbitMq/README.md)
### Web / Selenium library
[data:image/s3,"s3://crabby-images/478ca/478cafd4456f0f91e0278b38c7bb519298454072" alt="Version"](https://www.nuget.org/packages/Withywoods.Selenium/)
[data:image/s3,"s3://crabby-images/4e559/4e55968189063cdfdbc7684b85e28223716d87fc" alt="Downloads"](https://www.nuget.org/packages/Withywoods.Selenium/)_tl;dr_ New extension method to find an element with a wait: `driver.FindElement(By.ClassName("title"), 360);`.
[More information](./src/Selenium/README.md)
### Web / Web Application library
[data:image/s3,"s3://crabby-images/2b84b/2b84b52f41280cde2bd3c4ad9f02a96cc47739e9" alt="Version"](https://www.nuget.org/packages/Withywoods.AspNetCore/)
[data:image/s3,"s3://crabby-images/1db9d/1db9d6b083e5f7628dbaebef021610edd66d1a24" alt="Downloads"](https://www.nuget.org/packages/Withywoods.AspNetCore/)_tl;dr_ Easily add Swagger self-generated web page, only two lines in your Startup class!
```csharp
services.AddSwaggerGen(_webAppConfiguration); // in ConfigureServices()app.UseSwagger(_webAppConfiguration); // in Configure()
```[More information](./src/AspNetCore/README.md)
### Web / Web Testing library
[data:image/s3,"s3://crabby-images/865bc/865bc44f8a01a186d4b0f6937b6a4ea42400ad33" alt="Version"](https://www.nuget.org/packages/Withywoods.WebTesting/)
[data:image/s3,"s3://crabby-images/da497/da49727943c119674f25176b6d95903c10b9dd5d" alt="Downloads"](https://www.nuget.org/packages/Withywoods.WebTesting/)_tl;dr_ Use Selenium web driver inside ASP.NET Integration tests? Yes, that's possible with `LocalServerFactory` class!
```csharp
public class SwaggerResourceTest : IClassFixture>, IDisposable
{
[Fact]
public void AspNetCoreApiSampleSwaggerResourceGet_ReturnsHttpOk()
{
// Arrange & Act
_webDriver.Navigate().GoToUrl($"{_server.RootUri}/{_ResourceEndpoint}");// Assert
_webDriver.FindElement(By.ClassName("title"), 360);
_webDriver.Title.Should().Be("Swagger UI");
_webDriver.FindElementByClassName("title").Text.Should().Contain("My API");
}
}
```Want to write easy API Rest tests? Sure, just use the `TestRunner` class!
```csharp
[Fact]
public async Task AspNetCoreApiSampleTaskResourceFullCycle_IsOk()
{
var initialTasks = await _restRunner.GetResources(_client);
initialTasks.Count.Should().Be(0);var created = await _restRunner.CreateResource(_client);
await _restRunner.GetResourceById(created.Id, _client, created);
await _restRunner.UpdateResource(created.Id, created, _client);
var existingTasks = await _restRunner.GetResources(_client);
existingTasks.Count.Should().Be(1);await _restRunner.DeleteResource(created.Id, _client);
var expectedNotFound = new ProblemDetails
{
Title = "Not Found",
Status = 404,
Type = "https://tools.ietf.org/html/rfc7231#section-6.5.4"
};
await _restRunner.GetResourceById(created.Id, _client, expectedNotFound, HttpStatusCode.NotFound, config => config.Excluding(x => x.Extensions));var finalTasks = await _restRunner.GetResources(_client);
finalTasks.Count.Should().Be(0);
}
```[More information](./src/WebTesting/README.md)
## How to build
```bash
# check .NET Core SDK is installed (download from https://dotnet.microsoft.com/download)
dotnet --version# restore NuGet packages
dotnet restore# build the solution
dotnet build
```## How to test
/!\ MongoDB DAL integration tests require a local MongoDB server (through Docker for instance)
```bash
dotnet test
```## Samples
### AspNetCoreApiSample
This is a fully working example, with Swagger generation, API controllers, completely tested by integration tests.
### RabbitMQ
There are two console projects to publish and consumes messages through RabbitMQ, using Withywoods RabbitMQ library.