The new version of the IVOA website is being developed with Hugo, a popular open-source tool for generating static websites. Instead of creating and modifying the site content directly in HTML, contributors will write markdown for most content. Since the site is now managed in Github using source control, development will follow a typical Git workflow, which will be covered in detail.
You should install git if it is not already present on your system.
An account on Github is required, along with write permissions on the ivoa-web repository. Please refer to the Getting Help section for information on how to request write access to the repository.
In the future, the administrators plan to accept pull requests from forks, after which write access will not be required.
Pushing changes to the repository also requires working authentication, which is covered in the set up git documentation.
The site's repository may be checked out from Github as folows:
git clone https://github.com/ivoa/ivoa-web.git
You will now be able to make your intended changes locally and preview them.
All updates to the site beyond trivial ones, such as fixing spelling mistakes, should have their own dedicated issue in the Github issue tracker.
Here is the complete process for creating an issue:
- Go to the ivoa-web issues page and click on "New Issue."
- Under "Add a title," write a brief phrase describing what you plan to do in the present tense, for example, "Add a page describing what the IVOA does." (You do not need to include punctuation in the title itself.)
- Add a description with additional details about what you plan to do under "Add a description," if you feel that it would be helpful.
- Optionally, assign an appropriate tag such as "enhancement."
- Finally, click on "Submit new issue."
You will now be redirected to the new issue page. The number of the issue by the title (starts with "#") will be used in creating the Git branch corresponding to the issue.
You will need to create a branch which will contain the updates to the site.
If you are working from an existing copy of the repository rather than checking it out for the first time, always update the main
branch before creating your issue branch, as follows:
git checkout main && git pull
Assuming your issue number was "1234", which is just an example, a branch can be created as follows from your local ivoa-web
directory:
git checkout -b iss1234
The above naming pattern is preferred to clearly connect your branch to a corresponding issue in the Github tracker for future reference and documentation of what changes are being made and by whom.
You may optionally include some brief text in the branch name to describe your work, such as iss1234-add-a-page-about-the-ivoa
. The most important part is starting the branch name with iss
followed by the number of the issue in the tracker.
Hugo can be used to build the site locally and preview your changes. You may follow the installation instructions for your platform.
You can test that the hugo
command works by executing this command:
hugo --help
This will show a lot of usage information in the terminal.
Once you have changed an existing page or added a new one, the entire site can be regenerated with this simple command:
hugo -D
The -D
argument will make sure that links within the site use the local development URL.
In order to view the local version of the site, you can run the Hugo web server:
hugo server --watch --port 1313 -DEF --printI18nWarnings
Now, you will be able to see a local preview of the site at this address in your browser: http://localhost:1313/
The "What is the VO?" page provides a simple example of a markdown file. Most pages that you would likely add or change will similarily be located under content in the repository.
A typical markdown file will include a header followed by the page content, as in:
---
title: "What is the VO?"
date: 2024-02-09T10:00:00+02:00
draft: false
tags:
- about
---
The goal of the Virtual Observatory (VO) is most easily described by analogy with the World Wide Web.
[rest of content]
The date
is provided here for example purposes only. Usually, you can leave it out and the dates from your last Git commit to that file will be used automatically.
If not already present, a link should be added to the site map pointing to the new page, or you may need to add one or more links to other parts of the site. Please consult with the site administrators if you have questions about where you might need to add or update links based on your changes.
After you have updated your local repository with changes, you will need to follow this standard set of steps to push them to the Github repository.
- Use
git add
to stage the changes locally - When you type
git status
, the files which were added should show in green (You may want to double check that all the files you intended to add are listed there and that additional files were not included accidentally.) - Commit the changes with a message, e.g.,
git commit -m "Add about the IVOA page"
(You may want to review How to write better commit messages for some guidelines on this step.) - Push your branch with a command such as
git push --set-upstream origin iss1234
Once your local branch is associated with a remote branch on Github, you should subsequently be able to push using only the simple command git push
.
Once you have pushed all your changes, you may then open a pull request (PR) which is a request to merge your updates into the main copy of the site.
Here is the process for doing this:
- From this page, click on "New pull request."
- Select your branch from the list
- In the next page previewing your PR, confirm that the changes you see look correct
- Add descriptive text if you feel it is necessary
Now click "Create pull request."
It would also be helpful under "Development" on the righthand menu to select your branch from the list in order to connect it to the PR. (You can search for the issue by its issue number in the search box.)
Your changes will be included in a new branch version of the website after you open a PR. The deployment of this site is triggered automatically in the PR checks.
Assuming the issue branch was called iss10
and the action complete succesfully, the development version would be accessible at:
https://webtest.ivoa.info/v/iss10/
Additionally, a list of all available development versions of the site can be viewed at:
For now, these development versions are not deleted automatically but may be in the future.
A reviewer will be assigned by the administrators to look at your PR and approve it or request changes before approval. Once the PR has been approved, the branch can be merged by clicking on the green "Merge" button. Typically, a reviewer will not merge the PR themselves, as you might want to make minor changes after the approval, such as fixing spelling or grammar. (However, major changes should not be made to a PR branch after it has been reviewed, as that might require a re-review.)
The main URL of the test website is:
Once your PR has been merged, the changes you have made will be deployed there automatically.
The #ivoa-web channel on the [https://ivoa.slack.com](IVOA Slack) can be used to ask questions related to site development.
You may alternately open a ticket in the issue tracker and add the "question" label. The developers of the site will attempt to answer your question on the issue page in a timely manner.