Skip to content
This repository has been archived by the owner on Dec 4, 2024. It is now read-only.

Latest commit

 

History

History
66 lines (38 loc) · 5.08 KB

CONTRIBUTING.md

File metadata and controls

66 lines (38 loc) · 5.08 KB

Contributing to the LaunchDarkly Client-Side SDK for .NET

LaunchDarkly has published an SDK contributor's guide that provides a detailed explanation of how our SDKs work. See below for additional information on how to contribute to this SDK.

Submitting bug reports and feature requests

The LaunchDarkly SDK team monitors the issue tracker in the SDK repository. Bug reports and feature requests specific to this SDK should be filed in this issue tracker. The SDK team will respond to all newly filed issues within two business days.

Submitting pull requests

We encourage pull requests and other contributions from the community. Before submitting pull requests, ensure that all temporary or unintended code is removed. Don't worry about adding reviewers to the pull request; the LaunchDarkly SDK team will add themselves. The SDK team will acknowledge all pull requests within two business days.

Build instructions

Prerequisites

The .NET Standard target requires only the .NET Core 2.1 SDK or higher. The iOS, Android, MacCatalys, and Windows targets require Net 7.0 or later.

Building

To build the SDK (for all target platforms) without running any tests:

msbuild /restore src/LaunchDarkly.ClientSdk/LaunchDarkly.ClientSdk.csproj

Currently this command can only be run on MacOS, because that is the only platform that allows building for all of the targets (.NET Standard, Android, and iOS).

To build the SDK for only one of the supported platforms, add /p:TargetFramework=X where X is one of the items in the <TargetFrameworks> list of LaunchDarkly.XamarinSdk.csproj: netstandard2.0 for .NET Standard 2.0, MonoAndroid81 for Android 8.1, etc.:

msbuild /restore /p:TargetFramework=netstandard2.0 src/LaunchDarkly.ClientSdk/LaunchDarkly.ClientSdk.csproj

Note that the main project, src/LaunchDarkly.ClientSdk, contains source files that are built for all platforms (ending in just .cs, or .shared.cs), and also a smaller amount of code that is conditionally compiled for platform-specific functionality. The latter is all in the PlatformSpecific folder. We use #ifdef directives only for small sections that differ slightly between platform versions; otherwise the conditional compilation is done according to filename suffix (.android.cs, etc.) based on rules in the .csproj file.

Testing

The .NET Standard unit tests cover all of the non-platform-specific functionality, as well as behavior specific to .NET Standard (e.g. caching flags in the filesystem). They can be run with only the basic Xamarin framework installed, via the dotnet tool:

msbuild /p:TargetFramework=netstandard2.0 src/LaunchDarkly.ClientSdk
dotnet test tests/LaunchDarkly.ClientSdk.Tests/LaunchDarkly.ClientSdk.Tests.csproj

The equivalent test suites in Android or iOS must be run in an Android or iOS emulator. The projects tests/LaunchDarkly.ClientSdk.Android.Tests and tests/LaunchDarkly.ClientSdk.iOS.Tests consist of applications based on the xunit.runner.devices tool, which show the test results visually in the emulator and also write the results to the emulator's system log. The actual unit test code is just the same tests from the main tests/LaunchDarkly.ClientSdk.Tests project, but running them in this way exercises the mobile-specific behavior for those platforms (e.g. caching flags in user preferences).

You can run the mobile test projects from Visual Studio (the iOS tests require MacOS); there is also a somewhat complicated process for running them from the command line, which is what the CI build does (see .circleci/config.yml).

Note that the mobile unit tests currently do not cover background-mode behavior or connectivity detection.

To run the SDK contract test suite, in Linux or MacOS (see contract-tests/README.md):

make contract-tests

Packaging/releasing

Releases are done through LaunchDarkly's standard project releaser tool. The scripts in .ldrelease implement most of this process, because unlike our other .NET projects which can be built with the .NET 5 SDK in a Linux container, this one currently must be built on a MacOS host in CircleCI. Do not modify these scripts unless you are very sure what you're doing.

If you need to do a manual package build for any reason, you can do it (on MacOS) using the same command shown above under "Building", but adding the option /t:pack. However, this will not include Authenticode signing; therefore, please do not publish a GA release of the package from a manual build. If it's absolutely necessary to do so, consult with the SDK team to find out how to access the code-signing certificate.

Building a temporary package

If you need to build a .nupkg for testing another application (in cases where linking directly to this project is not an option), run ./scripts/build-test-package.sh. This will create a package with a unique version string in ./test-packages. You can then set your other project to use test-packages as a NuGet package source.