===== Git - version control tool ===== 'git' is an open source version control protocol available to all users on Pinnacle. It is used to keep track of changes made to files in a specific directory. The basic commands used for this purpose are: git init - specify a directory for version control with git git add - add a file to a list of file for version control git commit - create a snapshot of the current version of files git branch - create an alternate version of files git checkout - switch to the alternate branch (version of files) git merge - combine two branches into one git log - show a history of commits (snapshots) git ls-files - show an index of files in the version control system The following example shows step by step how to use git to keep track of changes made to your personal project on Pinnacle. **1.** create a new project directory and initialize its management with git. (''git init'') pinnacle-l1:pwolinsk:~$ mkdir project1 pinnacle-l1:pwolinsk:~$ cd project1/ pinnacle-l1:pwolinsk:~/project1$ git init Initialized empty Git repository in /scrfs/storage/pwolinsk/home/project1/.git/ pinnacle-l1:pwolinsk:~/project1$ **2.** create files in the project directory pinnacle-l1:pwolinsk:~/project1$ nano file1 pinnacle-l1:pwolinsk:~/project1$ nano file2 pinnacle-l1:pwolinsk:~/project1$ cat file1 Some text in file1 pinnacle-l1:pwolinsk:~/project1$ cat file2 More text in file 2. pinnacle-l1:pwolinsk:~/project1$ **3.** add new files to the index (list) of files managed with git. (''git add '',''git status'') pinnacle-l1:pwolinsk:~/project1$ git status # On branch master # # Initial commit # # Untracked files: # (use "git add ..." to include in what will be committed) # # file1 # file2 nothing added to commit but untracked files present (use "git add" to track) pinnacle-l1:pwolinsk:~/project1$ git add file1 pinnacle-l1:pwolinsk:~/project1$ git add file2 pinnacle-l1:pwolinsk:~/project1$ git status # On branch master # # Initial commit # # Changes to be committed: # (use "git rm --cached ..." to unstage) # # new file: file1 # new file: file2 # pinnacle-l1:pwolinsk:~/project1$ **4.** create a snapshot of the current state of all files tracked by git in the project directory. (''git commit -m "commit comment" '') pinnacle-l1:pwolinsk:~/project1$ git commit -m "added initial text to file 1" file1 [master (root-commit) d4a8ab1] added initial text to file 1 1 file changed, 1 insertion(+) create mode 100644 file1 pinnacle-l1:pwolinsk:~/project1$ git commit -m "added initial text to file 2" file2 [master cd7ebfa] added initial text to file 2 1 file changed, 1 insertion(+) create mode 100644 file2 pinnacle-l1:pwolinsk:~/project1$ **5.** modify file1 and file2 and create another snapshot of the current version of files. (''git commit -a -m "commit comment"'' will commit all tracked files in a project with a single comment.) pinnacle-l1:pwolinsk:~/project1$ echo "line 2" >> file1 pinnacle-l1:pwolinsk:~/project1$ echo "line 2 again" >>file2 pinnacle-l1:pwolinsk:~/project1$ git commit -a -m "added extra lines to file1 and file2" [master db1a5f1] added extra lines to file1 and file2 2 files changed, 2 insertions(+) pinnacle-l1:pwolinsk:~/project1$ **6.** review a history of commits. (''git log'') pinnacle-l1:pwolinsk:~/project1$ git log commit db1a5f1746b635bdbb73ebcc49dc3cf56a8ba2cf Author: pwolinsk Date: Tue Mar 1 12:47:48 2022 -0600 added extra lines to file1 and file2 commit cd7ebfa2e6e67cf4e918be7bbba5c0e79af76036 Author: pwolinsk Date: Tue Mar 1 12:45:02 2022 -0600 added initial text to file 2 commit d4a8ab16fc53ba39b8bdf8f3b40db21681901f2f Author: pwolinsk Date: Tue Mar 1 12:44:55 2022 -0600 added initial text to file 1 pinnacle-l1:pwolinsk:~/project1$ **7.** Revert to a previous version of the files. (''git checkout '') pinnacle-l1:pwolinsk:~/project1$ cat file1 Some text in file1 pinnacle-l1:pwolinsk:~/project1$ cat file2 More text in file 2. line 2 again pinnacle-l1:pwolinsk:~/project1$ git checkout d4a8ab16fc53ba39b8bdf8f3b40db21681901f2f Note: checking out 'd4a8ab16fc53ba39b8bdf8f3b40db21681901f2f'. You are in 'detached HEAD' state. You can look around, make experimental changes and commit them, and you can discard any commits you make in this state without impacting any branches by performing another checkout. If you want to create a new branch to retain commits you create, you may do so (now or later) by using -b with the checkout command again. Example: git checkout -b new_branch_name HEAD is now at d4a8ab1... added initial text to file 1 pinnacle-l1:pwolinsk:~/project1$ cat file1 Some text in file1 pinnacle-l1:pwolinsk:~/project1$ cat file2 pinnacle-l1:pwolinsk:~/project1$ **8.** Go back to the latest version of files. (''git log --all'' shows all commits even those after the current commit version,''git checkout '') pinnacle-l1:pwolinsk:~/project1$ git log commit db1a5f1746b635bdbb73ebcc49dc3cf56a8ba2cf Author: pwolinsk Date: Tue Mar 1 12:47:48 2022 -0600 added extra lines to file1 and file2 commit cd7ebfa2e6e67cf4e918be7bbba5c0e79af76036 Author: pwolinsk Date: Tue Mar 1 12:45:02 2022 -0600 added initial text to file 2 commit d4a8ab16fc53ba39b8bdf8f3b40db21681901f2f Author: pwolinsk Date: Tue Mar 1 12:44:55 2022 -0600 added initial text to file 1 pinnacle-l1:pwolinsk:~/project1$ pinnacle-l1:pwolinsk:~/project1$ git checkout db1a5f1746b635bdbb73ebcc49dc3cf56a8ba2cf Previous HEAD position was d4a8ab1... added initial text to file 1 HEAD is now at db1a5f1... added extra lines to file1 and file2 pinnacle-l1:pwolinsk:~/project1$ cat file1 Some text in file1 line 2 pinnacle-l1:pwolinsk:~/project1$ cat file2 More text in file 2. line 2 again pinnacle-l1:pwolinsk:~/project1$ ===== GitHub ===== Github is a popular platform for collaboration and data sharing. It is based on the 'git' version control software. Github.com is the central cloud based repository which provides storage for github user data. The github CLI (command line interface) allows AHPCC users to move data between the github repository and the AHPCC cluster storage as well as share them with other AHPCC users. ==== DART-ARP organization ==== A Github orgranization allow its members to collaborate and share data with each other. AHPCC set up a github organization named **DART-ARP** (Data Analytics that are Robust and Trusted - Arkansas Research Platform). ==== Joining DART-ARP ==== To become a member of DART-ARP organization and enable AHPCC/github integration, each user has to perform the following actions: - create a personal github account - add the AHPCC account SSH public key to the personal github account - accept and invitation to joing DART-ARP organization A user executable script **''join-github-DART-ARP.sh''** is available to assist in performing these steps. pinnacle-l7:user1:~$ /share/apps/bin/join-github-DART-ARP.sh ============= JOIN AHPCC-DART github orgranization =============== If you do not already have an active github.com account, before continuing with this script please visit: https://github.com/signup Do you have an existing github account? [y/N] y Please enter you github username: user1 Please enter your email: user1@uark.edu Github username: user1 email: user1@uark.edu Is this correct? [y/N] y Using a browser, please copy and paste your AHPCC SSH public key below into your github.com account (Account Profile->Settings->SSH and GPG Keys->New SSH key) ssh-rsa AAAAB3NzaC1yc2weiHlqDTaj1nTryFTIagEnMs+d5WhEskL4JFvFo+Er7qwDV8bziQWFuUmFTYZWcuZpyLbWgf9b5oAjlmu7bUd2FIGi2jQDut0wI9Oq8tRdjY5nNNLw9zPY3e/+gRPV7bypg549E9gU5poaagKSq4QBqCEzuIUOIMhTgNzEQiVSmfgQg9OICX4njDJuaUxprQHxAz5F4wKd/lE8rSRV6e0MlE19kbByC8A+akfk8V/pzmBoRejeAwd+70dZALFHoMU90prl8enY0KsQHmApf0ucyi6La95qRtu32w== user1@ar.uark.edu Did you add your public SSH key above to your github.com account? [y/N] y Your github configuration (in /home/user1/.gitconfig): [user] name = user1 email = gh_email [color] ui = true Logging into github... Please select "SSH, SKIP upload public key, authentication token" below Then please use a brower to open https://github.com/settings/tokens ? What is your preferred protocol for Git operations? SSH ? Upload your SSH public key to your GitHub account? Skip ? How would you like to authenticate GitHub CLI? Paste an authentication token Tip: you can generate a Personal Access Token here https://github.com/settings/tokens The minimum required scopes are 'repo', 'read:org'. ? Paste your authentication token: **************************************** - gh config set -h github.com git_protocol ssh ✓ Configured git protocol ✓ Logged in as user1 Testing github integration with your AHPCC account... github.com ✓ Logged in to github.com as user1 (/home/user1/.config/gh/hosts.yml) ✓ Git operations for github.com configured to use ssh protocol. ✓ Token: ******************* Invitation to join DART-ARP github organization has been sent to user1@uark.edu Please follow the link in the email to join. pinnacle-l7:user1:~$