- Contributing
CSC staff: do these two things first:
- Join the Git organization CSCfi by sending email to [email protected].
- Then join here the CSC employees team. Membership gives you permissions to edit source files that build the user guide. (Wait for a confirmation email.)
The rest of this document describes the workflow in Github as well as instructions for previewing and deploying the documentation. See Style guide for content and formatting instructions and Frequently Asked Questions for more in depth explanations of common questions you might encounter while contributing.
Once you've completed the steps above:
- In docs.csc.fi go to the page you want to edit and click the pen icon at top right
- (sign in to GitHub) and edit the content
- Scroll down to commit changes (create a new branch) -> make a pull request
- Assign a reviewer
The csc-user-guide repository uses the 'master' as the default branch. You can make changes in web gui, command line or desktop application.
Master branch is protected. You cannot make changes to it directly, but you must use pull requests.
- Create your own branch from master (or work in an already existing branch, if agreed)
- Create / bring there the content you want to work with. Pay attention to file naming!
- Make sure the data is 100% correct (no Taito or other old references, language is correct, commands work, style is same as in other articles)
- When creating a new article, add it also to the mkdocs.yml navigation OR in the index.md file in that folder (in case of FAQs for example). For new software (=apps) pages, add them to by_discipline.md. See also the FAQ.
- Make a pull request for your work to be added to Master
- Look at the test results of your PR: if they are red, check what's wrong and commit to the PR directly to fix it. See the FAQ for instructions.
- Assign one or more reviewers, try to choose someone who knows the content. See also the FAQ.
- Please add a link to the rahtiapp-preview page
https://csc-guide-preview.rahtiapp.fi/origin/<your-branch-name>/rest-of-url/
) in the Pull Request description to help reviewer.
- Please add a link to the rahtiapp-preview page
- You can also add a label to your PR. For example, if your edit is minor (e.g. fixed link or typo), you can add the label "trivial change" to expedite the reviewing process.
- Pull requests which do not meet the requirements will not be accepted. Note that you can keep committing to a pull request after it has been submitted.
- If your commits aren't showing up on the pull request, i.e., the pull request isn't updating when making new commits, try switching the base branch ('Edit' button, top-right) from
master
to something else and then back again.
- If your commits aren't showing up on the pull request, i.e., the pull request isn't updating when making new commits, try switching the base branch ('Edit' button, top-right) from
- Write meaningful pull request messages, so it is easier for reviewers to do their job.
- Communicate! Use "WIP" (= Work In Progress) in your pull request title, if you don't wish the branch to be merged to master (i.e. you want to continue working with it).
- Once your PR has been accepted, remove the temporary branch (if not deleted by an admin at merge)
If you get a request to review a pull request, please contribute to help publish the changes!
- See the FAQ for detailed instructions.
- Follow the link (or navigate to the pull request)
- Make sure the tests pass
- Edit the pages as needed (perhaps via the Web GUI)
- It's ok to edit small typos directly in the text. Request changes if more extensive revisions are needed.
- Once you're happy with the content, in the "Files changed" tab click "Review changes" -> "Approve"
- Anyone can be a reviewer, while pull requests can be accepted only by a smaller group of people
If you see an approved branch:
- "Squash and merge" it
- Delete the (now unnecessary) branch
- Occasionally the number of (unnecessary) branches grows: prune.
Note: If you make bigger changes to the (main) categories / menu on the left, it might affect some links used on our webpages. Please communicate these changes, for example in the RC-channel #research.csc.fi.
The GitHub web interface gives a preview (also while editing) but it does not render all syntax used in mkdocs correctly. A full preview for ongoing work is available for all branches: https://csc-guide-preview.rahtiapp.fi/origin/ Note, currently absolute internal links don't work in the preview, but work on docs.csc.fi. For more details, see the FAQ.
- In the master branch, navigate to the page you want to edit.
- Click the pen-logo at the top right to edit.
- Once ready, at the bottom choose "Create new branch from this commit and start a pull request". Note, that you should give the branch a descriptive name at this point.
- If you wish to edit an already existing branch, first change to the correct branch in the upper left "branch" button, next to the path to the file.
- If you found an error in the pull request of your own branch, you can commit to it directly instead of creating another pull request (the two choices at the bottom).
Overview:
- Update your local repository
- Make a new branch from the master branch
- Work and commit in your new branch
- Push changes to GitHub
- Make a pull request to merge changes from your new branch into the master branch
- Ask a person to review and merge the changes
To get a copy of the repository, you need to clone it.
git clone https://github.com/CSCfi/csc-user-guide.git
All other Git commands are given inside the directory that you have cloned.
cd csc-user-guide
When you have cloned the repository, master branch is what you
see. If you are unsure which branch you are in, you can run git branch
. The active branch can be changed with the git checkout
command.
Method:
git pull
git checkout master # switch to master branch
git checkout -b your_branch_name # create a new (temporary) branch and switch to it
# create some nice content, add files
git add example-file.md
git status # check the status
git commit -v
git push origin your_branch_name
Now, in the GitHub web GUI you can create a pull request, ask a person to review it and (some admin to) merge the changes. After the PR has been merged, the branch on github can be deleted.
Tip 1. Git uses Vim as the default editor for commit messages. It is possible to change the default editor, but below are the most important commands if you do not want to do it right now.
i Enter insert mode
Esc Exit insert mode
:wq Save and exit
Tip 2. See instructions on how to write a good Git commit message.
Tip 3. If pushing fails, the most probable reason is that somebody else has made edits while you were editing. This situation is called a conflict. For instructions on how to resolve a conflict, see here (web GUI) and here (command line).
GitHub Desktop offers a third way to work with the repository.
To clone the repository, do the following:
- Click Current repository
- Click Add and select Clone repository...
- Find
CSCfi/csc-user-guide
and click Clone
Pull requests can be created as follows:
- Click Pull origin
- Click Current branch then New branch
- Type the name of the new branch and click Create branch
- Edit the files locally and commit the changes
- Finally click Publish branch and Create Pull Request
- You are directed to web gui, where you click Create pull request
See the FAQ for how to preview the Docs CSC website locally using MkDocs.
A newbie-friendly guide on how to set up the necessary tools on Windows is available here.
You can also create a Docker container to host the docs. First build an image from the included Dockerfile.
sudo docker build -t csc-user-guides .
This will build a container image called 'csc-user-guides'. Once the image is built, you can run it.
sudo docker run --rm -it -p 80:8000 --name csc-user-guides csc-user-guides
This will run a web server on your laptop in port 80. You can view the content of the user guides by pointing your browser to localhost.
Install & authorize command line tools. For reference, see the Rahti documentation.
The Dockerfile is also made to be compatible with OpenShift, so it
works with the source-to-image mechanism when using oc new-app
. First create a new project to host the user guide.
oc new-project my-user-guide-project
Note that the name of the project must be unique within the OpenShift
cluster you are running this in. Someone else may have already taken
my-user-guide-project
.
You can then run oc new-app
to create the user guide deployment.
oc new-app https://github.com/CSCfi/csc-user-guide#feature-a --name=csc-user-guide-feature-a
In the command above, the #feature-a
at the end specifies the branch to
use. The option --name=
is free to be chosen.
Now Rahti will build an image and a small webserver that can be exposed to
internet with the oc expose
command:
oc expose svc/csc-user-guide-feature-a --hostname=cug-user-guide-feature-a.rahtiapp.fi
You are free to choose any unused hostname.
Rebuilding the content is done with oc start-build
command:
oc start-build csc-user-guide-feature-a
Or by setting up a webhook (see Rahti User Guide.)
If you always do your features in the branch with the same name, you only have
to issue oc start-build
command to have your preview of the user-guide updated.
When you are sure you don't ever need the preview website again, please either
delete your project or clean it with oc delete
:
oc delete all -l app=csc-user-guide-feature-a
Each page in Docs CSC shows a "Last update" timestamp. To ensure that content
stays up to date and valid, it is good practice to search for and check pages
that have not been updated in a long time. A script scripts/last_update.sh
is provided for this purpose that goes through the git log and prints for each
.md
file its last update timestamp and who made the most recent commit.
Consider using the script from time to time to check pages that have not been
touched in a while, say, 1-2 years.
Run the script in the root of the repository as
bash scripts/last_update.sh
You can also filter out pages that no one has touched after you using the -u
option. The search pattern used here corresponds to your git username as
defined in your git config (see git config user.name
).
bash scripts/last_update.sh -u
Note that if you've changed your git username recently, the results may be incomplete and you might need to manually grep for your commits.
If you find something worth updating, please do so and create a PR to help us maintain Docs. If nothing needs to be modified, one way to update the timestamp without actually making any visible changes is to add a comment in the file using HTML tags, e.g.
<!-- Page OK, add comment to update timestamp -->