DRN.Framework.EntityFramework 0.2.2-preview002

Prefix Reserved
This is a prerelease version of DRN.Framework.EntityFramework.
There is a newer version of this package available.
See the version list below for details.
dotnet add package DRN.Framework.EntityFramework --version 0.2.2-preview002                
NuGet\Install-Package DRN.Framework.EntityFramework -Version 0.2.2-preview002                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="DRN.Framework.EntityFramework" Version="0.2.2-preview002" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add DRN.Framework.EntityFramework --version 0.2.2-preview002                
#r "nuget: DRN.Framework.EntityFramework, 0.2.2-preview002"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install DRN.Framework.EntityFramework as a Cake Addin
#addin nuget:?package=DRN.Framework.EntityFramework&version=0.2.2-preview002&prerelease

// Install DRN.Framework.EntityFramework as a Cake Tool
#tool nuget:?package=DRN.Framework.EntityFramework&version=0.2.2-preview002&prerelease                

master develop Quality Gate Status

Security Rating Maintainability Rating Reliability Rating Vulnerabilities Bugs Lines of Code Coverage

DRN.Framework.EntityFramework provides DrnContext with conventions to develop rapid and effective domain models.

DRNContext

DrnContext has following unique features:

  • Implements IDesignTimeDbContextFactory to enable migrations from dbContext defining projects.
  • Implements IDesignTimeServices to support multi context projects with default output directories in the context specific folder.
  • Uses HasDrnContextServiceCollectionModule attribute for automatic registration with AddServicesWithAttributes service collection extension method.
  • Uses context name (typeof(TContext).Name) as connection string key by convention.
  • Automatically applies IEntityTypeConfiguration implementations from the assembly whose namespace contains the derived context's namespace.
  • Automatically marks Entities derived from DRN.Framework.SharedKernel.Domain.Entity as created, modified or deleted.
  • Enables DRN.Framework.Testing to create easy and effective integration tests with conventions and automatic registrations.
    • Application modules can be registered without any modification to TestContext
    • TestContext's ContainerContext
      • creates a postgresql container then scans TestContext's service collection for inherited DrnContexts.
      • Adds a connection strings to TestContext's configuration for each DrnContext according to convention.
    • TestContext acts as a ServiceProvider and when a service is requested it can build it from service collection with all dependencies.
namespace DRN.Framework.EntityFramework.Context;

[HasDrnContextServiceCollectionModule]
public abstract class DrnContext<TContext> : DbContext, IDesignTimeDbContextFactory<TContext>, IDesignTimeServices where TContext : DbContext, new()
{ 
...

public class HasDrnContextServiceCollectionModuleAttribute : HasServiceCollectionModuleAttribute
{
    static HasDrnContextServiceCollectionModuleAttribute()
    {
        ModuleMethodInfo = typeof(ServiceCollectionExtensions).GetMethod(nameof(ServiceCollectionExtensions.AddDbContextsWithConventions))!;
    }
}

Example Usage

namespace Sample.Infra;

public static class InfraModule
{
    public static IServiceCollection AddSampleInfraServices(this IServiceCollection sc)
    {
        sc.AddServicesWithAttributes();

        return sc;
    }
}

public class QAContext : DrnContext<QAContext>
{
    public QAContext(DbContextOptions<QAContext> options) : base(options)
    {
    }

    public QAContext() : base(null)
    {
    }

    public DbSet<User> Users { get; set; }
    public DbSet<Question> Questions { get; set; }
    public DbSet<Answer> Answers { get; set; }
    public DbSet<QuestionComment> Comments { get; set; }
    public DbSet<Category> Categories { get; set; }
    public DbSet<Tag> Tags { get; set; }
}

Global Usings

global using DRN.Framework.EntityFramework.Context;
global using Microsoft.EntityFrameworkCore;
global using DRN.Framework.Utils.DependencyInjection;

Commit Info

Author: Duran Serkan KILIÇ
Date: 2024-01-19 00:39:49 +0300
Hash: 9ed2ad070a2da35c57e2741172e1abd7070f38cf

Product 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on DRN.Framework.EntityFramework:

Package Downloads
DRN.Framework.Testing

DRN.Framework.Testing package encapsulates testing dependencies and provides practical, effective helpers such as resourceful data attributes and test context. This package enables a new encouraging testing technique called as DTT(Duran's Testing Technique). With DTT, any developer can write clean and hassle-free unit and integration tests without complexity. ## Commit Info Author: Duran Serkan KILIÇ Date: 2024-11-23 12:55:43 +0300 Hash: 32f0afe1111835522efd4371482436aa3de7c36d

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.7.0-preview004 39 11/23/2024
0.7.0-preview003 32 11/20/2024
0.7.0-preview002 67 11/17/2024
0.7.0-preview001 68 11/14/2024
0.6.0 86 11/10/2024
0.6.0-preview002 77 11/10/2024
0.6.0-preview001 77 11/10/2024
0.5.1-preview002 76 9/30/2024
0.5.1-preview001 75 9/22/2024
0.5.0 113 8/30/2024
0.5.0-preview011 82 8/30/2024
0.5.0-preview010 111 8/25/2024
0.5.0-preview009 100 8/8/2024
0.5.0-preview008 101 8/7/2024
0.5.0-preview007 63 8/2/2024
0.5.0-preview006 65 7/30/2024
0.5.0-preview005 92 7/27/2024
0.5.0-preview004 84 7/15/2024
0.5.0-preview003 107 6/6/2024
0.5.0-preview002 99 6/5/2024
0.5.0-preview001 95 6/4/2024
0.4.0 88 5/19/2024
0.4.0-preview006 75 5/19/2024
0.4.0-preview005 99 5/12/2024
0.4.0-preview004 94 5/12/2024
0.4.0-preview003 101 5/11/2024
0.4.0-preview002 120 5/8/2024
0.4.0-preview001 110 5/5/2024
0.3.1-preview001 94 4/26/2024
0.3.0 110 4/23/2024
0.3.0-preview002 94 4/23/2024
0.3.0-preview001 106 4/23/2024
0.2.2-preview010 111 4/11/2024
0.2.2-preview009 94 3/18/2024
0.2.2-preview008 90 3/18/2024
0.2.2-preview007 106 3/16/2024
0.2.2-preview006 85 3/11/2024
0.2.2-preview005 89 3/10/2024
0.2.2-preview004 90 3/10/2024
0.2.2-preview003 136 1/22/2024
0.2.2-preview002 106 1/18/2024
0.2.2-preview001 109 1/14/2024
0.2.1 184 1/7/2024
0.2.0 110 12/31/2023
0.2.0-preview009 85 12/31/2023
0.2.0-preview008 86 12/30/2023
0.2.0-preview007 94 12/28/2023
0.2.0-preview006 85 12/27/2023
0.2.0-preview005 86 12/25/2023
0.2.0-preview004 92 12/23/2023
0.2.0-preview003 94 12/20/2023
0.2.0-preview002 83 12/19/2023

Not every version includes changes, features or bug fixes. This project can increment version to keep consistency with other DRN.Framework projects.

## Version 0.2.0

### Breaking Changes

### New Features
* DrnContext added
   * Implemented IDesignTimeDbContextFactory to enable migrations from dbContext defining projects.
   * Implemented IDesignTimeServices to support multi context projects with default output directory in the context specific folder.
   * Uses HasDrnContextServiceCollectionModule to automatic registration with AddServicesWithAttributes service collection extension method.
   * Uses context name (typeof(TContext).Name) as connection string key by convention.
   * Enables DRN.Framework.Testing to create easy and effective integration tests with conventions and automatic registrations.

### Bug Fixes  
 
## Commit Info  
Author: Duran Serkan KILIÇ  
Date: 2024-01-19 00:39:49 +0300  
Hash: 9ed2ad070a2da35c57e2741172e1abd7070f38cf