There are two ways to work on CircleCI docs locally: with Docker and with Ruby/Bundler.
- Install Docker for you platform: https://docs.docker.com/engine/installation/
- Clone the CircleCI docs repo:
git clone https://github.com/circleci/circleci-docs.git
- Download this file: https://circleci.com/docs/assets/app.bundle-576b5ac91166f5b87d5f6254b647c9182e3468eeea4717c8cdc7ff7304cac0c9.js
- Rename the file from Step 3 to
app.bundle.js
and save it in thejekyll/assets/js
directory. cd
into the directory where you cloned the docs- Run
docker-compose up
- The docs site will now be running on http://localhost:4000/docs/
Note: If you want to submit a pull request to update the docs, you'll need to make a fork of this repo and clone your version in step 2 above. Then when you push your changes to your fork you can submit a pull request to us.
If you already have a stable Ruby environment (currently Ruby 2.3.3) and feel comfortable installing dependencies, install Jekyll by following this guide.
Check out the Gemfile for the Ruby version we're currently using. We recommend RVM for managing multiple Ruby versions.
We also use a gem called HTMLProofer to test links, images, and HTML. The docs site will need a passing build to be deployed, so use HTMLProofer to test everything before you push changes to GitHub.
You're welcome to use Bundler to install these gems.
Our js assets are compiled by webpack and put into a place that the jekyll build can find them.
Anytime you are working on js be sure to run:
$ npm install
$ npm run webpack-watch
To get a local copy of our docs, run the following commands:
git clone https://github.com/circleci/circleci-docs.git
cd circleci-docs/jekyll
jekyll serve -Iw
Jekyll will build the site and start a web server, which can be viewed in your browser at http://localhost:4000/docs/. -w
tells Jekyll to watch for changes and rebuild, while -I
enables an incremental rebuild to keep things efficient.
For more info on how to use Jekyll, check out their docs.
The docs site includes Bootstrap 3 JS and CSS, so you'll have access to all of its reusable components.
All docs live in folders named after the version of CircleCI. The only two you need to worry about are jekyll/_cci1
and jekyll/_cci2
. These correspond to CircleCI Classic and CircleCI 2.0, respectively.
-
Create a branch and switch to it:
git checkout -b <branch-name
-
Add or modify Markdown files in these directories according to our style guide.
-
When you're happy with your changes, commit them with a message summarizing what you did:
git commit -am "commit message"
-
Push your branch up:
git push origin <branch-name>
New articles can be added to the jekyll/_cci2 directory in this repo.
When you make a new article, you'll need to add front matter. This contains metadata about the article you're writing and is required so everything works on our site.
Front matter for our docs will look something like:
---
layout: classic-docs
title: "Your Doc Title"
short-title: "Short Title"
categories: [category-slug]
order: 10
---
layout
and title
are the only required variables. layout
describes visual settings shared across our docs. title
will appear at the top of your article and appear in hypenated form for the URL.
The remaining variables (categories
, short-title
, and order
) are deprecated and no longer used in documentation. Navigation links to each article are manually added to category landing pages. If you're having trouble deciding where to put an article, a CircleCI docs lead can help.
Jekyll will automatically convert your article's title into a level one heading (#), so we recommend using level two (##), level three (###) and level four (####) headings when structuring your article.
If your article has more than three headings after the title, please use a table of contents. To add a table of contents, use the following reference name:
* TOC
{:toc}
This will create an unordered list for every heading level in your article (the * TOC
line will not display).
If you want to exclude a heading from a TOC, you can specify that with another reference name:
# Not in the TOC
{:.no_toc}
After you are finished with your changes, please follow our Contributing Guide to submit a pull request.
The Docker tag list for convenience images, located in ./jekyll/_cci2/circleci-images.md, is dynamically updated during a CircleCI build.
There's usually no need to touch this.
If you'd like to see an updated list generated locally however, you can do so by running ./scripts/pull-docker-image-tags.sh
from the root of this repo.
Note that you'll need the command-line tool jq installed.
Our API is handled in two possible places currently:
- Old version - This currently accessible via the CircleCI landing page > Developers Dropdown > "Api"
- New Version using Slate - A newer API guide, built with Slate
What is Slate?
Slate is a tool for generating API documentation. Slate works by having a user
clone or fork it's Github Repo, having the user fill in the API spec into a
index.html.md
file, and then generating the static documentation using Ruby
(via bundler
).
How do we use Slate?
We have cloned slate into our docs repo ("vendored" it) so that the whole
project is available under circleci-docs/src-api
. Because Slate is not a
library, it is required that we vendor it and use its respective build
steps to create our API documentation.
Making changes to the documentation
When it comes time to make changes to our API, start with the following:
- All changes to the API happen in
circleci-docs/src-api/source/
folder. - Our API documentation is broken up into several documents in the
source/includes
folder. For example, all API requests related toProjects
are found in thecircleci-docs/src-api/source/includes/_projects.md
file. - Within the
/source
folder, theindex.html.md
has anincludes
key in the front matter. The includes key gathers the separated files in theincludes
folder and merges them into a single file at build time. - Because Slate builds the entire API guide into a single html file, we can view the artifact file on CircleCI whenever a build is run.
The following is an example workflow to contribute to a document (from Github, no less):
- Navigate to the file you want to edit (example:
src-api/source/includes/_projects.md
) - Click the
edit
button on GitHub and make your changes. - Commit your changes and submit a PR.
- Go to the CircleCI web app, find the build for the latest commit for your PR
- Go to the
Artifacts
tab and navigate tocircleci-docs/api/index.html
to view the built file.
Local Development with Slate
- If you want to see your changes live before committing them,
cd
intosrc-api
and runbundle install
followed bybundle exec middleman server
. - You may need a specific version of Ruby for bundler to work (2.3.1).