OpenShift docs are getting modularized, starting from OpenShift 4.0. All existing content will be completely replaced with content that is based on user stories and complies with the modularization guidelines. All future content must both support a user story and be modular.
To contribute modularized content, you need to write a user story, create documentation modules to support the user story, and create an assembly for the story.
If you don’t want to write the modules yourself but have a content change, write a user story, provide details to support the story, and reach out to the OpenShift docs team.
If you have new content for OCP 4.0, it must be modularized before it is merged to the collection. Here is an overview of the active branches:
-
This builds both OCP 4.0 and OKD/Upstream content. Just like today, OKD content will be separated using ifdef statements in content and distro statements in the _topic_map.yml.
Only CCS submits and merges their PRs here until OCP 4.0 is released unless others are keen to submit content in modularized format.
-
master This builds legacy (existing), mostly non-user story based content. This branch will continue to update docs.okd.io (upstream) until we switch to 4.0 with the enterprise-4.0 branch.
Please continue to submit your PRs to this branch and specify if it is for 3.11 and/or 4.0. If the submitted PR is for the 3.11 branch, CCS merges with follow up edits in 3.11. CCS then creates user stories for its inclusion in enterprise-4.0 branch.
-
enterprise-3.11 This branch contains content for the 3.11 branch and the last branch that contains content that is not completely modularized.
This may contain modularized content based on user stories for content for completely new features.
Instead of a template, we have a series of questions for you to answer to create the user story. Follow the same steps if you are writing the modules yourself or if you plan to work with the docs team.
The basic format of a user story is:
As a <type of user>, I want to <goal state> because <reason behind the goal>.
For example, "As a cluster administrator, I want to enable an Auto Scaling group to manage my OpenShift Enterprise cluster deployed on AWS because I want my node count to scale based on application demand."
Use the following questions to guide you in providing the context for your user story and the necessary technical details to start a draft. You don’t have to answer all of these questions, only the ones that make sense to your particular user story.
-
What is the feature being developed? What does it do?
-
How does it work?
-
Are there any configuration files/settings/parameters being added or modified? Are any new commands being added or modified?
-
What tools or software does the docs team need to test how this feature works? Does the docs team need to update any installed software?
-
Are there any existing blogs, Wiki posts, Kbase articles, or Bzs involving this feature? Or any other existing information that may help to understand this feature?
-
Who is the intended audience for this feature? If it’s for Enterprise, does it apply to developers, admins, or both?
-
Why is it important for our users? Why would they want to use this feature? How does it benefit them?
-
How will the customer use it? Is there a use case?
-
How will the customer interact with this feature? Client tools? Web console? REST API?
-
Is this feature being developed for Online? Enterprise? Dedicated? OKD? All?
-
Will this feature be rolled back to previous versions?
-
If it’s for Online, what type of plan do users need to use this feature?
-
Is it user-facing, or more behind-the-scenes admin stuff?
-
What tools or software does the docs team need to test how this feature works?
The full guidelines for writing modules are in the Customer Content Services (CCS) modularization guide.
The main concepts of writing in modules are:
-
Each assembly contains the information required for a user to achieve a single goal.
-
Assemblies contain primarily
include
statements, which are references to smaller, targeted module files. -
Modules can contain conceptual information, reference information, or steps, but not a combination of the types.
For example, a simple assembly might contain the following three modules:
-
A concept module that contains background information about the feature that the user will configure
-
A reference module that contains an annotated sample yaml file that the user needs to modify
-
A procedure module that contains the prerequisites that the user needs to complete before they start configuring and steps that the user takes to complete the configuration.
The enterprise-4.0
branch contains sample assemblies that explain how to
get started with modular documentation for OpenShift and that serve as
references for including modules in assemblies. The
Modular Docs OpenShift conventions
assembly contains the
Modular docs OpenShift conventions
reference module, and the
Getting started with modular docs on OpenShift
assembly contains the
Creating your first content
procedure module.