Tenemos un proceso donde los guiones de nuestra base de datos cambian (y los utilizan Juneau) a la base de datos de nuestra aplicación fuera de banda con nuestra base de código. Son buenos contabilizando que las columnas nuevas son nulas y no borran los datos existentes, pero de vez en cuando se produce un cambio de nombre de columna que no se comunica por completo. Entonces harán algunos cambios al esquema de la base de datos en un servidor de prueba, actualizaremos Entity Framework para trabajar con esos cambios y luego confirmaremos nuestro código. Este proceso funciona bien, excepto para cuando sea el momento de implementarlo.¿Verifica que el esquema de la base de datos de destino cumpla con lo que está en Entity Framework?
Tenemos TFS configurado para implementar la compilación exitosa en los servidores adecuados, pero no hay garantía de que la base de datos para ese entorno se haya actualizado. No nos importa si hay campos/tablas/vistas adicionales/etc. existen en la base de datos de destino, pero queremos cambiar la compilación para verificar que la base de datos contenga al menos todo lo que EF conoce.
Miré this question, pero no necesito que el esquema coincida exactamente. Además, no queremos que cree/modifique la base de datos directamente. Y this question parece que está tratando de lograr un ideal similar, pero aún no es lo que estamos buscando lograr. Solo queremos una especie de prueba de integración para verificar que nuestra versión de EF funcione con el esquema de destino.
Estoy completamente de acuerdo con el proceso de implementación, pero la persona de la base de datos no confía en los scripts de implementación generados a través de Juneau para automatizar por completo las secuencias de comandos de las actualizaciones de la base de datos. Por lo tanto, debemos verificar que nadie haya realizado un cambio manual en la base de datos de destino, o que solo haya aplicado parcialmente un script actualizado. –