From f6fa58ff723daab45b98ca77193dc7edcb5154a3 Mon Sep 17 00:00:00 2001 From: Vijay Garg Date: Thu, 18 Jul 2024 20:42:21 +0530 Subject: [PATCH] Add new dataquality generation module (#2967) * Add new dataquality generation module * remove unncessary relational store dependencies --- .../legend-engine-xt-dataquality-api/pom.xml | 11 +- .../dataquality/api/DataQualityExecute.java | 1 + ...tion.extension.ArtifactGenerationExtension | 1 - .../pom.xml | 155 ++ .../DataQualityLambdaGenerator.java | 2 +- ...ValidationArtifactGenerationExtension.java | 3 +- ...tion.extension.ArtifactGenerationExtension | 1 + ...ValidationArtifactGenerationExtension.java | 2 +- .../modelWithDataQualityValidation.json | 1533 +++++++++++++++++ legend-engine-xts-dataquality/pom.xml | 1 + 10 files changed, 1701 insertions(+), 9 deletions(-) delete mode 100644 legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/resources/META-INF/services/org.finos.legend.engine.language.pure.dsl.generation.extension.ArtifactGenerationExtension create mode 100644 legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/pom.xml rename legend-engine-xts-dataquality/{legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/api => legend-engine-xt-dataquality-generation/src/main/java/org/finos/legend/engine/generation/dataquality}/DataQualityLambdaGenerator.java (97%) rename legend-engine-xts-dataquality/{legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/deployment => legend-engine-xt-dataquality-generation/src/main/java/org/finos/legend/engine/generation/dataquality}/DataQualityValidationArtifactGenerationExtension.java (97%) create mode 100644 legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/resources/META-INF.services/org.finos.legend.engine.language.pure.dsl.generation.extension.ArtifactGenerationExtension rename legend-engine-xts-dataquality/{legend-engine-xt-dataquality-api/src/test/java/org/finos/legend/engine/language/dataquality/deployment => legend-engine-xt-dataquality-generation/src/test/java/org/finos/legend/engine/generation/dataquality}/TestDataQualityValidationArtifactGenerationExtension.java (98%) create mode 100644 legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/test/resources/inputs/modelWithDataQualityValidation.json diff --git a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/pom.xml b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/pom.xml index a6a9bde1426..f6fd5397acc 100644 --- a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/pom.xml +++ b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/pom.xml @@ -62,10 +62,6 @@ legend-engine-xt-relationalStore-javaPlatformBinding-pure runtime - - org.finos.legend.engine - legend-engine-pure-code-core-extension - org.finos.legend.engine legend-engine-xt-relationalStore-pure @@ -127,6 +123,7 @@ httpclient + org.finos.legend.engine legend-engine-xt-dataquality-protocol @@ -137,6 +134,11 @@ legend-engine-xt-dataquality-pure ${project.version} + + org.finos.legend.engine + legend-engine-xt-dataquality-generation + ${project.version} + org.finos.legend.engine legend-engine-xt-dataquality-grammar @@ -149,6 +151,7 @@ runtime ${project.version} + diff --git a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/api/DataQualityExecute.java b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/api/DataQualityExecute.java index 03dffd58272..cd85b2fc009 100644 --- a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/api/DataQualityExecute.java +++ b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/api/DataQualityExecute.java @@ -26,6 +26,7 @@ import org.eclipse.collections.api.factory.Maps; import org.eclipse.collections.api.list.MutableList; import org.eclipse.collections.api.map.MutableMap; +import org.finos.legend.engine.generation.dataquality.DataQualityLambdaGenerator; import org.finos.legend.engine.language.pure.compiler.toPureGraph.PureModel; import org.finos.legend.engine.language.pure.modelManager.ModelManager; import org.finos.legend.engine.language.pure.modelManager.sdlc.configuration.MetaDataServerConfiguration; diff --git a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/resources/META-INF/services/org.finos.legend.engine.language.pure.dsl.generation.extension.ArtifactGenerationExtension b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/resources/META-INF/services/org.finos.legend.engine.language.pure.dsl.generation.extension.ArtifactGenerationExtension deleted file mode 100644 index 892b5e69787..00000000000 --- a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/resources/META-INF/services/org.finos.legend.engine.language.pure.dsl.generation.extension.ArtifactGenerationExtension +++ /dev/null @@ -1 +0,0 @@ -org.finos.legend.engine.language.dataquality.deployment.DataQualityValidationArtifactGenerationExtension diff --git a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/pom.xml b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/pom.xml new file mode 100644 index 00000000000..d9a8bf9900c --- /dev/null +++ b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/pom.xml @@ -0,0 +1,155 @@ + + + + legend-engine-xts-dataquality + org.finos.legend.engine + 4.51.2-SNAPSHOT + + 4.0.0 + + legend-engine-xt-dataquality-generation + jar + Legend Engine - XT - DataQuality - Generation + + + + 11 + 11 + + + + + + org.finos.legend.engine + legend-engine-xt-dataquality-protocol + ${project.version} + + + org.finos.legend.engine + legend-engine-xt-dataquality-pure + ${project.version} + + + org.finos.legend.engine + legend-engine-xt-dataquality-grammar + runtime + ${project.version} + + + org.finos.legend.engine + legend-engine-xt-dataquality-compiler + runtime + ${project.version} + + + + + + org.eclipse.collections + eclipse-collections-api + + + + + + org.finos.legend.engine + legend-engine-pure-code-compiled-core + + + org.finos.legend.pure + legend-pure-m3-core + + + + + + org.finos.legend.engine + legend-engine-pure-code-core-extension + + + org.finos.legend.engine + legend-engine-shared-core + + + org.finos.legend.engine + legend-engine-protocol-pure + + + org.finos.legend.engine + legend-engine-language-pure-compiler + + + org.finos.legend.engine + legend-engine-executionPlan-generation + + + org.finos.legend.engine + legend-engine-identity-core + ${project.version} + + + org.finos.legend.engine + legend-engine-language-pure-dsl-generation + + + org.finos.legend.engine + legend-engine-xt-relationalStore-javaPlatformBinding-pure + runtime + + + + + + com.fasterxml.jackson.core + jackson-databind + + + + + + org.eclipse.collections + eclipse-collections + + + + + + org.slf4j + slf4j-api + + + + + + junit + junit + test + + + org.finos.legend.engine + legend-engine-shared-core + test-jar + test + + + org.glassfish.jersey.core + jersey-common + test + + + org.finos.legend.engine + legend-engine-language-pure-compiler + test-jar + test + + + + com.h2database + h2 + test + + + + diff --git a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/api/DataQualityLambdaGenerator.java b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/java/org/finos/legend/engine/generation/dataquality/DataQualityLambdaGenerator.java similarity index 97% rename from legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/api/DataQualityLambdaGenerator.java rename to legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/java/org/finos/legend/engine/generation/dataquality/DataQualityLambdaGenerator.java index 3af91656fcc..a44d7b7061a 100644 --- a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/api/DataQualityLambdaGenerator.java +++ b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/java/org/finos/legend/engine/generation/dataquality/DataQualityLambdaGenerator.java @@ -12,7 +12,7 @@ // See the License for the specific language governing permissions and // limitations under the License. -package org.finos.legend.engine.language.dataquality.api; +package org.finos.legend.engine.generation.dataquality; import org.eclipse.collections.impl.factory.Lists; import org.finos.legend.engine.language.pure.compiler.toPureGraph.PureModel; diff --git a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/deployment/DataQualityValidationArtifactGenerationExtension.java b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/java/org/finos/legend/engine/generation/dataquality/DataQualityValidationArtifactGenerationExtension.java similarity index 97% rename from legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/deployment/DataQualityValidationArtifactGenerationExtension.java rename to legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/java/org/finos/legend/engine/generation/dataquality/DataQualityValidationArtifactGenerationExtension.java index 585ee6f1d61..6b640b385cf 100644 --- a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/main/java/org/finos/legend/engine/language/dataquality/deployment/DataQualityValidationArtifactGenerationExtension.java +++ b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/java/org/finos/legend/engine/generation/dataquality/DataQualityValidationArtifactGenerationExtension.java @@ -12,13 +12,12 @@ // See the License for the specific language governing permissions and // limitations under the License. -package org.finos.legend.engine.language.dataquality.deployment; +package org.finos.legend.engine.generation.dataquality; import com.fasterxml.jackson.databind.ObjectMapper; import org.eclipse.collections.api.RichIterable; import org.eclipse.collections.api.block.function.Function; import org.eclipse.collections.api.factory.Lists; -import org.finos.legend.engine.language.dataquality.api.DataQualityLambdaGenerator; import org.finos.legend.engine.language.pure.compiler.toPureGraph.PureModel; import org.finos.legend.engine.language.pure.dsl.generation.extension.Artifact; import org.finos.legend.engine.language.pure.dsl.generation.extension.ArtifactGenerationExtension; diff --git a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/resources/META-INF.services/org.finos.legend.engine.language.pure.dsl.generation.extension.ArtifactGenerationExtension b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/resources/META-INF.services/org.finos.legend.engine.language.pure.dsl.generation.extension.ArtifactGenerationExtension new file mode 100644 index 00000000000..30f41e36796 --- /dev/null +++ b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/main/resources/META-INF.services/org.finos.legend.engine.language.pure.dsl.generation.extension.ArtifactGenerationExtension @@ -0,0 +1 @@ +org.finos.legend.engine.generation.dataquality.DataQualityValidationArtifactGenerationExtension diff --git a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/test/java/org/finos/legend/engine/language/dataquality/deployment/TestDataQualityValidationArtifactGenerationExtension.java b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/test/java/org/finos/legend/engine/generation/dataquality/TestDataQualityValidationArtifactGenerationExtension.java similarity index 98% rename from legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/test/java/org/finos/legend/engine/language/dataquality/deployment/TestDataQualityValidationArtifactGenerationExtension.java rename to legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/test/java/org/finos/legend/engine/generation/dataquality/TestDataQualityValidationArtifactGenerationExtension.java index 6020161953c..740a5604c59 100644 --- a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-api/src/test/java/org/finos/legend/engine/language/dataquality/deployment/TestDataQualityValidationArtifactGenerationExtension.java +++ b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/test/java/org/finos/legend/engine/generation/dataquality/TestDataQualityValidationArtifactGenerationExtension.java @@ -12,7 +12,7 @@ // See the License for the specific language governing permissions and // limitations under the License. -package org.finos.legend.engine.language.dataquality.deployment; +package org.finos.legend.engine.generation.dataquality; import org.finos.legend.engine.language.pure.compiler.Compiler; import org.finos.legend.engine.language.pure.compiler.toPureGraph.PureModel; diff --git a/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/test/resources/inputs/modelWithDataQualityValidation.json b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/test/resources/inputs/modelWithDataQualityValidation.json new file mode 100644 index 00000000000..ca5cafab1d9 --- /dev/null +++ b/legend-engine-xts-dataquality/legend-engine-xt-dataquality-generation/src/test/resources/inputs/modelWithDataQualityValidation.json @@ -0,0 +1,1533 @@ +{ + "_type": "data", + "elements": [ + { + "_type": "connection", + "connectionValue": { + "_type": "RelationalDatabaseConnection", + "authenticationStrategy": { + "_type": "h2Default", + "sourceInformation": { + "endColumn": 18, + "endLine": 10, + "sourceId": "", + "startColumn": 3, + "startLine": 10 + } + }, + "databaseType": "H2", + "datasourceSpecification": { + "_type": "h2Local", + "sourceInformation": { + "endColumn": 4, + "endLine": 9, + "sourceId": "", + "startColumn": 3, + "startLine": 6 + }, + "testDataSetupSqls": [] + }, + "element": "meta::dataquality::db", + "elementSourceInformation": { + "endColumn": 30, + "endLine": 4, + "sourceId": "", + "startColumn": 10, + "startLine": 4 + }, + "postProcessorWithParameter": [], + "sourceInformation": { + "endColumn": 1, + "endLine": 11, + "sourceId": "", + "startColumn": 1, + "startLine": 2 + }, + "type": "H2" + }, + "name": "H2", + "package": "meta::dataquality", + "sourceInformation": { + "endColumn": 1, + "endLine": 11, + "sourceId": "", + "startColumn": 1, + "startLine": 2 + } + }, + { + "_type": "relational", + "filters": [], + "includedStores": [], + "joins": [ + { + "name": "Address_Person", + "operation": { + "_type": "dynaFunc", + "funcName": "equal", + "parameters": [ + { + "_type": "column", + "column": "ID", + "sourceInformation": { + "endColumn": 62, + "endLine": 20, + "sourceId": "", + "startColumn": 24, + "startLine": 20 + }, + "table": { + "_type": "Table", + "database": "meta::dataquality::db", + "mainTableDb": "meta::dataquality::db", + "schema": "default", + "sourceInformation": { + "endColumn": 35, + "endLine": 20, + "sourceId": "", + "startColumn": 24, + "startLine": 20 + }, + "table": "addressTable" + }, + "tableAlias": "addressTable" + }, + { + "_type": "column", + "column": "ADDRESSID", + "sourceInformation": { + "endColumn": 62, + "endLine": 20, + "sourceId": "", + "startColumn": 42, + "startLine": 20 + }, + "table": { + "_type": "Table", + "database": "meta::dataquality::db", + "mainTableDb": "meta::dataquality::db", + "schema": "default", + "sourceInformation": { + "endColumn": 52, + "endLine": 20, + "sourceId": "", + "startColumn": 42, + "startLine": 20 + }, + "table": "personTable" + }, + "tableAlias": "personTable" + } + ], + "sourceInformation": { + "endColumn": 62, + "endLine": 20, + "sourceId": "", + "startColumn": 40, + "startLine": 20 + } + }, + "sourceInformation": { + "endColumn": 63, + "endLine": 20, + "sourceId": "", + "startColumn": 4, + "startLine": 20 + } + }, + { + "name": "Address_Location", + "operation": { + "_type": "dynaFunc", + "funcName": "equal", + "parameters": [ + { + "_type": "column", + "column": "LOCATIONID", + "sourceInformation": { + "endColumn": 67, + "endLine": 21, + "sourceId": "", + "startColumn": 26, + "startLine": 21 + }, + "table": { + "_type": "Table", + "database": "meta::dataquality::db", + "mainTableDb": "meta::dataquality::db", + "schema": "default", + "sourceInformation": { + "endColumn": 37, + "endLine": 21, + "sourceId": "", + "startColumn": 26, + "startLine": 21 + }, + "table": "addressTable" + }, + "tableAlias": "addressTable" + }, + { + "_type": "column", + "column": "ID", + "sourceInformation": { + "endColumn": 67, + "endLine": 21, + "sourceId": "", + "startColumn": 52, + "startLine": 21 + }, + "table": { + "_type": "Table", + "database": "meta::dataquality::db", + "mainTableDb": "meta::dataquality::db", + "schema": "default", + "sourceInformation": { + "endColumn": 64, + "endLine": 21, + "sourceId": "", + "startColumn": 52, + "startLine": 21 + }, + "table": "locationTable" + }, + "tableAlias": "locationTable" + } + ], + "sourceInformation": { + "endColumn": 67, + "endLine": 21, + "sourceId": "", + "startColumn": 50, + "startLine": 21 + } + }, + "sourceInformation": { + "endColumn": 68, + "endLine": 21, + "sourceId": "", + "startColumn": 4, + "startLine": 21 + } + } + ], + "name": "db", + "package": "meta::dataquality", + "schemas": [ + { + "name": "default", + "sourceInformation": { + "endColumn": 1, + "endLine": 22, + "sourceId": "", + "startColumn": 1, + "startLine": 14 + }, + "tables": [ + { + "columns": [ + { + "name": "ID", + "nullable": false, + "sourceInformation": { + "endColumn": 40, + "endLine": 16, + "sourceId": "", + "startColumn": 23, + "startLine": 16 + }, + "type": { + "_type": "Integer" + } + }, + { + "name": "FIRSTNAME", + "nullable": true, + "sourceInformation": { + "endColumn": 64, + "endLine": 16, + "sourceId": "", + "startColumn": 43, + "startLine": 16 + }, + "type": { + "_type": "Varchar", + "size": 200 + } + }, + { + "name": "LASTNAME", + "nullable": true, + "sourceInformation": { + "endColumn": 87, + "endLine": 16, + "sourceId": "", + "startColumn": 67, + "startLine": 16 + }, + "type": { + "_type": "Varchar", + "size": 200 + } + }, + { + "name": "AGE", + "nullable": true, + "sourceInformation": { + "endColumn": 96, + "endLine": 16, + "sourceId": "", + "startColumn": 90, + "startLine": 16 + }, + "type": { + "_type": "Integer" + } + }, + { + "name": "ADDRESSID", + "nullable": true, + "sourceInformation": { + "endColumn": 111, + "endLine": 16, + "sourceId": "", + "startColumn": 99, + "startLine": 16 + }, + "type": { + "_type": "Integer" + } + }, + { + "name": "FIRMID", + "nullable": true, + "sourceInformation": { + "endColumn": 123, + "endLine": 16, + "sourceId": "", + "startColumn": 114, + "startLine": 16 + }, + "type": { + "_type": "Integer" + } + } + ], + "milestoning": [], + "name": "personTable", + "primaryKey": [ + "ID" + ], + "sourceInformation": { + "endColumn": 124, + "endLine": 16, + "sourceId": "", + "startColumn": 4, + "startLine": 16 + } + }, + { + "columns": [ + { + "name": "ID", + "nullable": false, + "sourceInformation": { + "endColumn": 41, + "endLine": 17, + "sourceId": "", + "startColumn": 24, + "startLine": 17 + }, + "type": { + "_type": "Integer" + } + }, + { + "name": "LOCATIONID", + "nullable": true, + "sourceInformation": { + "endColumn": 57, + "endLine": 17, + "sourceId": "", + "startColumn": 44, + "startLine": 17 + }, + "type": { + "_type": "Integer" + } + }, + { + "name": "TYPE", + "nullable": true, + "sourceInformation": { + "endColumn": 67, + "endLine": 17, + "sourceId": "", + "startColumn": 60, + "startLine": 17 + }, + "type": { + "_type": "Integer" + } + } + ], + "milestoning": [], + "name": "addressTable", + "primaryKey": [ + "ID" + ], + "sourceInformation": { + "endColumn": 68, + "endLine": 17, + "sourceId": "", + "startColumn": 4, + "startLine": 17 + } + }, + { + "columns": [ + { + "name": "ID", + "nullable": false, + "sourceInformation": { + "endColumn": 42, + "endLine": 18, + "sourceId": "", + "startColumn": 25, + "startLine": 18 + }, + "type": { + "_type": "Integer" + } + }, + { + "name": "STREET", + "nullable": true, + "sourceInformation": { + "endColumn": 63, + "endLine": 18, + "sourceId": "", + "startColumn": 45, + "startLine": 18 + }, + "type": { + "_type": "Varchar", + "size": 200 + } + }, + { + "name": "LOCALITY", + "nullable": true, + "sourceInformation": { + "endColumn": 86, + "endLine": 18, + "sourceId": "", + "startColumn": 66, + "startLine": 18 + }, + "type": { + "_type": "Varchar", + "size": 200 + } + } + ], + "milestoning": [], + "name": "locationTable", + "primaryKey": [ + "ID" + ], + "sourceInformation": { + "endColumn": 87, + "endLine": 18, + "sourceId": "", + "startColumn": 4, + "startLine": 18 + } + } + ], + "views": [] + } + ], + "sourceInformation": { + "endColumn": 1, + "endLine": 22, + "sourceId": "", + "startColumn": 1, + "startLine": 14 + }, + "stereotypes": [] + }, + { + "_type": "mapping", + "associationMappings": [], + "classMappings": [ + { + "_type": "relational", + "class": "meta::dataquality::Person", + "classSourceInformation": { + "endColumn": 28, + "endLine": 29, + "sourceId": "", + "startColumn": 4, + "startLine": 29 + }, + "distinct": false, + "groupBy": [], + "primaryKey": [], + "propertyMappings": [ + { + "_type": "relationalPropertyMapping", + "property": { + "class": "meta::dataquality::Person", + "property": "name", + "sourceInformation": { + "endColumn": 10, + "endLine": 31, + "sourceId": "", + "startColumn": 7, + "startLine": 31 + } + }, + "relationalOperation": { + "_type": "column", + "column": "FIRSTNAME", + "sourceInformation": { + "endColumn": 57, + "endLine": 31, + "sourceId": "", + "startColumn": 14, + "startLine": 31 + }, + "table": { + "_type": "Table", + "database": "meta::dataquality::db", + "mainTableDb": "meta::dataquality::db", + "schema": "default", + "sourceInformation": { + "endColumn": 47, + "endLine": 31, + "sourceId": "", + "startColumn": 37, + "startLine": 31 + }, + "table": "personTable" + }, + "tableAlias": "personTable" + }, + "sourceInformation": { + "endColumn": 57, + "endLine": 31, + "sourceId": "", + "startColumn": 12, + "startLine": 31 + } + }, + { + "_type": "relationalPropertyMapping", + "property": { + "class": "meta::dataquality::Person", + "property": "age", + "sourceInformation": { + "endColumn": 9, + "endLine": 32, + "sourceId": "", + "startColumn": 7, + "startLine": 32 + } + }, + "relationalOperation": { + "_type": "column", + "column": "AGE", + "sourceInformation": { + "endColumn": 50, + "endLine": 32, + "sourceId": "", + "startColumn": 13, + "startLine": 32 + }, + "table": { + "_type": "Table", + "database": "meta::dataquality::db", + "mainTableDb": "meta::dataquality::db", + "schema": "default", + "sourceInformation": { + "endColumn": 46, + "endLine": 32, + "sourceId": "", + "startColumn": 36, + "startLine": 32 + }, + "table": "personTable" + }, + "tableAlias": "personTable" + }, + "sourceInformation": { + "endColumn": 50, + "endLine": 32, + "sourceId": "", + "startColumn": 11, + "startLine": 32 + } + }, + { + "_type": "relationalPropertyMapping", + "property": { + "class": "meta::dataquality::Person", + "property": "addresses", + "sourceInformation": { + "endColumn": 15, + "endLine": 33, + "sourceId": "", + "startColumn": 7, + "startLine": 33 + } + }, + "relationalOperation": { + "_type": "elemtWithJoins", + "joins": [ + { + "db": "meta::dataquality::db", + "name": "Address_Person", + "sourceInformation": { + "endColumn": 56, + "endLine": 33, + "sourceId": "", + "startColumn": 42, + "startLine": 33 + } + } + ], + "sourceInformation": { + "endColumn": 56, + "endLine": 33, + "sourceId": "", + "startColumn": 19, + "startLine": 33 + } + }, + "sourceInformation": { + "endColumn": 56, + "endLine": 33, + "sourceId": "", + "startColumn": 17, + "startLine": 33 + } + } + ], + "root": false, + "sourceInformation": { + "endColumn": 4, + "endLine": 34, + "sourceId": "", + "startColumn": 4, + "startLine": 29 + } + }, + { + "_type": "relational", + "class": "meta::dataquality::Address", + "classSourceInformation": { + "endColumn": 29, + "endLine": 36, + "sourceId": "", + "startColumn": 4, + "startLine": 36 + }, + "distinct": false, + "groupBy": [], + "primaryKey": [], + "propertyMappings": [ + { + "_type": "relationalPropertyMapping", + "property": { + "class": "meta::dataquality::Address", + "property": "addressId", + "sourceInformation": { + "endColumn": 15, + "endLine": 38, + "sourceId": "", + "startColumn": 7, + "startLine": 38 + } + }, + "relationalOperation": { + "_type": "column", + "column": "ID", + "sourceInformation": { + "endColumn": 56, + "endLine": 38, + "sourceId": "", + "startColumn": 19, + "startLine": 38 + }, + "table": { + "_type": "Table", + "database": "meta::dataquality::db", + "mainTableDb": "meta::dataquality::db", + "schema": "default", + "sourceInformation": { + "endColumn": 53, + "endLine": 38, + "sourceId": "", + "startColumn": 42, + "startLine": 38 + }, + "table": "addressTable" + }, + "tableAlias": "addressTable" + }, + "sourceInformation": { + "endColumn": 56, + "endLine": 38, + "sourceId": "", + "startColumn": 17, + "startLine": 38 + } + }, + { + "_type": "relationalPropertyMapping", + "property": { + "class": "meta::dataquality::Address", + "property": "location", + "sourceInformation": { + "endColumn": 14, + "endLine": 39, + "sourceId": "", + "startColumn": 7, + "startLine": 39 + } + }, + "relationalOperation": { + "_type": "elemtWithJoins", + "joins": [ + { + "db": "meta::dataquality::db", + "name": "Address_Location", + "sourceInformation": { + "endColumn": 57, + "endLine": 39, + "sourceId": "", + "startColumn": 41, + "startLine": 39 + } + } + ], + "sourceInformation": { + "endColumn": 57, + "endLine": 39, + "sourceId": "", + "startColumn": 18, + "startLine": 39 + } + }, + "sourceInformation": { + "endColumn": 57, + "endLine": 39, + "sourceId": "", + "startColumn": 16, + "startLine": 39 + } + } + ], + "root": false, + "sourceInformation": { + "endColumn": 4, + "endLine": 40, + "sourceId": "", + "startColumn": 4, + "startLine": 36 + } + }, + { + "_type": "relational", + "class": "meta::dataquality::Location", + "classSourceInformation": { + "endColumn": 30, + "endLine": 42, + "sourceId": "", + "startColumn": 4, + "startLine": 42 + }, + "distinct": false, + "groupBy": [], + "primaryKey": [], + "propertyMappings": [ + { + "_type": "relationalPropertyMapping", + "property": { + "class": "meta::dataquality::Location", + "property": "street", + "sourceInformation": { + "endColumn": 12, + "endLine": 44, + "sourceId": "", + "startColumn": 7, + "startLine": 44 + } + }, + "relationalOperation": { + "_type": "column", + "column": "STREET", + "sourceInformation": { + "endColumn": 58, + "endLine": 44, + "sourceId": "", + "startColumn": 16, + "startLine": 44 + }, + "table": { + "_type": "Table", + "database": "meta::dataquality::db", + "mainTableDb": "meta::dataquality::db", + "schema": "default", + "sourceInformation": { + "endColumn": 51, + "endLine": 44, + "sourceId": "", + "startColumn": 39, + "startLine": 44 + }, + "table": "locationTable" + }, + "tableAlias": "locationTable" + }, + "sourceInformation": { + "endColumn": 58, + "endLine": 44, + "sourceId": "", + "startColumn": 14, + "startLine": 44 + } + }, + { + "_type": "relationalPropertyMapping", + "property": { + "class": "meta::dataquality::Location", + "property": "locality", + "sourceInformation": { + "endColumn": 14, + "endLine": 45, + "sourceId": "", + "startColumn": 7, + "startLine": 45 + } + }, + "relationalOperation": { + "_type": "column", + "column": "LOCALITY", + "sourceInformation": { + "endColumn": 62, + "endLine": 45, + "sourceId": "", + "startColumn": 18, + "startLine": 45 + }, + "table": { + "_type": "Table", + "database": "meta::dataquality::db", + "mainTableDb": "meta::dataquality::db", + "schema": "default", + "sourceInformation": { + "endColumn": 53, + "endLine": 45, + "sourceId": "", + "startColumn": 41, + "startLine": 45 + }, + "table": "locationTable" + }, + "tableAlias": "locationTable" + }, + "sourceInformation": { + "endColumn": 62, + "endLine": 45, + "sourceId": "", + "startColumn": 16, + "startLine": 45 + } + } + ], + "root": false, + "sourceInformation": { + "endColumn": 4, + "endLine": 46, + "sourceId": "", + "startColumn": 4, + "startLine": 42 + } + } + ], + "enumerationMappings": [], + "includedMappings": [], + "name": "dataqualitymappings", + "package": "meta::dataquality", + "sourceInformation": { + "endColumn": 1, + "endLine": 47, + "sourceId": "", + "startColumn": 1, + "startLine": 26 + }, + "tests": [] + }, + { + "_type": "runtime", + "name": "DataQualityRuntime", + "package": "meta::dataquality", + "runtimeValue": { + "_type": "engineRuntime", + "connectionStores": [], + "connections": [ + { + "sourceInformation": { + "endColumn": 5, + "endLine": 61, + "sourceId": "", + "startColumn": 5, + "startLine": 58 + }, + "store": { + "path": "meta::dataquality::db", + "sourceInformation": { + "endColumn": 25, + "endLine": 58, + "sourceId": "", + "startColumn": 5, + "startLine": 58 + }, + "type": "STORE" + }, + "storeConnections": [ + { + "connection": { + "_type": "connectionPointer", + "connection": "meta::dataquality::H2", + "sourceInformation": { + "endColumn": 41, + "endLine": 60, + "sourceId": "", + "startColumn": 21, + "startLine": 60 + } + }, + "id": "connection_1", + "sourceInformation": { + "endColumn": 41, + "endLine": 60, + "sourceId": "", + "startColumn": 7, + "startLine": 60 + } + } + ] + } + ], + "mappings": [ + { + "path": "meta::dataquality::dataqualitymappings", + "sourceInformation": { + "endColumn": 42, + "endLine": 54, + "sourceId": "", + "startColumn": 5, + "startLine": 54 + }, + "type": "MAPPING" + } + ], + "sourceInformation": { + "endColumn": 1, + "endLine": 63, + "sourceId": "", + "startColumn": 1, + "startLine": 50 + } + }, + "sourceInformation": { + "endColumn": 1, + "endLine": 63, + "sourceId": "", + "startColumn": 1, + "startLine": 50 + } + }, + { + "_type": "class", + "constraints": [ + { + "functionDefinition": { + "_type": "lambda", + "body": [ + { + "_type": "func", + "function": "greaterThanEqual", + "parameters": [ + { + "_type": "property", + "parameters": [ + { + "_type": "var", + "name": "this", + "sourceInformation": { + "endColumn": 25, + "endLine": 70, + "sourceId": "", + "startColumn": 21, + "startLine": 70 + } + } + ], + "property": "age", + "sourceInformation": { + "endColumn": 29, + "endLine": 70, + "sourceId": "", + "startColumn": 27, + "startLine": 70 + } + }, + { + "_type": "integer", + "sourceInformation": { + "endColumn": 35, + "endLine": 70, + "sourceId": "", + "startColumn": 34, + "startLine": 70 + }, + "value": 18 + } + ], + "sourceInformation": { + "endColumn": 35, + "endLine": 70, + "sourceId": "", + "startColumn": 31, + "startLine": 70 + } + } + ], + "parameters": [] + }, + "name": "mustBeOfLegalAge", + "sourceInformation": { + "endColumn": 35, + "endLine": 70, + "sourceId": "", + "startColumn": 3, + "startLine": 70 + } + } + ], + "name": "Person", + "originalMilestonedProperties": [], + "package": "meta::dataquality", + "properties": [ + { + "multiplicity": { + "lowerBound": 1, + "upperBound": 1 + }, + "name": "name", + "propertyTypeSourceInformation": { + "endColumn": 16, + "endLine": 73, + "sourceId": "", + "startColumn": 11, + "startLine": 73 + }, + "sourceInformation": { + "endColumn": 20, + "endLine": 73, + "sourceId": "", + "startColumn": 4, + "startLine": 73 + }, + "stereotypes": [], + "taggedValues": [], + "type": "String" + }, + { + "multiplicity": { + "lowerBound": 1, + "upperBound": 1 + }, + "name": "age", + "propertyTypeSourceInformation": { + "endColumn": 16, + "endLine": 74, + "sourceId": "", + "startColumn": 10, + "startLine": 74 + }, + "sourceInformation": { + "endColumn": 20, + "endLine": 74, + "sourceId": "", + "startColumn": 4, + "startLine": 74 + }, + "stereotypes": [], + "taggedValues": [], + "type": "Integer" + }, + { + "multiplicity": { + "lowerBound": 0 + }, + "name": "addresses", + "propertyTypeSourceInformation": { + "endColumn": 41, + "endLine": 75, + "sourceId": "", + "startColumn": 16, + "startLine": 75 + }, + "sourceInformation": { + "endColumn": 45, + "endLine": 75, + "sourceId": "", + "startColumn": 4, + "startLine": 75 + }, + "stereotypes": [], + "taggedValues": [], + "type": "meta::dataquality::Address" + } + ], + "qualifiedProperties": [], + "sourceInformation": { + "endColumn": 1, + "endLine": 76, + "sourceId": "", + "startColumn": 1, + "startLine": 68 + }, + "stereotypes": [], + "superTypes": [], + "taggedValues": [] + }, + { + "_type": "class", + "constraints": [], + "name": "Address", + "originalMilestonedProperties": [], + "package": "meta::dataquality", + "properties": [ + { + "multiplicity": { + "lowerBound": 1, + "upperBound": 1 + }, + "name": "location", + "propertyTypeSourceInformation": { + "endColumn": 40, + "endLine": 80, + "sourceId": "", + "startColumn": 14, + "startLine": 80 + }, + "sourceInformation": { + "endColumn": 44, + "endLine": 80, + "sourceId": "", + "startColumn": 4, + "startLine": 80 + }, + "stereotypes": [], + "taggedValues": [], + "type": "meta::dataquality::Location" + }, + { + "multiplicity": { + "lowerBound": 1, + "upperBound": 1 + }, + "name": "locationStreet", + "propertyTypeSourceInformation": { + "endColumn": 25, + "endLine": 81, + "sourceId": "", + "startColumn": 20, + "startLine": 81 + }, + "sourceInformation": { + "endColumn": 29, + "endLine": 81, + "sourceId": "", + "startColumn": 4, + "startLine": 81 + }, + "stereotypes": [], + "taggedValues": [], + "type": "String" + }, + { + "multiplicity": { + "lowerBound": 1, + "upperBound": 1 + }, + "name": "addressId", + "propertyTypeSourceInformation": { + "endColumn": 20, + "endLine": 82, + "sourceId": "", + "startColumn": 15, + "startLine": 82 + }, + "sourceInformation": { + "endColumn": 24, + "endLine": 82, + "sourceId": "", + "startColumn": 4, + "startLine": 82 + }, + "stereotypes": [], + "taggedValues": [], + "type": "String" + } + ], + "qualifiedProperties": [], + "sourceInformation": { + "endColumn": 1, + "endLine": 83, + "sourceId": "", + "startColumn": 1, + "startLine": 78 + }, + "stereotypes": [], + "superTypes": [], + "taggedValues": [] + }, + { + "_type": "class", + "constraints": [], + "name": "Location", + "originalMilestonedProperties": [], + "package": "meta::dataquality", + "properties": [ + { + "multiplicity": { + "lowerBound": 1, + "upperBound": 1 + }, + "name": "street", + "propertyTypeSourceInformation": { + "endColumn": 17, + "endLine": 87, + "sourceId": "", + "startColumn": 12, + "startLine": 87 + }, + "sourceInformation": { + "endColumn": 21, + "endLine": 87, + "sourceId": "", + "startColumn": 4, + "startLine": 87 + }, + "stereotypes": [], + "taggedValues": [], + "type": "String" + }, + { + "multiplicity": { + "lowerBound": 1, + "upperBound": 1 + }, + "name": "locality", + "propertyTypeSourceInformation": { + "endColumn": 19, + "endLine": 88, + "sourceId": "", + "startColumn": 14, + "startLine": 88 + }, + "sourceInformation": { + "endColumn": 23, + "endLine": 88, + "sourceId": "", + "startColumn": 4, + "startLine": 88 + }, + "stereotypes": [], + "taggedValues": [], + "type": "String" + } + ], + "qualifiedProperties": [], + "sourceInformation": { + "endColumn": 1, + "endLine": 89, + "sourceId": "", + "startColumn": 1, + "startLine": 85 + }, + "stereotypes": [], + "superTypes": [], + "taggedValues": [] + }, + { + "_type": "dataQualityValidation", + "context": { + "_type": "mappingAndRuntimeDataQualityExecutionContext", + "_type": "mappingAndRuntimeDataQualityExecutionContext", + "mapping": { + "path": "meta::dataquality::dataqualitymappings", + "sourceInformation": { + "endColumn": 73, + "endLine": 94, + "sourceId": "", + "startColumn": 36, + "startLine": 94 + }, + "type": "MAPPING" + }, + "runtime": { + "path": "meta::dataquality::DataQualityRuntime", + "sourceInformation": { + "endColumn": 112, + "endLine": 94, + "sourceId": "", + "startColumn": 76, + "startLine": 94 + }, + "type": "RUNTIME" + } + }, + "dataQualityRootGraphFetchTree": { + "_type": "dataQualityRootGraphFetchTree", + "_type": "dataQualityRootGraphFetchTree", + "class": "meta::dataquality::Person", + "constraints": [ + "mustBeOfLegalAge" + ], + "sourceInformation": { + "endColumn": 31, + "endLine": 97, + "sourceId": "", + "startColumn": 7, + "startLine": 97 + }, + "subTrees": [ + { + "_type": "dataQualityPropertyGraphFetchTree", + "_type": "dataQualityPropertyGraphFetchTree", + "constraints": [], + "parameters": [], + "property": "name", + "sourceInformation": { + "endColumn": 12, + "endLine": 98, + "sourceId": "", + "startColumn": 9, + "startLine": 98 + }, + "subTrees": [], + "subTypeTrees": [] + } + ], + "subTypeTrees": [] + }, + "filter": { + "_type": "lambda", + "body": [ + { + "_type": "func", + "function": "equal", + "parameters": [ + { + "_type": "property", + "parameters": [ + { + "_type": "var", + "name": "p", + "sourceInformation": { + "endColumn": 47, + "endLine": 95, + "sourceId": "", + "startColumn": 46, + "startLine": 95 + } + } + ], + "property": "name", + "sourceInformation": { + "endColumn": 52, + "endLine": 95, + "sourceId": "", + "startColumn": 49, + "startLine": 95 + } + }, + { + "_type": "string", + "sourceInformation": { + "endColumn": 60, + "endLine": 95, + "sourceId": "", + "startColumn": 55, + "startLine": 95 + }, + "value": "John" + } + ], + "sourceInformation": { + "endColumn": 54, + "endLine": 95, + "sourceId": "", + "startColumn": 53, + "startLine": 95 + } + } + ], + "parameters": [ + { + "_type": "var", + "class": "meta::dataquality::Person", + "multiplicity": { + "lowerBound": 1, + "upperBound": 1 + }, + "name": "p", + "sourceInformation": { + "endColumn": 39, + "endLine": 95, + "sourceId": "", + "startColumn": 15, + "startLine": 95 + } + } + ], + "sourceInformation": { + "endColumn": 60, + "endLine": 95, + "sourceId": "", + "startColumn": 44, + "startLine": 95 + } + }, + "name": "PersonDataQualityValidation", + "package": "meta::dataquality", + "sourceInformation": { + "endColumn": 1, + "endLine": 101, + "sourceId": "", + "startColumn": 1, + "startLine": 92 + }, + "stereotypes": [], + "taggedValues": [] + }, + { + "_type": "sectionIndex", + "name": "SectionIndex", + "package": "__internal__", + "sections": [ + { + "_type": "importAware", + "elements": [], + "imports": [], + "parserName": "Pure", + "sourceInformation": { + "endColumn": 8, + "endLine": 1, + "sourceId": "", + "startColumn": 1, + "startLine": 1 + } + }, + { + "_type": "importAware", + "elements": [ + "meta::dataquality::H2" + ], + "imports": [], + "parserName": "Connection", + "sourceInformation": { + "endColumn": 2, + "endLine": 13, + "sourceId": "", + "startColumn": 8, + "startLine": 2 + } + }, + { + "_type": "default", + "elements": [ + "meta::dataquality::db" + ], + "parserName": "Relational", + "sourceInformation": { + "endColumn": 1, + "endLine": 25, + "sourceId": "", + "startColumn": 1, + "startLine": 14 + } + }, + { + "_type": "importAware", + "elements": [ + "meta::dataquality::dataqualitymappings" + ], + "imports": [], + "parserName": "Mapping", + "sourceInformation": { + "endColumn": 2, + "endLine": 49, + "sourceId": "", + "startColumn": 1, + "startLine": 26 + } + }, + { + "_type": "importAware", + "elements": [ + "meta::dataquality::DataQualityRuntime" + ], + "imports": [], + "parserName": "Runtime", + "sourceInformation": { + "endColumn": 1, + "endLine": 67, + "sourceId": "", + "startColumn": 1, + "startLine": 50 + } + }, + { + "_type": "importAware", + "elements": [ + "meta::dataquality::Person", + "meta::dataquality::Address", + "meta::dataquality::Location" + ], + "imports": [], + "parserName": "Pure", + "sourceInformation": { + "endColumn": 2, + "endLine": 91, + "sourceId": "", + "startColumn": 1, + "startLine": 68 + } + }, + { + "_type": "default", + "elements": [ + "meta::dataquality::PersonDataQualityValidation" + ], + "parserName": "DataQualityValidation", + "sourceInformation": { + "endColumn": 1, + "endLine": 103, + "sourceId": "", + "startColumn": 1, + "startLine": 92 + } + } + ] + } + ] +} \ No newline at end of file diff --git a/legend-engine-xts-dataquality/pom.xml b/legend-engine-xts-dataquality/pom.xml index b6819401180..d6ea8da1bd1 100644 --- a/legend-engine-xts-dataquality/pom.xml +++ b/legend-engine-xts-dataquality/pom.xml @@ -17,6 +17,7 @@ legend-engine-xt-dataquality-protocol legend-engine-xt-dataquality-api legend-engine-xt-dataquality-compiler + legend-engine-xt-dataquality-generation