This example shows how to use the Data Processing Library's validation module to build an
incremental processing pipeline that validates the content of HERE Map Content's topology-geometry
layer against a set of acceptance criteria. In particular, we validate the following invariants:
- A Node's geometry must be contained in its host tile's boundaries.
- A Node must be attached to at least one Segment.
- A Node must not have dangling references to non-existent Segments.
- A Segment must not have dangling references to non-existent Nodes.
- A Segment's start Node must be in its host tile.
- A Segment's Shape Points should go from the start Node to the end Node.
Finally, we check that the partitionName
field of a topology-geometry
partition equals the
actual HERE Tile ID of the partition.
As these checks are carried out, we keep track of the following metric values, which are automatically aggregated together with the test results:
- Number of Nodes per tile.
- Number of Segments per tile.
- Number of Segments attached to each Node.
To implement these tests we use a scalatest suite, parametrized on the content of one
topology-geometry
partition and of all the referenced neighbour partitions, using the Data
Processing Library's batch-validation-scalatest
module.
The validation module automatically encodes the test results and publishes them in a validation report catalog, which consists of the following layers:
report
contains the report of the failed tests (succeeded tests are by default filtered out to simplify debugging and identification of data issues, and to reduce the amount of published data). This layer will be empty if there are no failed tests.metrics
contains statistics about all test cases run in the suite, and the accumulated values of the custom accumulators specified in the suite. Partitions are first published at the input zoom level (12) and then incrementally and recursively aggregated at higher zoom levels - by default using all the zoom levels configured in the layer up to level 0 (the root partition). In this example we use levels 12, 10, 8, 6, 4, 2 and 0.assessment
contains the final assessment partition. This layer will contain one single partition, encoding our custom assessment class. In this example we simply assess that no test cases have failed.
To run this example, you need two sets of credentials:
- Platform credentials: To get access to the platform data and resources, including HERE Map Content data for your pipeline input.
- Repository credentials: To download HERE Data SDK for Java & Scala libraries and Maven archetypes to your environment.
For more details on how to set up your credentials, see the Identity & Access Management Developer Guide.
For more details on how to verify that your platform credentials are configured correctly, see the Verify Your Credentials tutorial.
In the commands that follow, replace the variable placeholders with the following values:
$CATALOG_ID
is your output catalog's ID.$CATALOG_HRN
is your output catalog'sHRN
(returned byolp catalog create
).$HRN_PARTITION
is the platform environment you are in. The value should behere
.$PROJECT_HRN
is your project'sHRN
(returned byolp project create
command).$REALM
The ID of your organization, also called a realm. Consult your platform invitation letter to learn your organization ID.$CATALOG_RIB
is the HRN of the public HERE Map Content catalog in your pipeline configuration (HERE environment.
Note: We recommend you to set values to variables so that you can easily copy and execute the following commands.
As mentioned above, we will use the public HERE Map Content input catalog, however, we need to create our own output catalog to store the validation reports and metrics generated by the compiler.
To run this compiler locally, use a local output catalog as described below. For more information about local catalogs, see the SDK tutorial about local development and testing and the OLP CLI documentation.
- Use the
olp local catalog create
command to create the local catalog.
olp local catalog create heremapcontent-validation "HERE Map Content - Topology and Geometry Validation" \
--summary "Validation of HERE Map Content Topology and Geometry layer" \
--description "Validation of HERE Map Content Topology and Geometry layer"
The local catalog will have the HRN hrn:local:data:::heremapcontent-validation
.
- Use the
olp local catalog layer add
command to add fourversioned
layers to your catalog:
olp local catalog layer add hrn:local:data:::heremapcontent-validation report report --versioned \
--summary "Test report" \
--description "Test report" --partitioning heretile:12 \
--schema hrn:$HRN_PARTITION:schema:::com.here.platform.data.processing.validation.schema:report_v2:1.0.0 \
--content-type application/json
olp local catalog layer add hrn:local:data:::heremapcontent-validation metrics metrics --versioned \
--summary "Test metrics" \
--description "Test metrics" --partitioning heretile:12,10,8,6,4,2,0 \
--schema hrn:$HRN_PARTITION:schema:::com.here.platform.data.processing.validation.schema:metrics_v2:1.0.0 \
--content-type application/json
olp local catalog layer add hrn:local:data:::heremapcontent-validation assessment assessment --versioned \
--summary "Test assessment" \
--description "Test assessment" --partitioning generic \
--content-type application/json
olp local catalog layer add hrn:local:data:::heremapcontent-validation state state --versioned \
--summary "state" \
--description "state" --partitioning generic \
--content-type application/octet-stream
If a billing tag is required in your realm, use the
--billing-tags: "YOUR_BILLING_TAG"
parameter.
To run the compiler locally, you will need to run the entry point to the compiler:
com.here.platform.data.processing.example.scala.validation.Main
As arguments, you must provide the -Dspark.master=local[*]
parameter with the address of the Spark server
master to connect to, and any configuration parameters you want to override. Alternatively, you can
add those parameters to the application.conf
file.
Additionally, you also need to specify the -Dpipeline-config.file
and -Dpipeline-job.file
parameters to specify the location of a configuration file that contains the catalogs as well as
job-specific versions of the catalogs, to read and write to.
For local runs, a bounding box filter is provided in the
config/here/local-application.conf
to
limit the number of partitions to be processed. This speeds up the compilation process. In this
example, we use a bounding box around the cities of Berlin. You can edit the bounding box coordinates to compile a different
partition of HERE Map Content. Make sure you update the layer coverage to reflect the different
geographical region. In order to use this configuration file, you need to use the -Dconfig.file
parameter.
Finally, run the following command line in the heremapcontent-validation
directory to compile and
run the validation pipeline.
For the HERE platform environment:
sbt run \
-Dpipeline-config.file=./config/here/local-pipeline-config.conf \
-Dpipeline-job.file=./config/here/pipeline-job.conf \
-Dconfig.file=./config/here/local-application.conf \
-Dspark.master=local[*]
After one run, in the HERE platform environment you can inspect the local catalog with the OLP CLI:
olp local catalog inspect hrn:local:data:::heremapcontent-validation
You can also download partitions from the local catalog to manually inspect them. The command below, for example, downloads the aggregated metrics containing all statistics about the validation run. Metrics are aggregated at different zoom levels, and the root partition (HERE Tile ID 1) contains the aggregation of all metrics partitions:
olp local catalog layer partition get hrn:local:data:::heremapcontent-validation metrics --partitions 1
The report
layer will be likely empty, because no test cases have failed. To force some failures
and check how the output would change in that case, search for [inject]
in Main.scala
and
uncomment the line that follows:
val (resultsAndMetricsPublishedSet, aggregatedMetrics) = testData
// [inject] Uncomment the following line to inject some "dangling reference" errors
// .mapValues(ErrorInjection.injectError)
.mapValues(suiteCompiler.compile)
.publishAndAggregateByLevel(suiteCompiler.outLayers, suiteCompiler.metricsLayer)
To run the example as a HERE Platform Pipeline, you'll first need a project. A project is a collection of platform resources (catalogs, pipelines, and schemas) with controlled access. You can create a project through the HERE platform portal.
Alternatively, use the OLP CLI
olp project create
command to create the project:
olp project create $PROJECT_ID $PROJECT_NAME
The command returns the HERE Resource Name (HRN) of your new project. Note down this HRN as you'll need it later in this tutorial.
Note: You don't have to provide a
--scope
parameter if your app has a default scope. For details on how to set a default project scope for an app, see the Specify a default Project for Apps chapter of the Identity & Access Management Developer Guide.
For more information on how to work with projects, see the Organize your work in projects tutorial.
Create a catalog to store the validation reports and metrics generated by the compiler. You will use the non-local variants of the same commands you have run before to create a local catalog:
- Use the
olp catalog create
command to create the catalog. Make sure to note down the HRN returned by the following command for later use:
olp catalog create $CATALOG_ID "HERE Map Content - Topology and Geometry Validation" \
--summary "Validation of HERE Map Content Topology and Geometry layer" \
--description "Validation of HERE Map Content Topology and Geometry layer" \
--scope $PROJECT_HRN
- Use the
olp catalog layer add
command to add twoversioned
layers to your catalog:
olp catalog layer add $CATALOG_HRN report report --versioned \
--summary "Test report" \
--description "Test report" --partitioning heretile:12 \
--schema hrn:$HRN_PARTITION:schema::$REALM:com.here.platform.data.processing.validation.schema:report_v2:1.0.0 \
--content-type application/json --scope $PROJECT_HRN
olp catalog layer add $CATALOG_HRN metrics metrics --versioned \
--summary "Test metrics" \
--description "Test metrics" --partitioning heretile:12,10,8,6,4,2,0 \
--schema hrn:$HRN_PARTITION:schema::$REALM:com.here.platform.data.processing.validation.schema:metrics_v2:1.0.0 \
--content-type application/json --scope $PROJECT_HRN
olp catalog layer add $CATALOG_HRN assessment assessment --versioned \
--summary "Test assessment" \
--description "Test assessment" --partitioning generic \
--content-type application/json --scope $PROJECT_HRN
olp catalog layer add $CATALOG_HRN state state --versioned \
--summary "state" \
--description "state" --partitioning generic \
--content-type application/octet-stream --scope $PROJECT_HRN
If a billing tag is required in your realm, use the
--billing-tags: "YOUR_BILLING_TAG"
parameter.
- Use the
olp project resource link
command to link the HERE Map Content catalog to your project:
olp project resource link $PROJECT_HRN $CATALOG_RIB
- For more details on catalog commands, see Catalog Commands.
- For more details on layer commands, see Layer Commands.
- For more details on project commands, see Project Commands.
- For instructions on how to link a resource to a project, see Project Resource Link command.
From the SDK examples directory, open the data-processing/scala/heremapcontent-validation
project
in your Integrated Development Environment (IDE).
The config/here/pipeline-config.conf
(for the HERE platform environment) file contains
the permanent configuration of the data sources for the compiler.
Pick the file that corresponds to your platform environment. For example, the pipeline configuration for the HERE platform environment looks like:
pipeline.config {
output-catalog {hrn = "YOUR_OUTPUT_CATALOG_HRN"}
input-catalogs {
hmc {hrn = "hrn:here:data::olp-here:rib-2"}
}
}
Replace YOUR_OUTPUT_CATALOG_HRN
with the HRN of your validation catalog.
To find the HRN, in the HERE platform portal, navigate to your catalog. The HRN is displayed in the upper
left corner of page.
The remainder of the configuration is specified in the application.conf
file that can be found in the
src/main/resources
directory of the compiler project. However, you do not have to modify it unless
you want to change the behavior of the compiler.
Run the sbt assembly
command in the heremapcontent-validation
directory
to generate a fat JAR file to deploy the compiler to a pipeline.
sbt assembly
Once the previous command is finished, your JAR is then available at the target
directory, and you
can upload it using the HERE pipelines UI
or the OLP CLI.
You can use the OLP CLI to create pipeline components and activate the pipeline version with the following commands:
- Create pipeline components:
For this example, a bounding box filter is provided by --runtime-config
parameter to
limit the number of partitions to be processed. This speeds up the compilation process. In this
example, we use a bounding box around the cities of Berlin. You can edit the bounding box coordinates to compile a different
partition of HERE Map Content. Make sure you update the layer coverage to reflect the different
geographical region.
olp pipeline create $COMPONENT_NAME_Pipeline --scope $PROJECT_HRN
olp pipeline template create $COMPONENT_NAME_Template batch-4.0 $PATH_TO_JAR \
com.here.platform.data.processing.example.scala.validation.Main \
--workers=4 --worker-units=3 --supervisor-units=2 --input-catalog-ids=hmc \
--scope $PROJECT_HRN
olp pipeline version create $COMPONENT_NAME_version $PIPELINE_ID $PIPELINE_TEMPLATE_ID \
"$PATH_TO_CONFIG_FOLDER/pipeline-config.conf" \
--runtime-config here.platform.data-processing.deltasets.partitionKeyFilters.0.className=BoundingBoxFilter \
here.platform.data-processing.deltasets.partitionKeyFilters.0.param.boundingBox.north=52.67551 \
here.platform.data-processing.deltasets.partitionKeyFilters.0.param.boundingBox.south=52.338261 \
here.platform.data-processing.deltasets.partitionKeyFilters.0.param.boundingBox.east=13.76116 \
here.platform.data-processing.deltasets.partitionKeyFilters.0.param.boundingBox.west=13.08835 \
--scope $PROJECT_HRN
- Activate the pipeline version:
olp pipeline version activate $PIPELINE_ID $PIPELINE_VERSION_ID \
--input-catalogs "$PATH_TO_CONFIG_FOLDER/pipeline-job.conf" \
--scope $PROJECT_HRN
You don't have to specify the input catalog's version, unless you want to. The latest version will be automatically used.
In the HERE platform portal navigate to your pipeline to see its status.
In the HERE platform portal select the Data tab and find your catalog.
- Open the
assessment
layer and select the Inspect tab. - Select the
assessment
partition to view the result of the assessment.