Skip to content

Latest commit

 

History

History
255 lines (167 loc) · 11.5 KB

README.md

File metadata and controls

255 lines (167 loc) · 11.5 KB

Contributor's guide

When you contribute to the docs, it helps to know how things work.

Table of Contents

Important directories

For writers, these are the most important directories:

  • docs/sources is where the docs live.
  • docs/sources/VERSION/shared has Markdown files that can be reused across multiple pages by using the shared shortcode.
  • src/data/markdown contains the Markdown files for the legacy version of the docs, available at https://k6.io/docs. You do not need to update these files if you're making changes to the current or next version of the docs, available at https://grafana.com/docs/k6/latest/.

Build locally

Before you begin

To build the k6 docs in your machine, you'll need:

If you're using Docker, make sure you have the Docker Desktop application running.

Build and preview

Clone the repository to your machine:

git clone https://github.com/grafana/k6-docs.git

Run npm start:

npm start

You should see an output similar to this when the site finishes building:

View documentation locally:
                             http://localhost:3002/docs/k6/

                                                           Press Ctrl+C to stop the server

Go to http://localhost:3002/docs/k6/, and you should be able to see a preview of the docs.

Refer to Writers' Toolkit, Build and review documentation for more details about how to build the docs, and tools you can use such as Vale.

Write

You can find the Markdown file for the docs in the docs/sources folder. In that folder you'll find:

  • A next folder, which represents the docs for the next major release of k6.
  • Multiple version folders (for example, v0.47.x), which represents the docs for that specific version of k6.

Depending on the type of update you need to make, you'll want to make updates to different folders.

Where to make updates

Updates and fixes to the latest version of k6

If you're making any updates or fixes that apply to the latest version of k6, you'll need to:

  • Update the Markdown files in the docs/sources/k6/next folder.
  • Update the Markdown files in the docs/sources/k6/v{LATEST_VERSION} folder.

This is to make sure that any changes you make are also brought over to the next major release version of k6.

If your update or fix also applies to previous versions of k6, use the apply-patch script to port your changes to the latest version, and two previous versions.

Updates and fixes to the next major release of k6

If you're making any updates or fixes that only apply to the next major release of k6, you'll need to:

  • Update the Markdown files in the docs/sources/k6/next folder.

Once you make any changes and open a PR, and that PR is reviewed, you can merge it without having to worry about those changes showing up in the latest version of the docs. The latest version will always display the highest numbered version folder of the docs.

Use the apply-patch script

You can use the apply-patch script to port changes from one version folder to another. This is especially helpful if you're making updates or fixes to the latest version of k6, and want to make sure they're also reflected in the next version folder.

To use the script, make sure you're in the root of the k6-docs folder and run:

scripts/apply-patch <COMMIT> <SOURCE> <DESTINATION>

For example, if you'd like to apply the changes from your last commit, from the docs/sources/k6/next folder to the docs/sources/k6/v0.47.x, you can run:

scripts/apply-patch HEAD~ docs/sources/k6/next docs/sources/k6/v0.47.x

Or if you'd like to apply the changes from your previous three commits, you can run:

scripts/apply-patch HEAD~3 docs/sources/k6/next docs/sources/k6/v0.47.x

Style guides

k6 follows the style prescribed in the Grafana Writers' Toolkit, which itself inherits most of its rules from the Google developer documentation style guide.

Shortcodes

We've also added a number of writing enhancements, like admonitions, tabbed code fences, and collapsible sections. For all syntax and components you can use, checkout the Writers' Toolkit, Shortcodes.

Refer to Writers' Toolkit, Write documentation for more details about how to write new topics, how to use shortcodes, how to add images, and more.

Code snippets and ESLint

We use ESLint in the repository to validate code snippets in Markdown files. It checks for things such as valid JavaScript syntax, or that imports are defined.

When writing tutorials, it's common to include code snippets that only contain a few lines, and might not necessarily have all necessary imports or variable declarations. For example, if you try to include this code snippet:

```javascript
export default async function () {
  const browser = chromium.launch({ headless: false });
  const page = browser.newPage();
}
```

You might see the following error when trying to commit the file:

/Users/USERNAME/path/to/file/_index.md
  12:19  error  'chromium' is not defined  no-undef

In case having a short snippet makes sense for your tutorial, you can disable ESLint for a code snippet by using the eslint-skip rule:

<!-- eslint-skip -->

```javascript
export default async function () {
  const browser = chromium.launch({ headless: false });
  const page = browser.newPage();
}
```

Code snippets evaluation

In addition to linting code snippets, we also run the snippets using k6 OSS. This is done automatically on PRs, only for Markdown files that have been changed in the docs/sources/next directory when compared to main. See the scripts/md-k6.py script for details on how this works internally.

Code snippets are run using the -w k6 OSS flag. If the code snippet causes k6 to exit with a nonzero status, then the script (and, therefore, the workflow) will fail. If any error is logged by k6, for example, because an exception was raised, this will also fail the execution.

You can control the behaviour of md-k6.py via magic md-k6 HTML comments placed above the code snippets. The format is the following:

<!-- md-k6:opt1,opt2,... -->

That is, md-k6: followed by a comma-separated list of options.

skip Option

The skip option will cause md-k6.py to ignore the code snippet completely (i.e. <!-- md-k6:skip -->). This is useful for code snippets that only showcase a very specific aspect of k6 scripting and do not contain an actually fully working script.

Tip

You can combine both md-k6.py and ESLint skip directives by placing the md-k6.py directive first:

<!-- md-k6:skip -->
<!-- eslint-skip -->

```javascript
export default async function () {
  const browser = chromium.launch({ headless: false });
  const page = browser.newPage();
}
```

skipall Option

The skipall option will cause md-k6.py to ignore the entire Markdown file. Note that this option is special: it can be specified anywhere in the file, for example, at the very end. It also does not need to be placed above a code snippet. In order for this option to be read correctly, it must be specified alone, with no other additional options in the same HTML comment tag.

nofail Option

The nofail option will allow the k6 code snippet to freely log errors without failing. However, if k6 exits with a nonzero status, the md-k6.py script will still fail. For this reason, using nofail will provide slightly better coverage than simply using skip on a code snippet.

env.X=Y Option

Any option taking the form of env.KEY=VALUE will be parsed by the md-k6.py script, and the corresponding KEY=VALUE pairing will be added to the environment variables when executing the k6 code snippet. Note that for KEY and VALUE the following characters are not allowed: ,, -, and $.

fixedscenarios Option

By default, all code snippets are run with whatever scenarios they define via their options variable. However, some command line arguments to md-k6.py can change this, for example: -d/--duration. This option replaces the scenarios for all code snippets run with a scenario lasting only a specific amount of time. However, this behavior may break some scripts, for this reason, it is possible to specify the fixedscenarios option to ensure that the code snippet scenarios will be used as they appear in the Markdown file.

Usage

To run the md-k6.py script locally, invoke it using Python. For example:

python3 scripts/md-k6.py docs/sources/k6/next/examples/functional-testing.md

You can also read the usage information:

python3 scripts/md-k6.py --help

Deploy

Once a PR is merged to the main branch, if there are any changes made to the docs/sources folder, the GitHub Action publish-technical-documentation.yml will sync the changes with the grafana/website repository, and the changes will be deployed to production soon after.

Create a new release

⚠️ Versions

Versions follow the same major numbers as github.com/grafana/k6.

When a new major version of k6 is released, you need to create a new folder for it in the docs/sources folder.

The process for creating a new release should be:

  • Review any open PRs that relate to the next major release, and merge them if they have been reviewed and approved.
  • git pull the latest version of the k6-docs repository.
  • In the docs/sources folder:
    • Duplicate the next folder.
    • Rename the next copy folder to match the next major release version. For example, if the next release is v0.48, the folder should be renamed to v0.48.x.
  • Build the docs locally to check that the latest version matches the new version folder.
  • Commit and push your changes.

Once your changes are automatically deployed, you should be able to see the new version live by going to https://grafana.com/docs/k6/latest/.