This test suite verifies that a WFS implementation conforms to the NSG Web Feature Service 2.0 Implementation Profile, v1.0.0 (NGA.STND.0062_2.0_WFS, 2017-01-11). The aim is to cover the MANDATORY and RECOMMENDED capabilities stipulated in all relevant specifications.
Note that this profile extends and restricts the specifications upon which it is based. The main dependencies are:
- DGIWG Web Feature Service 2.0 Profile (DGIWG-122)
- OGC Web Feature Service standard, Version 2.0.2 [OGC 09-025r2]
- OGC Filter Encoding standard, Version 2.0.2 [OGC 09-026r2].
Visit the project documentation website for more information, including the API documentation.
The test suite is built using Apache Maven v3. The options for running the suite are summarized below.
Use a Java IDE such as Eclipse, NetBeans, or IntelliJ. Clone the repository and build the project.
Set the main class to run: org.opengis.cite.wfs20-nsg.TestNGController
Arguments: The first argument must refer to an XML properties file containing the
required test run arguments. If not specified, the default location at $ {user.home}/test-run-props.xml
will be used.
You can modify the sample file in src/main/config/test-run-props.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd">
<properties version="1.0">
<comment>Test run arguments</comment>
<entry key="iut">http://schemas.opengis.net/gml/3.2.1/gml.xsd</entry>
</properties>
The TestNG results file (testng-results.xml
) will be written to a subdirectory
in ${user.home}/testng/
having a UUID value as its name.
One of the build artifacts is an "all-in-one" JAR file that includes the test suite and all of its dependencies; this makes it very easy to execute the test suite in a command shell:
java -jar ets-wfs20-nsg-0.1-SNAPSHOT-aio.jar [-o|--outputDir $TMPDIR] [test-run-props.xml]
Use TEAM Engine, the official OGC test harness. The latest test suite release are usually available at the beta testing facility. You can also build and deploy the test harness yourself and use a local installation.
If you would like to get involved, you can:
- Report an issue such as a defect or an enhancement request
- Help to resolve an open issue
- Fix a bug: Fork the repository, apply the fix, and create a pull request
- Add new tests: Fork the repository, implement and verify the tests on a new topic branch, and create a pull request (don't forget to periodically rebase long-lived branches so there are no extraneous conflicts)