Darp.Utils.TestRail
1.16.1
dotnet add package Darp.Utils.TestRail --version 1.16.1
NuGet\Install-Package Darp.Utils.TestRail -Version 1.16.1
<PackageReference Include="Darp.Utils.TestRail" Version="1.16.1" />
<PackageVersion Include="Darp.Utils.TestRail" Version="1.16.1" />
<PackageReference Include="Darp.Utils.TestRail" />
paket add Darp.Utils.TestRail --version 1.16.1
#r "nuget: Darp.Utils.TestRail, 1.16.1"
#addin nuget:?package=Darp.Utils.TestRail&version=1.16.1
#tool nuget:?package=Darp.Utils.TestRail&version=1.16.1
Darp.Utils
This repository bundles all open source c# helper modules of 'rosslight GmbH'. To extend, add a new project and test project.
Darp.Utils.Assets
A collection of simple interfaces for app assets targeting desktop apps.
Currently implemented:
IFolderAssetsService
: Read or write to a specific folderIAppDataAssetsService
: Read or write to theApplicationData
. The relativePath might be e.g. the app name.IProgramDataAssetsService
: Read or write to theProgramData
. The relativePath might be e.g. the app name.IBaseDirectoryAssetsService
: Read from the base directory of the App's executableIEmbeddedResourceAssetsService
: Read files marked asEmbeddedResource
of a specific Assembly
Additionally, there is a MemoryAssetsService
that can be used during testing
Example:
// Add EmbeddedResources and AppData assets to the DI Container
ServiceProvider provider = new ServiceCollection()
.AddEmbeddedResourceAssetsService(typeof(Test).Assembly)
.AddAppDataAssetsService("RelativePath")
.BuildServiceProvider();
// Example read and write operations with the app data
IAppDataAssetsService service = provider.GetRequiredService<IAppDataAssetsService>();
await service.SerializeJsonAsync("test.json", new Test("value"));
Test deserialized = await service.DeserializeJsonAsync<Test>("test.json");
await service.WriteTextAsync("test2.txt", "some content");
// Copy an embedded resource to the app data
IEmbeddedResourceAssetsService resourceService = provider.GetRequiredService<IEmbeddedResourceAssetsService>();
await resourceService.CopyToAsync("test.json", service, "test.json");
file sealed record Test(string Prop1);
Darp.Utils.Configuration
A writable configuration service. Can be registered using DI and injected into target services. Usage might include reading, writing and listening to changes via the INotifyPropertyChanged interface.
Example:
ServiceProvider provider = new ServiceCollection()
.AddAppDataAssetsService("RelativePath")
.AddConfigurationFile<TestConfig, IAppDataAssetsService>("config.json")
.BuildServiceProvider();
IConfigurationService<TestConfig> service = provider.GetRequiredService<IConfigurationService<TestConfig>>();
TestConfig config = await service.LoadConfigurationAsync();
await service.WriteConfigurationAsync(config with { Setting = "NewValue" });
Darp.Utils.Dialog
A lightweight dialog service which allows for opening dialogs from the ViewModel.
Implementation | Description |
---|---|
Implementation based on FluentAvalonia |
Example:
ServiceProvider provider = new ServiceCollection()
.AddSingleton<IDialogService, AvaloniaDialogService>()
.BuildServiceProvider();
IDialogService dialogService = provider.GetRequiredService<IDialogService>();
// Specify the Type of the dataContext of the window the dialog is supposed to be shown on
// .WithDialogRoot<MainWindowViewModel>()
await dialogService.CreateMessageBoxDialog("Title", "Message").ShowAsync();
// Assumes you have registered a view for 'SomeViewModel' in a ViewLocator
// Works with any kind of content
var viewModel = new SomeViewModel();
await dialogService.CreateContentDialog("Title", viewModel)
.SetDefaultButton(ContentDialogButton.Primary)
.SetCloseButton("Close")
.SetPrimaryButton("Ok", onClick: model => model.IsModelValid)
.ShowAsync();
Darp.Utils.Avalonia
A collection of classes and methods to help reduce the boilerplate when working with Avalonia. These contain:
ViewLocatorBase
: Resolve views at compile-timeUserControlBase
,WindowBase
: Add aViewModel
property to have typed access to the DataContextAvaloniaHelpers
: A collection of helper methods
Darp.Utils.ResxSourceGenerator
A source generator for generating strongly typed singleton resource classes from .resx files. Additional documentation here.
Darp.Utils.TestRail
A library allowing for communication with a TestRail instance in a easy and modern way.
Core features:
- Modern: Build on the latest .Net technologies. NativeAot compatible
- Extensible:
ITestRailService
is the core with a bunch of extension methods defining the actual API - Testable: Operates purely on the interface
ITestRailService
which can be mocked easily
Getting started:
var service = TestRailService.Create("https://[your-organization].testrail.io", "username", "passwordOrApiKey");
var projectsEnumerable = service.GetProjects(ProjectsFilter.ActiveProjectsOnly);
await foreach (var project in projectsEnumerable)
{
var casesEnumerable = service.GetCases(project.Id);
}
var caseResponse = await service.GetCaseAsync((CaseId)1);
var customProperty = caseResponse.Properties["custom_property"].GetString();
await service.UpdateCase(new UpdateCaseRequest { CaseId = caseResponse.Id, Title = "New Title" });
Extension methods:
public static async Task<GetCaseResponse> GetCaseAsync(this ITestRailService testRailService, CaseId caseId)
{
var jsonTypeInfo = YourSourceGenerationContext.Default.GetCaseResponse;
return await testRailService.GetAsync($"/get_case/{(int)caseId}", jsonTypeInfo, default(cancellationToken));
}
Usage with IHttpClientFactory
for http client caching:
var provider = new ServiceCollection()
.AddHttpClient("TestRailClient", (provider, client) =>
{
client.BaseAddress = new Uri("https://[your-organization].testrail.io");
var authBytes = Encoding.UTF8.GetBytes("username:passwordOrApiKey");
var base64Authorization = Convert.ToBase64String(authBytes);
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", base64Authorization);
client.DefaultRequestHeaders.Add("Accept", "application/json");
})
.AddSingleton<ITestRailService>(provider => new TestRailService<IHttpClientFactory>(
provider.GetRequiredService<IHttpClientFactory>(),
factory => factory.CreateClient("TestRailClient"),
NullLogger.Instance))
.BuildServiceProvider();
var service = provider.GetRequiredService<ITestRailService>();
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net8.0
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.5)
-
net9.0
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.5)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.16.1 | 50 | 6/3/2025 |
1.16.0 | 66 | 5/24/2025 |
1.15.0 | 63 | 5/24/2025 |
1.14.3 | 142 | 5/22/2025 |
1.14.2 | 136 | 5/22/2025 |
1.14.1 | 140 | 5/20/2025 |
1.14.0 | 139 | 5/20/2025 |
1.13.2 | 142 | 5/19/2025 |
1.13.1 | 141 | 5/19/2025 |
1.13.0 | 298 | 3/5/2025 |
1.12.3 | 388 | 12/17/2024 |
1.12.2 | 175 | 12/12/2024 |
1.12.1 | 115 | 12/11/2024 |
1.12.0 | 108 | 12/11/2024 |