Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

JavaPackage.containsCycle reports acyclic packages #12

Open
lukeu opened this issue Jun 12, 2017 · 0 comments
Open

JavaPackage.containsCycle reports acyclic packages #12

lukeu opened this issue Jun 12, 2017 · 0 comments

Comments

@lukeu
Copy link

lukeu commented Jun 12, 2017

The method JavaPackage.containsCycle currently returns true for packages that merely reference cyclic packages, even when they do not form part of a cycle themselves.

As an example, consider these packages with 2 small cycles:

    A  --->  W <=> X  --->  B  --->  Y <=> Z  --->  C

The method would return true for all packages except C.

A more useful method would be one that returns true only for strongly connected packages. i.e. "from a package, is there any path through the graph that leads back to it?" This method would return true for W, X, Y, Z, but false for A, B and C.

Of course it is possible to implement this method externally via getEfferents(), however it would benefit more people if the method were directly available from the natural place in JavaPackage. Perhaps a new method named isWithinCycle?

I can provide a patch or pull-request if there is interest.

Motivation:
Asserting the absence of cycles is useful in unit tests to help lock-down packages once we succeed in making them cycle-free. While there are tangles however, it important to minimise the number of packages listed as being "cyclic"; since these (somewhat simple) unit-tests offer no protection for these packages. Hence it is important to rule out any 'false positives' to minimise the scope for architectural rot.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant