Skip to content

Check whether some Java code is transitively dependent on some other packages.

License

Notifications You must be signed in to change notification settings

Sounie/dependency-check

Repository files navigation

Dependency Checker

Example of checking whether an application includes a dependency on particular packages.

Dependencies of this project

  • Java 11
  • Junit for unit tests.
  • ClassGraph for scanning the code to build up relations.
  • Gradlew for building (the pom.xml file is generated to allow Github to detect dependencies - don't expect to be able to build with maven).

Motivation

Some Java libraries and frameworks specify a broad range of dependencies. Sometimes those dependencies are only required for a subset of the uses of the library. Sometimes the dependencies clash with a version of the same library that an application already includes.

Maven, Gradle etc. allow us to specify some exclusions when bringing in a dependency.

Wouldn't it be nice if we could have confidence that our application will not break at runtime when some untested path through a library is reached?

Version history

Current implementation

  • Recursively checks from initial package, checking whether any dependency exists that would introduce a class from one of the unwanted packages, or any sub-package.
  • Unit tests attempt to check whether code that references apache hadoop mapreduce functionality would lead to the Jersey server or Jersey packages that are included as dependencies of that hadoop client artifact.

First attempt

  • Just starts from a specified package, then recursively steps through the detected dependencies and accumulates the class names and checks whether a class is in one of the specified unwanted packages. A single object with 2 unit tests. Not set up as a distributable artifact.

Known limitations

  • The recursive approach to accumulating dependency class information could potentially run out of stack.
  • Won't pick up on dependencies that are brought in by reflection, including dependency injection frameworks driven by classpath scanning or XML files. e.g. if your code specifies an interface, then the framework detects an implementation in your classpath and wires it in at runtime, the compile time checking applied in this system wouldn't pick that up.
  • If a dependency brings in is dependencies as "shaded" classes, then those will not match against our specified exclusions. This occurred as a potential gotcha when I read the documentation for hadoop 3.2.0.

About

Check whether some Java code is transitively dependent on some other packages.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published