Homepage: http://rdfunit.aksw.org
Documentation: https://github.com/AKSW/RDFUnit/wiki
Mailing list: https://groups.google.com/d/forum/rdfunit (rdfunit [at] googlegroups.com)
Presentations: http://www.slideshare.net/jimkont
Brief Overview: https://github.com/AKSW/RDFUnit/wiki/Overview
RDFUnit is implemented on top of the Test-Driven Data Validation Ontology and designed to read and produce RDF that complies to that ontology only. The main components that RDFUnit reads are TestCases (manual & automatic), TestSuites, Patterns & TestAutoGenerators. RDFUnit also strictly defines the results of a TestSuite execution along with different levels of result granularity.
See RDFUnit from Command Line for (a lot) more options but the simplest setting is as follows:
$ bin/rdfunit -d <local-or-remote-location-URI>
What RDFUnit will do is:
- Get statistics about all properties & classes in the dataset
- Get the namespaces out of them and try to dereference all that exist in LOV
- Run our Test Generators on the schemas and generate RDFUnit Test cases
- Run the RDFUnit test cases on the dataset
- You get a results report in html (by default) but you can request it in RDF or even multiple serializations with e.g.
-o html,turtle,jsonld
- The results are by default aggregated with counts, you can request different levels of result details using
-r {status|aggregated|shacl|shacllite|rlog|extended}
. See here for more details.
You can also run:
$ bin/rdfunit -d <dataset-uri> -s <schema1,schema2,schema3,...>
Where you define your own schemas and we pick up from step 3. You can also use prefixes directly (e.g. -s foaf,skos
) we can get everything that is defined in LOV.
RDFUnit supports the following types of schemas
- OWL (using CWA): We pick the most commons OWL axioms as well as schema.org. (see [1],[2] for details
- SHACL: SHACL is still in progress but we support the most stable parts of the language. Whatever constructs we support can also run on SPARQL Endpoints (SHACL does not support SPARQL endpoints by design)
- IBM Resource Shapes: The progress is tracked here bus as soon as SHACL becomes stable we will drop support for RS
- DSP (Dublin Core Set Profiles): The progress is tracked here bus as soon as SHACL becomes stable we will drop support for RS
Note that you can mix all of these constraints together and RDFUnit will validate the dataset against all of them.