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

What makes the E2E tests use too much memory? #89

Open
Brandhoej opened this issue Nov 15, 2022 · 0 comments
Open

What makes the E2E tests use too much memory? #89

Brandhoej opened this issue Nov 15, 2022 · 0 comments
Labels
enhancement New feature or request

Comments

@Brandhoej
Copy link
Contributor

In #74 it was noted that e2e tests are ignored as they are using too much memory. We need to figure out what causes them to use as much memory as they do. It would be preferable to do so Personally my top three lists of high memory usage is:

  1. Refinement as a precondition checks for consistency of both the lhs and rhs before doing the refinement check. Consistency checks calls getNextTransitions on mostly the same states as refinement does. If possible consistency should be checked as the systems are being traversed when checking for refinement.
  2. Long lived objects. When doing refinement we keep track of all the visited locations. This reference might be the only one to the object and for this reason we are keeping it alive. I think passed lists of locations and such should be of the identifiers of the objects we passed instead of a reference to it. If this is done then we might experience a decrease in memory and CPU usage. Memory will decrease because the GC can collect them. CPU will be used because the ID will most likely be a type which is quicker to check equality for.
  3. Garbage collection. I think both the state and location class have many different places with short lived objects (Where they are only alive in a small span of the time). Object pooling will be beneficial in this case, and for "bulk" instantiation (Many instantiations instead of a single constructor call).
    This issue is resolved when issues have been open for the most obvious for memory usage.
@Brandhoej Brandhoej added the enhancement New feature or request label Nov 15, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

1 participant