Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
SchemaSqlMojo |
|
| 2.5;2.5 |
1 | package org.apache.torque.mojo; | |
2 | ||
3 | import org.apache.maven.plugin.MojoExecutionException; | |
4 | import org.apache.torque.util.ChangeDetector; | |
5 | ||
6 | /** | |
7 | * Generates platform specific SQL from database agnostic XML files.<br> | |
8 | * <br> | |
9 | * There are two types of SQL files created by this goal:<br> | |
10 | * <br> | |
11 | * Type 1: DDL statements for creating tables, primary keys, indexes, and unique constraints. Does not contain DDL for | |
12 | * enforcing relationships between tables.<br> | |
13 | * Type 2: DDL statements for creating and enforcing relationships between tables<br> | |
14 | * <br> | |
15 | * This allows data to be imported into multiple tables concurrently. Running the first type of SQL file will create the | |
16 | * empty tables without any foreign key constraints. Data can then be loaded concurrently into the tables (using | |
17 | * optimized high speed tools if desired) without needing to worry about the order in which the tables are loaded. After | |
18 | * data has been loaded, the second type of SQL file can be run to add the relationships between the tables. As long as | |
19 | * the data set is consistent and correct, all the relationships will get created correctly.<br> | |
20 | * <br> | |
21 | * The database platform to generate SQL for is determined by ${targetDatabase}. See also <code>impex:datasql</code> | |
22 | * | |
23 | * @goal schemasql | |
24 | * @phase generate-sources | |
25 | */ | |
26 | 0 | public class SchemaSqlMojo extends SqlMojoBase { |
27 | ||
28 | /** | |
29 | * The directory in which the SQL will be generated. | |
30 | * | |
31 | * @parameter property="outputDir" expression="${outputDir}" default-value="${project.build.directory}/classes/sql" | |
32 | */ | |
33 | @SuppressWarnings("unused") | |
34 | private String dummy1; | |
35 | ||
36 | /** | |
37 | * The location where the report file will be generated. | |
38 | * | |
39 | * @parameter property="reportFile" expression="${reportFile}" default-value= | |
40 | * "../../../reports/report.${project.artifactId}.sql.generation" | |
41 | */ | |
42 | @SuppressWarnings("unused") | |
43 | private String dummy2; | |
44 | ||
45 | /** | |
46 | * The location where the context property file for velocity will be generated. | |
47 | * | |
48 | * @parameter property="contextPropertiesPath" expression="${contextPropertiesPath}" | |
49 | * default-value="${project.build.directory}/reports/context.sql.properties" | |
50 | */ | |
51 | @SuppressWarnings("unused") | |
52 | private String dummy3; | |
53 | ||
54 | /** | |
55 | * The suffix of the generated sql files. | |
56 | * | |
57 | * @parameter property="suffix" expression="${suffix}" | |
58 | */ | |
59 | @SuppressWarnings("unused") | |
60 | private String dummy4; | |
61 | ||
62 | protected void showConfig() { | |
63 | 0 | getLog().info("Schema Dir: " + getSchemaDir()); |
64 | 0 | getLog().info("Includes: " + getSchemaIncludes()); |
65 | 0 | getLog().info("Excludes: " + getSchemaExcludes()); |
66 | 0 | } |
67 | ||
68 | /** | |
69 | * Generate SQL from schema XML files | |
70 | */ | |
71 | @Override | |
72 | public void executeMojo() throws MojoExecutionException { | |
73 | 0 | updateConfiguration(); |
74 | 0 | validateConfiguration(); |
75 | 0 | generateContextProperties(); |
76 | 0 | configureTask(); |
77 | 0 | addTargetDatabaseToOutputDir(); |
78 | 0 | addTargetDatabaseToReportFile(); |
79 | 0 | showConfig(); |
80 | 0 | ChangeDetector detector = new ChangeDetector(getCanonicalReportFile(), getSchemaFiles()); |
81 | 0 | if (!detector.isChanged() && isRunOnlyOnSchemaChange()) { |
82 | 0 | getLog().info("Schema has not changed. Skipping generation"); |
83 | 0 | return; |
84 | } | |
85 | 0 | getLog().info("------------------------------------------------------------------------"); |
86 | 0 | getLog().info("Generating SQL for " + getTargetDatabase() + " from schema XML files"); |
87 | 0 | getLog().info("------------------------------------------------------------------------"); |
88 | 0 | getAntTask().execute(); |
89 | 0 | } |
90 | } |