uid |
---|
contributing |
Follow this document
Folder | Description |
---|---|
.\Build | Build and CI files, check readme.md in that folder |
.\Data | Databases and database creation scripts for tests |
.\NuGet | LINQ to DB NuGet packages build files |
.\Redist | Binaries,unavailable officially at NuGet, used by tests and nugets |
.\Source\LinqToDB | LINQ to DB source code |
.\Source\LinqToDB.Tools | LINQ to DB Tools source code |
.\Source\LinqToDB.AspNet | LINQ to DB ASP.NET Core integration library source code |
.\Source\LinqToDB.Templates | LINQ to DB t4models source code |
.\Tests | Unit test projects folder |
.\Tests\Base | LINQ to DB testing framework |
.\Tests\FSharp | F# models and tests |
.\Tests\Linq | Main project for LINQ to DB unit tests |
.\Tests\Model | Model classes for tests |
.\Tests\Tests.T4 | T4 templates test project |
.\Tests\Tests.Android | Xamarin Forms for Android test project |
.\Tests\Tests.Benchmark | Benchmarks |
.\Tests\Tests.PLayground | Test project for use with linq2db.playground.sln lite test solution Used for work on specific test without full solution load |
.\Tests\VisualBasic | Visual Basic models and tests support |
Solutions:
.\linq2db.sln
- full linq2db VS2019 solution.\linq2db.playground.sln
- ligthweight linq2db VS2019 test solution. Used to work on specific test without loading of all payload of full solution
Project \ Target | .NET 4.5 | .NET 4.6 | .NET 4.7.2 | .NET Standard 2.0 | .NET Core 2.1 | .NET Standard 2.1 | .NET Core 3.1 |
---|---|---|---|---|---|---|---|
.\Source\LinqToDB\LinqToDB.csproj |
√ | √ | √ | √ | √ | √ | √ |
.\Source\LinqToDB\LinqToDB.Tools.csproj |
√ | √ | √ | ||||
.\Source\LinqToDB\LinqToDB.AspNet.csproj |
√ | √ |
Preferred target defines:
NETFRAMEWORK
-net45
,net46
andnet472
target ifdef!NETFRAMEWORK
-netstandard2.0
and newer target ifdefNETCOREAPP
-netcoreapp2.1
andnetcoreapp3.1
target ifdefNETSTANDARD2_1PLUS
-netstandard2.1
andnetcoreapp3.1
target ifdefNATIVE_ASYNC
- ifdef with native support forValueTask
,IAsyncEnumerable<T>
andIAsyncDisposable
types
Other allowed target defines:
NETSTANDARD2_1
-netstandard2.1
target ifdefNETCOREAPP3_1
-netcoreapp3.1
target ifdefNETSTANDARD2_0
-netstandard2.0
target ifdefNETCOREAPP2_1
-netcoreapp2.1
target ifdefNET45
-net45
target ifdefNET46
-net46
target ifdefNET472
-net472
target ifdef
Allowed debugging defines:
TRACK_BUILD
DEBUG
- for debug code in debug build. To disable debug code useDEBUG1
renameOVERRIDETOSTRING
- enables ToString()overrides for AST model (must be enabled in LinqToDB.csproj by renaming existing
OVERRIDETOSTRING1` define)
Project \ Target | .NET 4.7.2 | .NET Core 2.1 | .NET Core 3.1 | .NET 5.0 |
---|---|---|---|---|
.\Tests\Base\Tests.Base.csproj |
√ | √ | √ | √ |
.\Tests\FSharp\Tests.FSharp.fsproj |
√ | √ | √ | √ |
.\Tests\Linq\Tests.csproj |
√ | √ | √ | √ |
.\Tests\Model\Tests.Model.csproj |
√ | √ | √ | √ |
.\Tests\Tests.Benchmarks\Tests.Benchmarks.csproj |
√ | √ | √ | √ |
.\Tests\Tests.Playground\Tests.Playground.csproj |
√ | √ | √ | √ |
.\Tests\Tests.T4\Tests.T4.csproj |
√ | √ | √ | √ |
.\Tests\VisualBasic\Tests.VisualBasic.vbproj |
√ | √ | √ | √ |
Allowed target defines:
NETCOREAPP3_1
-netcoreapp3.1
target ifdefNETCOREAPP2_1
-netcoreapp2.1
target ifdefNET5_0
-net5.0
target ifdefNET472
-net472
target ifdefAZURE
- for Azure Pipelines CI builds
You can use the solution to build and run tests. Also you can build whole solution or library using the following batch files:
.\Build.cmd
- builds all the projects in the solution for Debug, Release and Azure configurations.\Compile.cmd
- builds LinqToDB project for Debug and Release configurations.\Clean.cmd
- cleanups solution projects for Debug, Release and Azure configurations.\Test.cmd
- buildDebug
configuration and run tests fornet472
,netcoreapp2.1
,netcoreapp3.1
andnet5.0
targets. You can set other configuration by passing it as first parameter, disable test targets by passing 0 to second (fornet472
), third (fornetcoreapp2.1
), fourth (fornetcoreapp3.1
) or fifth (fornet5.0
) parameter and format (default:html) as 6th parameter.
Example of running Release build tests for netcoreapp2.1
only with trx as output:
test.cmd Release 0 1 0 0 0 trx
Because of compiling for different platforms we do use:
- Conditional compilation. See supported defines above
- Implementing missing classes and enums. There are some under
.\Source\LinqToDB\Compatibility
folder
master
- current development branch for next releaserelease
- branch with the latest release
NUnit3 is used as unit testing framework. Most of tests are run for all supported databases, and written in same pattern:
[TestFixture]
public class Test: TestBase // TestBase - base class, provides base methods and object data sources
{
// DataSourcesAttribute - implements NUnit IParameterDataSource to provide testcases for enabled database providers
[Test]
public void Test([DataSources] string context)
{
// TestBase.GetDataContext - creates new IDataContext
// also supports creation of remote client and server
// for remote contexts
using(var db = GetDataContext(context))
{
// Here is the most interesting
// this.Person - list of persons, corresponding Person table in database (derived from TestBase)
// db.Person - database table
// So test checks that LINQ to Objects query produces the same result as executed database query
AreEqual(this.Person.Where(_ => _.Name == "John"), db.Person.Where(_ => _.Name == "John"));
}
}
}
DataSourcesAttribute
generates tests for each enabled data provider. Configuration is taken
from .\Tests\Linq\DataProviders.json
and .\Tests\Linq\UserDataProviders.json
(used first, if exists).
Configuration file is used to specify user-specific settings such as connection strings to test databases and list of providers to test.
The [User]DataProviders.json
is a regular JSON file:
{
// .net framework 4.7.2 test configuration
"NET472" :
{
// base configuration to inherit settings from
// Inheritance rules:
// - DefaultConfiguration, TraceLevel, Providers - use value from base configuration only if it is not defined in current configuration
// - Connections - merge current and base connection strings
"BasedOn" : "LocalConnectionStrings",
// default provider, used as a source of reference data
// LINQ to DB uses SQLite for it and you hardly need to change it
"DefaultConfiguration" : "SQLite.Classic",
// (optional) contains full or relative (from test assembly location) path to test baselines directory.
// When path is set and specified directory exists - enables baselines generation for tests.
"BaselinesPath": "c:\\github\\linq2db.baselines",
// logging level
// Supported values: Off, Error, Warning, Info, Verbose
// Default level: Info
"TraceLevel" : "Error",
// list of database providers, enabled for current test configuration
"Providers" :
[
"Access",
"SqlCe",
"SQLite.Classic",
"SQLite.MS",
"Northwind.SQLite",
"Northwind.SQLite.MS",
"SqlServer",
"SqlServer.2014",
"SqlServer.2012", "SqlServer.2012.1",
"SqlServer.2008", "SqlServer.2008.1",
"SqlServer.2005", "SqlServer.2005.1",
"SqlAzure",
"DB2",
"Firebird",
"Informix",
"MySql",
"MariaDB",
"Oracle.Native",
"Oracle.Managed",
"PostgreSQL",
"Sybase",
"Northwind",
"TestNoopProvider"
],
// list of test skip categories, disabled for current test configuration
// to set test skip category, use SkipCategoryAttribute on test method, class or whole assembly
"Skip" :
[
"Access.12"
]
},
// .net core 2.1 test configuration
"CORE21" :
{
"BasedOn" : "LocalConnectionStrings",
"Providers" :
[
"SQLite.MS",
"Northwind.SQLite.MS",
"SqlServer",
"SqlServer.2014",
"SqlServer.2012", "SqlServer.2012.1",
"SqlServer.2008", "SqlServer.2008.1",
"SqlServer.2005", "SqlServer.2005.1",
"SqlAzure",
"Firebird",
"MySql",
"MariaDB",
"PostgreSQL",
"Northwind",
"TestNoopProvider"
]
},
// list of connection strings for all providers
"LocalConnectionStrings":
{
"BasedOn" : "CommonConnectionStrings",
"Connections" :
{
// override connection string for SqlAzure provider
// all other providers will use default inherited connection strings from CommonConnectionStrings configuration
"SqlAzure" :
{
"Provider" : "System.Data.SqlClient",
"ConnectionString" : "Server=tcp:xxxxxxxxx.database.windows.net,1433;Database=TestData;User ID=TestUser@zzzzzzzzz;Password=TestPassword;Trusted_Connection=False;Encrypt=True;"
}
}
}
}
To define your own configurations DO NOT EDIT DataProviders.json
- create .\Tests\Linq\UserDataProviders.json
and define needed configurations.
Tests execution depends on _CreateData.*
tests executed first. Those tests recreate test databases and populate them with test data, so if you are going to run one test be sure to run _CreateData
before it manually.
Also - if your test changes database data, be sure to revert those changes (!) to avoid side effects for other tests.
We do run builds and tests with:
- Azure Pipelines pipelines/default.yml.
It builds solution, generate and publish nugets and runs tests for:
- .Net 4.7.2
- .Net Core 2.1 (Windows/Linux and MacOS)
- .Net Core 3.1 (Windows/Linux and MacOS) (currently for limited set of providers to reduce test time)
- .Net 5.0 (Windows/Linux and MacOS) (currently for limited set of providers to reduce test time) For more details check readme
CI builds are done for all branches and PRs.
- Tests run for all branches and PRs except
release
branch - Nugets publishing to Azure feeds enabled only for
branch
- Nugets publishing to Nuget.org enabled only for
release
branch
If you want to skip building commit by CI (for example you have changed *.md files only) check this message.
- "Nightly" builds packages are published to Azure feeds for each successful build of master branch.
- Release packages are published to Nuget.org for each successful build of release branch.
- Update Release Notes and create empty entry for vNext release
- Create PR from
master
torelease
branch, in comments add @testers to notify all testers that we are ready to release - Wait few days for feedback from testers and approval from contributors
- Merge PR
- Tag release
- Update versions in
master
branch (this will lead to publish all nextmaster
builds as new version RC):- in .\azure-pipelines.yml set
assemblyVersion
andnugetVersion
parameters to next version. Always use next minor version and change it to major only before release, if it should be new major version release
- in .\azure-pipelines.yml set
In general you should follow simple rules:
- Development rules and regulations, code style
- Do not add new features without tests
- Avoid direct pushes to
master
andrelease
branches - To fix some issue or implement new feature create new branch and make pull request after you are ready to merge or create pull request as
work-in-progress
pull request. Merge your PR only after contributors' review. - If you do have repository write access, it is recommended to use central repository instead of fork
- Do not add new public classes, properties, methods without XML documentation on them
- Read issues and help users
- Do not EF :)