-
Notifications
You must be signed in to change notification settings - Fork 51
Drush launcher is not reading site aliases? #32
Comments
Same symptom. Drush Launcher installed as global composer package, OS: Ubuntu. Recognizes local Drush instance only if command ran inside Drupal's directory. |
The error message is in error -- site aliases have never been supported in the launcher, although this is an aspirational goal. Try installing Drush 9 globally, and use that as a launcher for your site-local instances of Drush 8. Should work great, and supports aliases. Note that Drush 9 uses a .yml format for aliases, but it will auto-convert from the old style to the new style. This strategy will change by the release of Drush 9.0.0 stable -- you will need to explicitly run a command to convert your aliases to the new format. If Drush 9.0.0 works for you as a launcher, I'd recommend switching to use the .yml format. If we do manage to add alias support to the launcher, we would use the .yml format. |
I removed that line from the error message. At this time, the launcher must have a local Drupal site before it can resolve any alias that is passed. |
In beta5, Drush aliases (and commandfiles) are no longer auto-discovered in the global locations like
This needs documenting somewhere. |
We were going to move this from |
c.f. drush-ops/drush#3010 |
I don't quite understand this. Aren't global aliases like those present on ~/.drush/ read by drush and not the launcher.. and if so, why wouldn't they work from the site-local version on drupal on drush 8.x. Or that was removed too from that branch? Are you saying that global aliases will never work? |
By default, Drush does not read alias files from global locations. To opt-in for this behavior, you need to set the valid alias locations in your drush.yml file. This is now documented in the site aliases example. |
but isn't that a drush 9 thing? or would a drush.yml file work for drush 8? Where should I put that file? What I meant is that if that my local version of drush is 8, that one does read from the global locations by default right?
Doesn't work
works. Both run from the site site-local. Using the latest launcher 0.4.2. |
Once the launcher has selected a particular Drupal site, it adds |
Thanks for the follow ups! Hmm, and why would it do that? I always thought as a launcher to select the proper version of drush, by why preventing global configs from being read, if that's what global configs are for. I guess I might be missing something, or maybe allow that to be optional for the launcher.. I guess I can edit it for the time being. And.. would What would be the recommended way of using drush8 and global aliases with the launcher? What you suggested above, using drush9 globally as the launcher? That's a bit counterintuitive, why would I want a global drush 9 if the recommended way is having drush as a site-local setup. |
I'm finding this to be an issue when trying to run drush make with no Drupal site files at all. Is there a work around for this? |
One of my hosts has two Drupal 8.4.0-rc2 instances in different paths. Site aliases are properly configured. When my current working directory is outside these paths, all attempts to run drush end up with an error:
When run inside a Drupal dir, drush works mostly, but site aliases are still not read (they're configured outside the project). It seems to me that drush is not even trying to read drushrc.php or aliases from ~/.drush or /etc/drush without --config option. Should it? And even --config doesn't help outside the project.
If I replace drush launcher with Drush 8.1.3 in /usr/local/bin, everything works just fine. Is this an environment problem, user error or a bug or feature in the launcher? (Running Ubuntu 16 & PHP7, Drush 9.0.0-beta4)
The text was updated successfully, but these errors were encountered: