Skip to content

🛠️ Simplifies EF management by helping to squash migrations

Notifications You must be signed in to change notification settings

pdevito3/StewardEF

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 

Repository files navigation

StewardEF 🛠️

StewardEF is a tool designed to make managing Entity Framework (EF) migrations easier for projects with a lengthy history. Specifically, it is able to squash your migrations back to a single file and drastically speed up your build times.

EF Core does not yet provide a built-in solution for squashing migrations yet (relevant issue here), but in the meantime, StewardEF can help fill the gap.


Installation

Install the StewardEF dotnet tool:

dotnet tool install -g StewardEF

Commands

squash

Squashes EF migrations into the first migration in the specified directory.

Usage:

steward squash -d path/to/migrations [-y year] [-t target]
Options
  • -d (or [MigrationsDirectory]): Path to the directory containing your EF migrations. If omitted, you'll be prompted to enter it interactively.
  • -y (or [Year]): Optional. Specify the year up to which migrations should be squashed. If omitted, all migrations will be squashed.
  • -t (or [TargetMigration]): Optional. Specify the target migration up to which migrations should be squashed. If omitted, all migrations will be squashed.

How It Works

⚠️ The squash command will modify your migrations files, so please be sure to start with a clean commit before squashing so you can easily undo your changes if needed

The squash command combines all existing migrations into a single, consolidated migration file. Here's how it works:

  • Combines Migration Methods: Aggregates the Up and Down methods across all migration files.
  • Retains Important Using Statements: Collects using statements from all migrations, ensuring no dependencies are missed.
  • Preserves the First Migration: Inserts the combined code into the first migration file in the specified directory.
  • Removes Redundant Files: Deletes all migrations except the first one, leaving a single, squashed migration.

Depending on how your migrations were structured, you might need to make some manual adjustments after running squash. Some things to watch for:

  • Private Fields: If any private readonly fields or other member data are in your migrations, ensure they're properly defined in the combined migration file.
  • Variable Conflicts: Sometimes migrations contain variables with the same name across different files. Double-check the final file for duplicate variables and resolve them accordingly.

About

🛠️ Simplifies EF management by helping to squash migrations

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages