layout | title | nav_order | parent |
---|---|---|---|
page |
Testing |
1 |
Developer Overview |
We have a stand-alone example that you can run in the integration tests.
The example is based off of the mortgage dataset you can download
here
and the code is in the com.nvidia.spark.rapids.tests.mortgage
package.
Unit tests exist in the tests directory. This is unconventional and is done so we can run the tests on the final shaded version of the plugin. It also helps with how we collect code coverage.
Use Maven to run the unit tests via mvn test
.
To run targeted Scala tests append -DwildcardSuites=<comma separated list of wildcard suite names to execute>
to the above command.
For more information about using scalatest with Maven please refer to the scalatest documentation.
You can run the unit tests against different versions of Spark using the different profiles. The default version runs against Spark 3.0.0, to run against other versions use one of the following profiles:
-Pspark301tests
(spark 3.0.1)-Pspark302tests
(spark 3.0.2)-Pspark303tests
(spark 3.0.3)-Pspark311tests
(spark 3.1.1)-Pspark312tests
(spark 3.1.2)
Please refer to the tests project POM to see the list of test profiles supported.
Apache Spark specific configurations can be passed in by setting the SPARK_CONF
environment
variable.
Examples:
- To run tests against Apache Spark 3.1.1,
mvn -P spark311tests test
- To pass Apache Spark configs
--conf spark.dynamicAllocation.enabled=false --conf spark.task.cpus=1
do something like.SPARK_CONF="spark.dynamicAllocation.enabled=false,spark.task.cpus=1" mvn ...
- To run test ParquetWriterSuite in package com.nvidia.spark.rapids, issue
mvn test -DwildcardSuites="com.nvidia.spark.rapids.ParquetWriterSuite"
Please refer to the integration-tests README