erp5: new 'id-store-interval' instance parameter
See erp5@5169f193
-
Owner
This change breaks initialisation of SlapOS Master (and tests fail the whole weekend) as we have custom some instance-*.cfg because of few certificate authority entries which we cannot avoid for now.
As this is the third time at least that it happens, and I don't expect anyone to learn slapos master itself... Could we all in @nexedi use MR and ask review once change API on slapos instantiation of ERP5? and if possible "/cc @rafael" , in this way I can check and apply the changes for SlapOS master on the same MR, preventing tests to get broken.
Thanks in advance (Fix was applied for slapos master already)
-
Owner
Sorry for having missed but the problem is elsewhere: code duplication. It is a recurring problem that people copies things instead of doing a minimum of refactoring. Copying instance-erp5.cfg.in is not maintainable and slows down everyone. We can't all review everything.
(this is also one of the reasons for which I regret the move to jinja2 templating)
-
Owner
the problem is elsewhere: code duplication
I fully agree.
Work to find sustainable ways to extend without duplication is long overdue, and will have to answer questions of internal API between instanciation buildout files - a topic which I see as very hard. So hard that I do not see how it could be done without concrete example. So such work must happen when one considers copying buildout files around, in order to avoid that.
Here, it was not done, so to me the burden of checking and adapting to upstream changes belongs to maintainers of the duplicated code, not the other way around.
(this is also one of the reasons for which I regret the move to jinja2 templating)
It is probably just a poor word choice, but I do not think you have anything to regret, as you were not active on slapos development by the time it was introduced. You probably intended to say you are disappointed by some jinja limitations. Limitations which I fail to see: if anything, jinja allows more ways of including "stuff" (code or buildout config, hence reuse) than anything else we have (like old-style buildout templating: no inclusion, only variable expansion, or just buildout itself which is orthogonal to jinja). Could you explain more ?
-
Owner
Copying instance-erp5.cfg.in is not maintainable and slows down everyone.
Sure, Can you propose a better approach so (you can check the small diff comparing the 2 times.)? I think you can propose something as, those changes are also required for setup shacache.org without hardcoded ad-hoc apache setup like we have today.
-
Owner
Unfortunately, I don't have a nice approach to propose, hence my parenthesis about the move to jinja2 (I already wrote about this at !196 (merged)). Several ways have been tried so far:
- e.g. ERP5 extending NEO: macros are used a lot and the resulting code is complicated
- for wendelin-scalability scenarios, I do on-the-fly patching, plus some obscure dance with template-foo/template-foo-base/template-foo-patched, and all this is not great
I wish I had more time to improve slapos framework so that SR are easier to write and extend. And like always when it's not the time to do beautiful things, it can be acceptable to do dirty things but then one assumes.
Noone to blame here.