Мы используем инструмент migrate.exe Entity Framework 4.3.1 для выполнения миграции базы данных с нашего сервера сборки TeamCity в рамках нашей непрерывной интеграции и автоматизации развертывания. Одна из этих проблем, с которыми мы столкнулись, заключается в том, что инструмент migrate.exe не выдает ненулевой код выхода при сбое:
C:\<path>\packages\EntityFramework.4.3.1\tools>migrate.exe AppContext /startupdirectory:C:\<path>\bin\Debug /startupconfigurationfile:C:\<path>\Web.config /verbose
<Bunch of successful migrations>
Applying explicit migration: 201202212004585_UpdateTable
VERBOSE: ALTER TABLE [TableA] DROP CONSTRAINT [FK_TableA_TableB]
System.Data.Entity.Migrations.Design.ToolingException: 'FK_TableA_TableB' is not a constraint.
Could not drop constraint. See previous errors.
at System.Data.Entity.Migrations.Design.ToolingFacade.Run(BaseRunner runner)
at System.Data.Entity.Migrations.Design.ToolingFacade.Update(String targetMig
ration, Boolean force)
at System.Data.Entity.Migrations.Console.Program.Run()
at System.Data.Entity.Migrations.Console.Program.Main(String[] args)
ERROR: 'FK_TableA_TableB' is not a constraint.
Could not drop constraint. See previous errors.
C:\<path>\packages\EntityFramework.4.3.1\tools>echo %errorlevel%
0
Это приводит к тому, что Team City выдает сборку за «успешную», когда миграция завершается с ошибкой, а она должна быть неудачной.
Наш временный обходной путь заключается в поиске в журнале сборки «ОШИБКИ:» и сбое сборки, когда это происходит, но это решение является грубым, и мы не можем определить, произошел ли сбой EF или какой-либо другой процесс с аналогичной записью в журнале.
Любые предложения по улучшению работы? Либо способ заставить программу migrate.exe работать, либо способ заставить Team City понять, что сбой связан именно с migrate.exe.