-
-
Notifications
You must be signed in to change notification settings - Fork 24
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
Improvement: smooth installation on non-root systems #233
Comments
Hrmmm. Yeah, def could be improved. Are you wishing for those utilities to be installed, but just via a method that doesn't require sudo? Such would still let all the Dorothy commands function as expected. Let's call this the non-root complete install option; this might be easy enough to do, such as updating setup-util to filter methods based on root/non-root with a flag. Or do you wish to not have them installed at all, and use only a minimal set of Dorothy commands that do not need them? If so, is this use of Dorothy only for Dorothy's cross-shell configuration loading but not for Dorothy's own commands? Let's call this non-root minimal install; this will require some thinking on the best approach. For bash, which bash version did you wish to keep it on? Or are you okay with Dorothy getting a newer bash, as long as Dorothy only has access to it? Bash is definitely a dependency in which older version support varies… here is a list of issues that I've encountered with older bash versions: https://github.com/bevry/dorothy/blob/master/docs/bash/versions.md the bash.bash file provides shims of various compromises: https://github.com/bevry/dorothy/blob/master/sources/bash.bash What operating system and architecture was this? Does it have a docker container? If so, we can add CI testing. |
I think this issue is about the "non-root complete install". If I hadn't been prompted many times by sudo, the process would have been fine. The complaint about bash was more of an afterthought. My thought as it was happening was basically "Do I really need a new version of bash?" and I felt a little out of control during the process. This machine is fairly old and outdated: RHEL 7.9 on x86-64. The built-in version of /bin/bash is 4.2.46. Maybe all that is needed here is a prompt or message saying that bash is being upgraded because it is older than a certain version, or making it an interactive decision. It does look like there is a docker container for RHEL 7.9, but it's deprecated so it's probably not even worth your time to worry about that version specifically. (We are upgrading soon..... hopefully). |
Interesting, so did the deps manage to install via an alternative method? Or did Dorothy, or that dep installation, end up failing in the end? Do you still have the output of this session and are able to share, if so, it'll be easier for me to know which methods to filter as non-root compatible.
Good feedback. It does this check internally, but never communicates it externally if it can just do the upgrade: Lines 60 to 74 in a982b1d
dorothy/commands/is-bash-version-outdated Lines 86 to 90 in a982b1d
dorothy/commands/setup-util-bash Lines 92 to 99 in a982b1d
Will update it accordingly so that it is mentioned why it is upgrading. |
Some of them, such as bash, managed to install via an alternate method. It seemed like some of the others, like openssl, failed but then the process moved on. It's a bit unclear what happened to the dorothy install as a whole. The install did seem to fail, but it wasn't completely clear why. (It might have been my fault -- I have a submodule on my
I didn't save it, but I will recreate it. |
Hrmm, will need to see then in the recreation.
Ok cool, thank you. Could you record as well if not too inconvenient? I think the next step here is finding an up to date container that can reproduce the non-root experience. Then I can develop the adjustments against it, and add CI support for the adjustments. Would you be able to post back with such a container? I will schedule any adjustments for after #229 lands, which is my current task. So have 2 weeks before I start on this. |
Here's a A couple notes:
Not sure what was going on there, I didn't "select" any of them.
I'll try in the container and see if the same thing happens. |
I replicated this in a Docker container here: https://github.com/edmcman/dorothy-issue233 I also created a video: |
Great, thank you. So there's two approaches that I'm thinking of:
for the actual dorothy installation:
I've scheduled this in my Dorothy batch of work and for completion it'll probably be sometime next month. If someone wants to beat me to it, that's good too. depending on how it all goes, it may make sense to introduce a few different installation options:
however alternative installation options will be significant increase in complexity and support burden, so should only be done if justified and sustainable |
Besides the few fixes on the issue tracker, this is up next. |
Some good news. #268 will be implemented soon, in the current batch of changes, and while it won't completely eliminate sudo, it will dramatically reduce Dorothy's need for it. Doing the configuration adjustments for sudo is still on the roadmap. |
I am installing dorothy on a machine that I don't have root on. It begins to install the required packages, and basically prompts me to enter a sudo password many times for bash, moreutils, llvm, openssl, and so on. This is pretty annoying. I can press
Ctrl-D
to makesudo
bail and dorothy continues, but it's definitely not a great experience.Since dorothy can't upgrade the bash package, it also downloads and installs a new version of
bash
from source, which I really didn't want it to do.The text was updated successfully, but these errors were encountered: