...
- CI continuously monitors the 3 system of record locations
- As soon as a change is detected, a job is fired to generate SQL from the system of record locations
- The job generates SQL for MySQL and Oracle
- Any new or altered SQL is checked into its corresponding generated location
- Any old SQL is removed from its corresponding location
- This assures the SQL GENERATED locations are kept in sync with the SYSTEM OF RECORD locations as changes are committed
- The CI job also creates metadata describing the SQL files for each location -
src/main/resources/META-INF
- As soon as the SQL generation completes, a CI job is fired to execute the SQL
- The SQL execution job executes the SQL for both MySQL and Oracle against test databases
- The SQL execution job is a lightweight Spring based component at its core
- The Spring based nature of the SQL execution decouples the database creation process from:
- The file system
- The build system
- Source code management system
- "Other" random requirements imposed by the tooling being used to convert database agnostic XML into database specific SQL
- It also happens to run faster, but execution speed should be viewed as a side benefit and is not really the point or focus