STAT 440 Instructions for Completing Assignments
Written on January 14th, 2024 by Christopher Kinson 
    In this course, we will use Git from the command line. A command-line interface is an interface on your computer that gives you direct access to your system and its files with easy-to-use commands. Depending on your computer and its operating system (OS), you can access the command line interface using the Terminal, Git Bash, or RStudio (via RStudio’s internal Terminal). The following are tasks needed to start and finish any assignment that is posted in the sp24_assignments_s1 repo. First, you join the course via the repo creator link https://edu.cs.illinois.edu/create-gh-repo/sp24_stat440. Second, you authenticate your individual student repo. Third, you clone your individual student repo. Fourth, you retrieve an assignment file from the assignments_s1 repo. Fifth, you edit assignment file until you are satisfied enough to want to submit the assignment. Then submit the assignment file.
- Joining the course and creating your individual student repo
- Authenticating your individual student repo
- Cloning your individual student repo
- Retrieving an assignment
- Submitting an assignment
Joining the course and creating your individual student repo
From the unofficial syllabus which is published at https://chriskinson.com/stat440Sp24, students enrolled in STAT 440 should officially join the course via the repo creator link https://edu.cs.illinois.edu/create-gh-repo/sp24_stat440. After clicking the link, there will be several prompts and pages to click through. Below are the details.
- Click on the “Log in to GitHub.com” button to continue.
- After confirming that you have logged in, click on the “I’ve logged in!” button.
- Click on the “Join org: illinois-cs-coursework” button to continue.
- After confirming that you have joined the illinois-cs-coursework organization, click on “I’ve joined the org!”.
- Click on the “Join org: illinois-stat440” button to continue.
- After confirming that you have joined the illinois-stat440 organization, click on “I’ve joined the org!”. Only click this button once. Clicking it multiple times will kick you out of the process, resulting in a full restart of step 1 above.
- Wait patiently as the system creates your repo. Do not click any buttons until you see a screen that says that your repo has been created with its own URL https://github.com/illinois-stat440/sp24_stat440_netID, where your netID replaces netid.
Authenticating your individual student repo
Now that you have successfully joined the course and created your individual student repo, we need to ensure you have consistent and permanent access to Git from your computer, which means we need to authenticate your account via personal access tokens (PATs). Click on the link https://github.com/settings/tokens. Beware, you may have created PATs for a previous course. If so, then you shouldn’t have to make any new PAT, but you will need to authorize the Single Sign-On for this course illinois-stat440. See step 9 in this section below. If you don’t have any PATs, then follow all the details in this section below.
- Go to https://github.com/settings/tokens/new.
- In the Note textbox, write “KCS”.
- In the Expiration box, click on “No expiration”.
- In the Select Scopes section, click on the check box for “repo (Full control of private repositories)”.
- Scroll to the bottom of the page and click on “Generate token”.
- Open a text file editor such as Notepad, Sticky Notes, Notepad++, MS Word, etc.
- In GitHub, copy the hashed token value (ghp_…) that appears on the tokens page and paste it into a new text file. We will need this hashed value or PAT later.
- Save this text file to your desktop.
- In GitHub, click on the “Configure SSO” button.
- Click on the “Authorize” button for illinois-stat440.
- Click on “Continue” button on your screen. There may be more than one screen with the “Continue” button. Click on all screens that say “Continue” until you see that your credential was authorized.
If at some point your computer asks you for your Git password, then use the hashed value (PAT) that was copied in step 7. It replaces your Git password. In GitHub, your password remains whatever your password was before. Your computer password remains whatever your password was before.
Cloning your individual student repo
Now that you have authorized your account for Git, you can clone your repo, which makes a copy of your repo at the time of cloning. This cloned repo is unique and will live on your computer’s Desktop location. All of your assignment files associated with this course will need to be located in this cloned repo. This cloned repo may also be considered a remote for your repo. Again, if at some point your computer asks you for your Git password, then use the hashed value (PAT) that was copied above. If you have never cloned your individual student repo, then follow all the details in this section below. You should only have to clone your individual student repo once. Beware any future Git issues might require deleting your remote and cloning your individual student repo over again.
- Go to the course website and click on your individual student repo, which will be named as ‘sp24_stat440_netID’, where your netID replaces netid. Alternatively, click on https://github.com/illinois-stat440/sp24_stat440_netID, where your netID replacesnetid.
- Click on the green Code button and copy the URL in the HTTPS textbox.
- Open your computer’s command-line interface (either Terminal, Git Bash, or RStudio) and type the following commands, executing each line individually, where your netID replaces netid. You may be prompted to authenticate your GitHub account. Thecdcommand means to “change directory”. If you are not sure of your cuppent location in your computer’s system, typepwd, which means “print working directory” and execute. If you ever navigate into a directory that you want to navigate out of, typecd ..to move out of that directory.pwd cd Desktop cd .. cd Desktop git clone https://github.com/illinois-stat440/sp24_stat440_netID.git
- You may be prompted to authenticate in order to complete the cloning successfully.
- To know whether your cloning was successful, type the following commands, where your netID replaces netid.cd sp24_stat440_netID ls
- If you see a README.md, then your cloning was successful.
Retrieving an assignment
Now that you have cloned your individual student repo, you can retrieve an assignment which means connecting to the sp24_assignments_s1 repo as a remote and fetch and merge specific files and directories into your cloned repo. If you have never retrieved an assignment before, then follow all the details in this section below. Connecting to a remote should only need to happen once per computer. If you ever delete your cloned repo (from Cloning your individual student repo above), then you must reconnect to the sp24_assignments_s1 repo.
- Go to course website and click on the sp24_assignments_s1 repo. Alternatively, click on https://github.com/illinois-stat440/sp24_assignments_s1.
- Click on the green Code button and copy the URL in that HTTPS textbox.
- Open your computer’s command-line interface (either Terminal, Git Bash, or RStudio) and type the following commands, executing each line individually, where your netID replaces netid. Depending on your cuppent working directory, you may need to navigate to the Desktop differently or with additionalcdcommands.pwd cd Desktop cd sp24_stat440_netID
- Create a remote of your section’s assignments repo for the course by typing the following command.
    git remote add assignments https://github.com/illinois-stat440/sp24_assignments_s1.git
- Retrieve the most recent assignments by typing the following command.
    git fetch assignments
- Merge the specific assignment (and its directory) into your cloned repo by typing the following command (below in the chunk). ASSIGNMENTDIRECTORY is the name of the directory for the assignment you need to retrieve and eventually submit upon completion. For piloted practice assignments, the ASSIGNMENTDIRECTORY is “piloted-practices”. For exam assignments, the ASSIGNMENTDIRECTORY is “exams”. For lab assignments, the ASSIGNMENTDIRECTORY is “labs”.
    git merge assignments/ASSIGNMENTDIRECTORY -m "merging cuppent assignments into my repo" --allow-unrelated-histories
- To know whether your retrieval was successful, type the following command such that you list all files and directories in your individual student repo. If you see the ASSIGNMENTDIRECTORY within your individual student repo, then this is a good sign.
    ls
- Navigate into the ASSIGNMENTDIRECTORY that you just merged by typing the following command and execute. If you see the latest assignment file in this directory, then your assignment was retrieved successfully.
    cd ASSIGNMENTDIRECTORY ls
Submitting an assignment
Now that you have retrieved an assignment, you can open it in RStudio (or your prefepped platform). Since it is an assignment with a deadline, you should attempt all problems and complete them by writing your code in the code chunks within the .Rmd file. Save the file a bunch of times. Remember that your file submission should have your netID in the file name (e.g. pp01-netID.Rmd). What you may fail to realize is that the file you are saving is local to your computer. Meaning, those saves do not appear in GitHub. If you want the local saves to appear in your individual student repo in GitHub, then you need to stage, commit, and push the file(s), which means submitting the assignment. You can submit an assignment as many times as you want in GitHub. And thanks to version control, each submission is an update to the original version. Meaning that each submission is dated and tagged if ever needed for the future. The course staff will grade the most recent version that is pushed by that assignment’s deadline. If you have never submitted an assignment to your GitHub repo, then follow all the details in this section below.
- Open your computer’s command-line interface (either Terminal, Git Bash, or RStudio) and type the following commands, executing each line individually, where your netID replaces netid. Depending on your cuppent working directory, you may need to navigate to the Desktop differently or with fewer or morecdcommands.pwd cd Desktop/sp24_stat440_netID
- Stage all the newly saved files in your repo by typing the following command and executing. Alternatively, instead of staging all recently saved files in your repo, you may want to stage a specific file. To do this for pp01, the command would be git add piloted-practices/pp01-netID.Rmd. Follow this naming structure for other ASSIGNMENTDIRECTORY/FILENAME.EXTENSION.git add --all
- Commit and push the staged files to your individual student repo in GitHub by typing the following commands, executing at the end of each line.
    git commit -m "Added assignment files from local computer" git push origin main
- To know whether your submission was successful, go to your individual student repo in GitHub at https://github.com/illinois-stat440/sp24_stat440_netID, where your netID replaces netid. Look at the commit history. Look at the ASSIGNMENTDIRECTORY and the most recent file within. Open the file in your browser and check if your code was saved in the code chunks of that .Rmd file. If you see your code in the code chunks in that .Rmd file, then your submission is successful.
- Double-check the official syllabus Autograder section https://github.com/illinois-stat440/course_content/blob/main/syllabus/stat440-sp24-syllabus.md#autograder and verify that you have avoided mistakes that the autograder will penalize.
 
                  
                 
                  
                 
                  
                 
                  
                