-
-
Notifications
You must be signed in to change notification settings - Fork 5
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
[Help Needed] Working out CLI install workflows #170
Comments
I can help with Linux and/or Windows (I have access to both). I have little brothers who can be guinea pigs to see if they understand the instructions for beginners 😄 I'm more familiar with Linux development tools but I could probably figure out stuff for Windows, too. I solve exercism exercises in both. |
I can help with Linux. |
@HarrisonMc555 @mienaikage Thank you both. So I think the first step would be to go through the instructions at http://exercism.io/clients/cli/linux and check they are:
Then the next key thing is to highlight all the things that might block a beginner. For example, are the instructions at https://chocolatey.org/install usable for a beginner. One of the first lines is "Copy the text specific to your command shell" - does a beginner know what a command shell is and how to get it it? Once we've got all that information down, I think the key deliverable is a flowchart of knowledge (as I tried to explain in the initial post). Does that sound like a sane approach? |
That sounds like a sane approach, although I'd suggest also checking whether steps are necessary. |
I'm on board for Windows 10, Windows 7, and desktop Linux. |
They aren't, but at least they are canonical! We held that discussion before, and it is a complicated thing. |
If they're not usable then we need to work out how to make them usable then. Which bits don't make sense to a beginner and how can we help a beginner through that? |
There are this paragraphs:
They have improved since I installed choco by myself, but they appear to be an unimportant side note. Also I feel as if the hole page were out of order (in a sense that stuff is not written one after the other, but in random order). We once had an explanation of how to install choco on the website, but it got out of sync with the way choco was actually installed. We had about one broken choco install because of that per day in gitter.im/exercism/support. Some of them where broken in a way that involved very hard debugging sessions or even RDP sessions for actually helping to remove the partially installed choco and recovering the system into a state that was "clean enough" to start from scratch. Since those instructions were removed we only have about a single one per month asking about how to install choco. Since those people haven't broken their system until then it is a matter of minutes to help them out. So I stick to my opinion, that chocos instruction aren't clear, but at least clear enough and also they are the only canonical description of how to install choco! |
I was looking at the Choco instructions provided for the Windows client. It seems to me that Choco should be documented as an optional tool for install/updating the Windows CLI. In the meantime I thought I would try out the Windows Installer for the CLI. It won't work for me, so I have created issue #13 in the windows-installer repo. |
I think this would make sense. I would really like us to have a simple, beginner-friendly way for anyone to install Exercism. For people who already have Choco, then that is probably a good choice. But if not, then maybe we can come up with something better. If we could get the windows installer working, that might be a good choice. Or something else—like I said, I'm not so particular about which approach we choose, only that we find a way to lower the barrier for folks who might never have interacted with the command line before. |
@NobbZ Thanks for giving us some background on this.
It strikes me that the problems with the choco instructions are around using language that a beginner might not be familiar with (e.g. "Command Line"). If we can highlight those terms, then we can explain them to a beginner before pushing them to that file. That then means we can have canonical instructions, but also demystify them in advance.
This could just as easily mean we only have one total beginner per month installing Exercism on Windows now because they find it too difficult to do. I'm not sure that it's a good measure of whether it works or not, although I understand that it's a good thing that it's reduced the burden of maintainers on gitter. |
@iHiD I'm not sure if there was a particular place you wanted me to provide feedback, so I'll do it here unless otherwise directed. Linux CLI install workflowFunctional CheckFrom what I can tell, the instructions are both
Beginner stumbling blocksTo get a good perspective on how a beginner would feel, I got my 13-year-old brother (who has never used Linux) to try to get started using exercism. I had him start on the home page, but he quickly found his way to the Linux CLI installation page. Unfortunately, he got stuck pretty quickly, and even after trying for 10-15 minutes he wasn't able to figure out what to do. Eventually I gave him a few pointers which helped him get through. Here are some of my observations:
Suggested FlowMy suggested flow for Linux would only include one question:
Yes
Not really
I don't know what that is
|
@HarrisonMc555 this is amazing. I have no useful feedback only holy shit thank you 🌷 🌷 🌷 |
@HarrisonMc555 Thank you thank you thank you. This is super-helpful! |
@HarrisonMc555 I like your detailed report, and I really welcome the courage of your brother to be the “lab rat” for you ;) I do hope, that touching linux didn't do him any permanent harm ;) But I do not think, we should blow up linux instructions into even more sub-pages. Instead just give instructions for enabling system specific repositorys to install via As a last resort, we should provide a simple script, which one can download and run, which then does the following:
We could advertise this, as a non-root or local install, which might be necessary for some people. Not everyone will be able to do systemwide installs. [1]: I try to maintain a portage overlay at https://github.com/NobbZ/gentoo-overlay for personal use, which also includes [2]: I think providing official support for |
@kytrinyx @iHiD @NobbZ glad you found this helpful! @NobbZ I understand your reluctance to split the Linux instructions into sub-pages, but I'm going to stand by my original suggestions. I still go to the difference between me and my brother as the reason. If I started with exercism and had to wade through all of the information I suggest under the "I don't know what that is" section then I would find it really tedious. My thoughts would be "just show me a However, if you removed all of the helpful information, you return back to the state that we're currently at where beginners have no idea where to start or even where to look for help. At one point my brother Googled "Getting started with exercism" or something to that effect because he had no idea what to do. I think it would be quite beneficial to have different tracks for different degrees of familiarity for each OS. We've already decided to make different installation instructions for "beginners" and "experts", but that is before you go down a specific "OS track". I'm suggesting pushing down the beginner/expert distinction into the "OS tracks". It makes sense to do this since there are a lot of OS-specific instructions that we need to include for "beginners" that we don't need to include for "experts". I do agree that using |
@NobbZ I forgot to reply to your suggestion of the "last resort" script...I'm not sure if I'm a fan of that. Mostly because I would feel hesitant to alter the user's Is it too much to ask for a beginner to:
This is what we already ask users to do in the current instructions. The benefits I see to having beginning users explicitly type/copy and paste these in the command line is that
|
Of course I do not say, that our install page should simply say "run BUT, I had some talk with my father tonight, whom I showed the install page as well. He is using linux for about a year now, but GUI only. He was aware of the existence of the shell, but simply doesn't use it, since there is enough tooling available for him to avoid it. I asked him to at least take a look at the page. He told me, that it is far to much text, and suggested a short oneline installer as well. Folks wan't to get things up and running, not study CS just to install a small tool, which most of us do only use a subset of its functionality of. Perhaps we can have something like this:
Also I do not think we should explain how to open a terminal. The user will already know how to start a program on his DE, and we can't cover them all. There are quite to many. Also we should provide very precise comments in the script. You are right, altering the users rc-file without asking might be considered rude, but we could ask if we are allowed to. |
One of our goals with reworking all of this is to hide all the text that someone doesn't need to see now or yet or at all. This will vary from person to person, and in order to achieve this we need feedback about (1) whether or not the current instructions are complete and correct, and (2) how different people react to them so that we can start seeing patterns. Right now we're not making decisions about how to solve it, we're trying to figure out what the underlying constraints are, and what our options are. |
I stumbled upon AppImage for the first time today. It looks like it could be quite handy for the Linux CLI install process. |
Since go-binaries are usually statically linked and have no runtime dependencies, we do not need an additional layer of packaging. For AppImage there needs still to be choosen between 32 and 64 bit, and AFAIK it won't work on ARM. So it wouldn't change anything, we had 6 different linux builds to choose from. |
We've got this sorted, thanks to a whole host of helpful contributions. If you want to see it in action check out https://exercism.io/cli-walkthrough and if you want to contribute improvements check out https://github.com/exercism/interactive-cli-walkthrough |
Hi everyone. We need some help!
As part of the new website we want to build comprehensive instructions that make it really simple for beginners and experts to install the exercism CLI and download exercises. Depending on experience this ranges from something like
brew install exercism && exercism download bob
to "This is what a terminal is..."There's loads of content spread around on the current site, from language installation instructions to how to install the CLI. We want to to turn this into a series of questions and answers that are easy to walk through. For example:
etc etc
We need some volunteers to work out what these flows look like for Windows, Mac, and Linux. We'll then put them together into a master flow on the website.
Doing this requires the skill of understanding all the things a beginner would have no idea about, and also a knowledge of how to install everything on your OS. We also need this done asap (within 7 days).
If you'd like to volunteer to help, could you please say so below and then we'll move add you to a repo where we can work this all out. We'd be very very grateful! :)
The text was updated successfully, but these errors were encountered: