Contributors mailing list archives
contributors@odoo-community.org
Browse archives
Supplier discount on all products supplied
Any module that verify numbers, i.e., employee's citizen ID
requirements.txt: Repository Level vs Module Level
by
        
            dmytro.katyukha
        
        
        
    
        
        Hi all,
As i see, usually in OCA repositories "requirements.txt" file with pip dependencies is located in the root of the repository and contains a list of all python dependencies for all addons in the repository. This way it works fine, when we clone full repository, and install all dependencies for all modules there, thus when user will try to install new module on DB, 99% that all python dependencies will be satisfied.
But, let's take for example repository partner-contact repository for Odoo 12.0 and let's try to add the module 'partner_email_check' to odoo server. For this task, i will use [odoo-helper-scripts](https://github.com/katyukha/odoo-helper-scripts) that can automatically resolve repository dependencies (including those specified by oca_dependencies.txt). So, at first i would try to fetch (clone) repository partner-contact, and in this case system will automatically fetch 42 OCA repositories following 'oca_requirements.txt', and also it will try to install python dependencies mentioned in requirements.txt. It is good for development. But installation this way on prod, may lead to a lot of unneeded modules, that polutes system with strange dependencies that are in some cases may be not installable (for example because of system dependencies).
To solve this reason, we started to use 'assembly' approach, that assumes that we have to create separate git repository with only addons needed on server. But in this case, if assembly repo created automatically, there is no way to get python requirements for module, if it is not specified in module directory. Looking for python dependencies in manifest is also not good, because there are python packages exists, that has different name for package and python module inside package.
So, may be it have sense to place requirements.txt inside module directory? Thus module's requirements will be always delivered with module, that will make easier installation of module. Also, i think this way, it will be much easier to generate setup.py files for modules, that will contain info about module's python dependencies.
Possible drawbacks may be in case, when different versions of python dep will be specified in different modules. But same is applicable for repositories.
What do you think about this?
With regards,
Dmytro Katyukha
Follow-Ups
- 
                Re: requirements.txt: Repository Level vs Module LevelbyTecnativa. S. L., Pedro M. Baeza- 11/02/2021 11:37:53 - 0
- 
                Re: requirements.txt: Repository Level vs Module LevelbyClosingAp Open Source Integrators Europe, LDA., Daniel Reis- 11/02/2021 11:19:03 - 0
- 
                Re: requirements.txt: Repository Level vs Module LevelbyAcsone SA/NV, Stéphane Bidoul- 11/02/2021 11:13:33 - 0
- 
                Re: requirements.txt: Repository Level vs Module LevelbyCamptocamp SA, Simone Orsi- 11/02/2021 11:11:26 - 0