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

reduce public footprint of ev contrib #2888

Merged
merged 7 commits into from
Oct 23, 2023
Merged

reduce public footprint of ev contrib #2888

merged 7 commits into from
Oct 23, 2023

Conversation

kainagel
Copy link
Member

@kainagel kainagel commented Oct 20, 2023

bringing this closer to matsim standards (e.g. all static methods combined into one *Utils class; replace constructors by static factory methods in that *Utils class; then make implementing classes package-protected; make injected constructors non-public so that classes can only be instantiated through injection; ...).

can we still do this or is it too late (i.e. too many users)?

(If you prefer having the factory in the implementing class rather than in the *Utils class, that would be fine with me, and maybe even a bit more logical in the long run. Everywhere where it was like that I have left it like that, and we could also do it for the other implementing classes. It is just a little harder to audit, since one has to look into the class to make sure that it does not have a public constructor.)

@kainagel kainagel changed the title reduce public footprint reduce public footprint of ev contrib Oct 20, 2023
Copy link
Member

@michalmac michalmac left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks! It looks good to me.

Some thoughts:

  1. I think making things package-protected and final is good in general. From time to time though, we are asked to remove some of these restrictions from some classes, because there is no better alternative. So I hope/assume we will get a feedback if we break someone else's code without leaving a reasonable workaround.

  2. I often use factory methods inside a specific class/interface or interface-specific util (e.g. ElectricFleets), so things are more local and we avoid having big util classes (but maybe sometimes it leads to too many small utils here and there).

    I also think there is this naming policy for util classes to suffix them with s (e.g. Collectors, Arrays, Collections, Executors, Files or Objects).

    However, I do not have strong opinions on these (Utils as a suffix is fine, having factory methods in utils is fine).

@michalmac
Copy link
Member

Regarding .asEagerSingleton() vs .in(Scopes.SINGLETON):

I mostly use the former, and I do not remember I've ever run into any issues with that. This is maybe related to the fact how I write tests:

  • simple unit tests, where there is no DI (guice), because I try to keep such tests as simple as possible
  • more complex tests (often suffixed with IT), where a proper matsim scenario is set up and then DI (guice) is used

I guess eager singletons may cause problems in "half-setup" scenarios ("medium complexity unit tests"). Or maybe there are some other cases where it also causes problems? Out of curiosity, do we have such issues mentioned/reported somewhere?

Anyway, I do not see any reason against switching to latter type. I can do it also in the dvrp-related contribs.

@kainagel
Copy link
Member Author

kainagel commented Oct 23, 2023 via email

@kainagel
Copy link
Member Author

kainagel commented Oct 23, 2023 via email

@kainagel kainagel enabled auto-merge October 23, 2023 06:10
@kainagel kainagel merged commit 5695f63 into master Oct 23, 2023
@kainagel kainagel deleted the evMaintenance branch October 23, 2023 06:25
@nkuehnel
Copy link
Member

nkuehnel commented Dec 1, 2023

@kainagel @michalmac
We do have some troubles now with some classes, especially the default implementation of ChargingInfrastructureSpecification which has no public access anymore. This makes using the ChargerReader and manipulating chargers by code a bit cumbersome. At the moment we actually just duplicate the default implementation to our own repos which is not the desired outcome of this change, I guess. Couldn't we offer a public factory method in the Utils class as well? This should probably go to the existing ChargingInfrastructureUtils class

I can prepare a PR for that

@michalmac
Copy link
Member

Couldn't we offer a public factory method in the Utils class as well? This should probably go to the existing ChargingInfrastructureUtils class

Sounds good.

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

Successfully merging this pull request may close these issues.

3 participants