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

Revisit composer install triggered by INIT_PLUGINS env var #27

Open
petehalverson opened this issue Nov 20, 2019 · 5 comments
Open

Revisit composer install triggered by INIT_PLUGINS env var #27

petehalverson opened this issue Nov 20, 2019 · 5 comments

Comments

@petehalverson
Copy link
Member

The current method may cause conflicting dependencies.

@petehalverson
Copy link
Member Author

petehalverson commented Nov 20, 2019

I am trying to avoid requiring a persistent /vendor volume for a variety of reasons.

@jimcottrell, @LukeTowers pointed out the OC marketplace plugins add the replace property. I'm assuming that doesn't work unless composer install is run from the project root, correct?

@LukeTowers
Copy link

@petehalverson the point of running composer from the root instead of in each plugin is to make sure that all plugin dependencies are considered in addition to the core dependencies when determining what versions and libraries to pull; as well as preventing any duplicate dependencies (potentially with different versions) from being present in the project.

What the marketplace does is a compromise between a proper full install of dependencies in the project root and having a free for all in plugin vendor folders: it includes all dependencies that are already included in the base october project as values in the replace property that it injects into the composer file for each plugin before running composer install on that plugin directory. This prevents most of the issues relating to having multiple versions / copies of the same dependency loaded at the same time.

However, my vote would still be to run the composer install from the project root, as that's how it should be done when deploying to production and causes the least issues overall. By no means am I an expert with Docker though, so I'd like to hear the arguments against doing so.

@petehalverson
Copy link
Member Author

petehalverson commented Nov 20, 2019

For some context, composer install runs during the image build process and stores dependencies in the /var/www/html/vendor folder of the image.

For local development workflows, I assume volumes are mapped to folders within the project which contain the plugins in use. Most plugins repos ignore the plugin vendor folder, which means those dependencies need to be fetched at runtime (hence the INIT_PLUGINS=true option). Because those plugin folders exist on the host as a part of a project, those dependencies get stored locally and persist outside of the container.

In practice, this means composer install (and the wait that comes with it) is only triggered the first time a project is spun up or a new plugin is introduced.

I think applying a 'replace' fix to the plugin composer.json, similar to what's being done on the marketplace is a good idea to facilitate this assumed project layout.

To be clear, nothing is preventing users from mapping a local volume to /var/www/html/vendor and running composer install at the project root.

Perhaps we could support that workflow better by introducing a different entrypoint env var option e.g. INIT_PLUGINS=root which could automatically copy dependencies to your local filesystem and run composer install from the root.

When I tested a 'composer from root' workflow. I was deterred by:

  • Speed. Starting the container with composer install is slow. Even when testing with a composer cache stored in the image.
  • No easy way to detect if a new plugin is introduced to trigger composer automatically at start up.
  • Disk utilization. Core dependencies exists within the image and are efficiently reused for each project. Storing them locally with each project multiplies disk space / usage.

I recall digging into some other options to improve speed a bit by detecting if the dependencies for plugins already existed, without running composer install. It just felt like a hack...trying to run composer without running composer.

@petehalverson
Copy link
Member Author

petehalverson commented Nov 20, 2019

I should point out by detecting the presence of a composer file and whether or not a vendor folder exists in each plugin folder, we're able to elegantly support plugins introduced via the marketplace.

And by elegantly support, I mean do nothing because nothing needs to be done.

@LukeTowers
Copy link

Those points are fair enough. I agree that replace might be the way to go, my annoyance with the current process is just as a result of having plugins with composer files that aren't really needed (i.e. just pulling in composer/installers or requiring some laravel core dependency) will cause a vendor folder to get generated for the plugin which further more is only really a problem if using gitsubmodules because then it clutters up the git submodule repo status. That's really just correcting for developer mistakes (not including /vendor in the .gitignore and including composer dependencies even when they're not needed) but it would be nice to correct for those mistakes automatically.

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

2 participants