Skip to content

meretp/spdx-testbed

 
 

Repository files navigation

SPDX testbed

The SPDX testbed provides tasks that are meant to be solved by external SPDX tools/libraries to prove their capability in handling SPDX documents.

State

This is currently under development and not yet stable.

How to build

You can build the testbed locally using ./gradlew :testbed:shadowJar and then find testbed-*-all.jar in testbed/build/libs/.

How to use

The testbed is a CLI application. After building the executable jar (see above), you can check its usage via

java -jar testbed-*-all.jar -h

The most important parameters are -t and -c for selecting which test cases to run, and -f for specifying the input files provided by the external SPDX tool. For example,

java -jar testbed-*-all.jar -t generationMinimalTest generationDocumentTest -f minimalFile.xml documentFile.xml

will execute generationMinimalTest with minimalFile.xml as input and generationDocumentTest with documentFile.xml as input. The input files are expected to be created using the external SPDX tool.

A list of available test cases can be found here.

Currently, the following categories are available:

How to integrate

In order to submit a tool, a GitHub Actions workflow should be added at .github/workflows/[name of the external SPDX tool].yaml. This workflow should download and use the external SPDX tool in order to generate the desired solution, and then check it via the testbed application.

As an example, have a look at .github/workflows/tools-java.yaml that uses the spdx-tools-java-solver to generate an output file generationMinimalResult.xml that should solve the test generationMinimalTest.

Contributing

Contributions are very welcome! See CONTRIBUTING.md for instructions on how to contribute to the codebase.

License

This project is licensed under Apache-2.0

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 81.8%
  • Python 16.9%
  • Shell 1.3%