These validation value objects and entities should be useful classes.
Because this library is only useful for developers the installation depends on your build environment.
For example when using Apache Maven you could add the following dependency to your project:
<dependency>
<groupId>de.powerstat</groupId>
<artifactId>validation</artifactId>
<version>3.1.0</version>
</dependency>
Also please copy the checkstyle-config.xml
and PMD.xml
into your project.
Please add the following entry to your maven settings.xml
:
<server>
<id>nvd</id>
<password>nvd api-key</password>
</server>
The API-Key could be requested here: National Vulnerability Database
Other build tools like gradle will work analogous.
Java platform module system:
module com.example.java.app
{
requires de.powerstat.validation;
requires de.powerstat.validation.comparators;
requires de.powerstat.validation.containers;
requires de.powerstat.validation.entities;
requires de.powerstat.validation.interfaces;
requires de.powerstat.validation.values;
requires de.powerstat.validation.values.strategies;
}
To compile this project yourself you could use:
mvn clean install org.pitest:pitest-maven:mutationCoverage site
or simply:
mvn clean install
or for native image creation:
On windows Visual Studio 2022 is required and you have to call:
"C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvars64.bat" > nul
Compile and build image:
mvn clean -Pnative package
Run the image:
./target/[imagename]
To find newer dependencies:
mvn versions:display-dependency-updates
To find newer plugins:
mvn versions:display-plugin-updates
To make a new release:
set MAVEN_GPG_PASSPHRASE=TopSecret
mvn --batch-mode release:clean release:prepare release:perform
git push -–tags
git push origin master
To run checkstyle:
mvn checkstyle:check
To run pmd:
mvn pmd:check
To run spotbugs:
mvn spotbugs:check
To run arch-unit:
mvn arch-unit:arch-test
To run JDeprScan:
mvn jdeprscan:jdeprscan jdeprscan:test-jdeprscan
To run toolchain:
mvn toolchains:toolchain
If you use a sonar server:
mvn sonar:sonar -Dsonar.token=<token>
If you use [infer][https://fbinfer.com/]:
infer run -- mvn clean compile
To create a spdx:
mvn spdx:createSPDX
To create a cycloneDX:
mvn cyclonedx:makeBom
To upload bom to dependency-track:
mvn dependency-track:upload-bom
To look for dependency-track findings:
mvn dependency-track:findings
For usage in your own projects please read the Javadoc's and follow the examples in the unittests.
If you would like to contribute to this project please read How to contribute.
This code is licensed under the Apache License Version 2.0.