This guide describes how to use the aCoRNs release notes generator to create, maintain, and publish release notes from a combination of manually written documentation and generated ticket descriptions.
1. Installing aCoRNs
Install the aCoRNs release notes generator on your system, so that you can run it locally.
-
On Fedora, CentOS Stream, or RHEL, use the Copr repository.
The repository is only available for actively supported releases of the operating system. If you are using a legacy, unsupported release, you can no longer install or update the package. DNF reports the following error:
Error: This repository does not have any builds yet so you cannot enable it now.
If this is the case, please upgrade your system.
-
Enable the repository:
# dnf copr enable mmuehlfeldrh/acorns
-
Install the
acorns
package:# dnf install acorns
-
-
On any system that has the Docker or Podman container platform, you can use aCoRNs as a container.
On Fedora, RHEL, and CentOS, replace
docker
withpodman
in the following commands.-
Download the image:
$ docker pull quay.io/redhat-documentation/acorns
If this image is unavailable, you can use a backup image at docker.io/msuchane/acorns:latest
. -
Configure a command alias. Save this line in your shell configuration file:
alias acorns="docker run -it -e BZ_API_KEY -e JIRA_API_KEY -v .:/mnt/acorns:Z redhat-documentation/acorns acorns"
-
With the Bash shell, save the line at the end of
~/.bashrc
. -
With the ZSH shell, save the line at the end of
~/.zshrc
. -
With the Fish shell, save the alias using the following command:
$ alias --save acorns="docker run -it -e BZ_API_KEY -e JIRA_API_KEY -v .:/mnt/acorns:Z redhat-documentation/acorns acorns"
-
-
Open a new terminal to reload the shell configuration.
-
-
On macOS, you can use the Homebrew package manager:
This repository is currently experimental. Please report any problems with usage or installation as issues in the acorns
repository.-
Install the Homebrew package manager as described on https://brew.sh/.
-
Install
acorns
:$ brew install redhat-documentation/repo/acorns
-
-
On any system, including different Linux distributions and macOS, you can build aCoRNs from source:
-
Install the Rust toolchain se described at https://rustup.rs/.
-
Build and install aCoRNs from its Git repository:
$ cargo install --git https://github.com/redhat-documentation/acorns
If the build fails due to a missing dependency, install the missing dependency on your system and start the build again.
-
-
Try running
acorns
:$ acorns --version
2. Creating a new release notes project
Populate a directory with sample configuration files that aCoRNs uses to generate release notes.
-
You have installed aCoRNs.
-
Create all configuration files that are necessary to generate release notes using aCoRNs:
$ acorns init path-to-directory
Replace
path-to-directory
with the directory where you want to store your release notes configuration. -
Examine the newly populated directory.
See the
README.adoc
file in the directory for a description of the directory layout.
3. Enabling access to your ticket trackers
The default, sample project configuration tries to access ticket trackers that do not exist. Configure your release notes project to connect with trackers that host your tickets.
For the purpose of this document, a ticket tracker is either Bugzilla or Jira. In the future, aCoRNs might add support for additional trackers or remove support for current ones.
3.1. Configuring trackers
To enable access to your ticket trackers, enter the required settings in the trackers.yaml
configuration file.
-
You have installed aCoRNs.
-
You have initialized a directory with sample release notes project configuration.
-
In your release notes project, open the
acorns/trackers.yaml
file in an editor. -
Configure access to your Bugzilla and Jira instance.
Currently, aCoRNs requires configuration for both trackers. If you are using only one, you can enter empty, invalid values for the other, unused trackers, such as an empty list ( []
) or the default values. aCoRNs only loads the configuration for a particular tracker when your project contains tickets that come from the tracker. Otherwise, aCoRNs ignores the tracker configuration.-
In the
bugzilla
entry, fill out the following, required fields for Bugzilla:bugzilla: host: "https://bugzilla.host.org" (1) fields: doc_type: (2) - "cf_doc_type" doc_text: (3) - "cf_release_notes" doc_text_status: (4) - "requires_doc_text"
1 The base URL to your Bugzilla instance. 2 The ID of the Doc Type field, which is probably a drop-down menu of values. 3 The ID of the Doc Text field, which is a text box that contains your release note. 4 The ID of the flag that describes the status of the release note. -
In the
jira
entry, fill out the following, required fields for Jira:jira: host: "https://jira.host.org" (1) fields: doc_type: (2) - "customfield_12345678" doc_text: (3) - "customfield_23456789" doc_text_status: (4) - "customfield_34567890" docs_contact: (5) - "customfield_45678901"
1 The base URL to your Jira instance. 2 The ID of the field that lists the type of the release note. It is a drop-down menu of values. 3 The ID of the field that contains your release note. It is a text box. 4 The ID of the field that lists the status of the release note. It is a drop-down menu of values. 5 The ID of the field that contains the docs contact for this release note. It is a Jira user entry.
-
-
Add tickets to your release notes project.
-
Build the release notes.
3.2. Finding IDs of tracker fields
To access your Bugzilla and Jira instance, you must know the internal IDs that the tracker gives to your documentation fields. The following procedure identifies the field IDs.
-
You have logged into your ticket tracker.
-
Open a ticket that has your documentation fields.
-
In Bugzilla, click Show advanced fields if you cannot see your documentation fields.
-
Right-click the name of a documentation field, such as the Doc Type or Release note text field.
-
In the right-click menu, select Inspect.
-
Your web browser displays a toolbar that lists the elements of the web page, and highlights the element that represents the selected documentation field.
-
Find the field ID in the
label
tag:-
With Bugzilla:
<label for="cf_release_notes">
-
With Jira:
<label for="customfield_12345678">
-
3.3. Required and optional fields in tracker configuration
The lists below describe mandatory and optional fields for the acorns/trackers.yaml
configuration file.
bugzilla:
host: "https://bugzilla.host.org"
fields:
# Required
doc_type:
- "cf_doc_type"
doc_text:
- "cf_release_notes"
doc_text_status:
- "requires_doc_text"
# Optional
docs_contact:
- "cf_my_docs_contact"
target_release:
- "cf_internal_target_release"
subsystems:
- "pool"
The following fields are required:
host
-
The base URL to your Bugzilla instance.
doc_type
-
The ID of the Doc Type field, which is probably a drop-down menu of values.
doc_text
-
The ID of the Doc Text field, which is a text box that contains your release note.
doc_text_status
-
The ID of the flag that describes the status of the release note.
The following fields are optional:
docs_contact
-
By default, aCoRNs uses the standard Bugzilla Docs Contact field. You can override it with a custom field.
target_release
-
By default, aCoRNs uses the standard Bugzilla Target Release field. You can override it with a custom field.
subsystems
-
This field is required only if you configure your templates to organize using the subsystem.
Currently, this field expects an Agile Pool menu.
jira:
host: "https://jira.host.org"
private_projects:
- "SECRETPROJECT"
- "MYPROJECT"
fields:
# Required
doc_type:
- "customfield_12345678"
doc_text:
- "customfield_23456789"
doc_text_status:
- "customfield_34567890"
docs_contact:
- "customfield_45678901"
# Optional
target_release:
- "customfield_56789012"
subsystems:
- "customfield_67890123"
The following fields are required:
host
-
The base URL to your Jira instance.
doc_type
-
The ID of the field that lists the type of the release note. It is a drop-down menu of values.
doc_text
-
The ID of the field that contains your release note. It is a text box.
doc_text_status
-
The ID of the field that lists the status of the release note. It is a drop-down menu of values.
The following fields are optional:
private_projects
-
If you set certain Jira projects as private, all ticket IDs in these projects will be non-clickable, even if the ticket itself is public in Jira.
target_release
-
By default, aCoRNs uses the standard Jira Fix Version/s field. You can override it with a custom field.
subsystems
-
This field is required only if you configure your templates to organize using the subsystem. It is a drop-down menu of values.
Settings in the fields
entry always accept a list of IDs that aCoRNs tries out successively.
For example, if you use Jira tickets from three different projects that each set a different doc text field, you can list all field IDs:
jira:
host: "https://jira.host.org"
fields:
# All possible IDs
doc_text:
- "customfield_23456789"
- "customfield_34567890"
- "customfield_45678901"
3.4. Obtaining API keys to ticket trackers
To log into your ticket trackers, aCoRNs needs your API keys. If you do not have or do not know any API keys, you can generate them.
-
You have logged into your Jira and Bugzilla accounts.
-
Your Jira instance enables the Personal Access Tokens plug-in (
com.atlassian.pats
).
-
Generate a Jira API key:
-
Click your profile picture in the upper-right corner and select Profile.
-
Go to the Personal Access Tokens tab.
-
Click Create token.
-
In the Token Name field, enter a name for your new API key.
-
Under Expiry date, set for how long this API key stays valid.
-
Click Create.
-
Note down the API key displayed at the top of the page.
-
-
Generate a Bugzilla API key:
-
Click your name in the upper-right corner and select Preferences.
-
Click API Keys.
-
Under the New API key heading, check the checkbox and enter a name for your new API key.
-
Click Submit Changes.
-
Note down the API key displayed at the top of the page.
-
-
Save your API keys in a password manager.
You cannot recover the API keys from Jira or Bugzilla. You can only generate new ones and revoke existing ones.
4. Adding tickets to your project
The default, sample project configuration lists tickets that do not exist. Populate your release notes with existing tickets that contain documentation.
4.1. Specifying tickets
To add tickets to your project, specify them in the tickets.yaml
configuration file.
-
You have installed aCoRNs.
-
You have initialized a directory with sample release notes project configuration.
-
You have configured tracker access.
-
In your release notes project, open the
acorns/tickets.yaml
file in an editor. -
Remove or comment out the sample configuration, which points to non-existent tickets.
-
Add several tickets that contain release note documentation in the following format.
To test a new release notes project, it is recommended to add tickets that cover all possible doc types. -
Bugzilla tickets are identified by their ID number:
- [BZ, key: 1234567] - [BZ, key: 2345678]
-
Jira tickets are identified by their key, which consists of the project name and a number:
- [Jira, key: PROJECTA-123456] - [Jira, key: PROJECTB-234567]
-
-
For additional ways to specify tickets, such as search or overrides, see Alternative methods to specify tickets.
4.2. Alternative methods to specify tickets
The acorns/tickets.yaml
configuration file recognizes several kinds of syntax to identify tickets that belong into your release notes document.
Each entry in the acorns/tickets.yaml
configuration file follows this structure:
-
The
-
character to start a list item. -
A pair of square brackets (
[ ]
) to contain the entry. -
A keyword that identifies the ticket tracker, followed by a comma. The following values are supported:
-
Jira
-
Bugzilla
-
BZ
as a shorthand forBugzilla
-
-
A keyword that specifies the method to retrieve tickets. The following values are supported:
-
key
to select a single ticket, followed by the ID or key of the ticket. -
search
to select all tickets that match a search, followed by a string in the format that the ticket tracker recognizes as a search query.
-
-
Optional: The
overrides
keyword, which enables you to manually override the value of the ticket’s doc type, components, or subsystems. -
Optional: The
references
keyword, which enables you to attach multiple additional ticket IDs to this release note.
- [Jira, key: PROJECTA-123456]
- [Jira, key: PROJECTB-234567]
- [Jira, key: PROJECTC-345678]
- [BZ, key: 1234567]
- [BZ, key: 2345678]
- [BZ, search: 'bug_status=VERIFIED&bug_status=CLOSED&product=Our Container Platform&target_release=1.23.0']
- [BZ, search: '"f1=blocked&o1=equals&v1=12345678"']
- [Jira, search: 'project="CentOS Stream" AND priority=Blocker']
- [Jira, search: 'filter = 12345678']
- [Jira, search: 'issue in childIssuesOf("PROJECT-123456")']
- [Jira, search: 'issue in linkedIssues("PROJECT-123456")']
- [BZ, key: 1234567, { overrides: {subsystems: [sst_different]} }]
- [Jira, search: 'project="CentOS Stream" AND priority=Blocker', { overrides: {doc_type: "Known Issue"} }]
- [BZ, key: 1234567, { references: [[BZ, key: 2345678], [Jira, key: PROJECTC-345678]] }]
-
For an explanation of the
overrides
keyword, see Organizing a ticket manually. -
For an explanation of the
references
keyword, see Referring to another ticket from a release note.
5. Building release notes
Build a release notes project in a local directory that contains your aCoRNs configuration files.
-
You have installed aCoRNs.
-
You have configured access to your tickets trackers.
-
You have added tickets to your release notes project configuration.
-
Navigate to your release notes project:
$ cd my-release-notes
-
Set your API keys for Bugzilla and Jira:
$ export BZ_API_KEY=my-bugzilla-key $ export JIRA_API_KEY=my-jira-key
If you are using a shell that is not compatible with the Bourne shell syntax, adjust the commands.
For example, with the Fish shell:
$ set -x BZ_API_KEY=my-bugzilla-key $ set -x JIRA_API_KEY my-jira-key
-
Generate release notes:
$ acorns build
-
Compile the external and internal version of the AsciiDoc document:
$ asciidoctor --safe -vn main-external.adoc $ asciidoctor --safe -vn main-internal.adoc
-
Open the
main-external.html
andmain-internal.html
files in a web browser to preview the document.In the GNOME desktop environment, you can use the following commands:
$ gio open main-external.html $ gio open main-internal.html
6. Organizing tickets in your project using templates
The default, sample project configuration organizes your release notes based on their doc type. You can configure the templates in your release notes project to organize release notes using other criteria, and edit the content of the generated files.
6.1. Structuring templates
To structure your templates, edit the settings in the templates.yaml
configuration file.
-
You have installed aCoRNs.
-
You have configured access to your tickets trackers.
-
You have added tickets to your release notes project configuration.
-
In your release notes project, open the
acorns/templates.yaml
file in an editor. -
Edit the templates to organize your release notes in the rendered document:
-
In a relatively small project with few release notes, you might want to continue organizing just by one property of release notes, such as just by doc type, just by component, or just by subsystem.
In this case, keep the
chapters
entry of the configuration file and edit the rules in it. -
In a relatively large project with many release notes, you might want to further divide your release notes by several properties, which results in several levels of nested sections. For example, you can organize by doc type at the base level and further divide each doc type chapter into subsections based on components.
In this case:
-
Add the
subsections
entry at the top of the configuration file, where you define the deeper levels of nested organization. This entry is described in Available options to organize release notes. -
Edit the rules in the
chapters
entry of the configuration file. Include the organizing rules that you defined in thesubsections
entry. Use the YaML anchors syntax to include previously defined rules.
-
-
-
Rebuild your release notes and examine the generated files in the
acorns/generated/internal/
directory. -
Include the generated files in your
main-template.adoc
file.
-
Build an HTML preview of the internal document:
# asciidoctor --safe -vn internal.adoc
-
Open the preview and check the document structure.
-
For a complete description of the syntax in the
templates.yaml
file, see Available options to organize release notes. -
For the process that creates AsciiDoc files from the template configuration, see Documentation files generated from templates.
6.2. Available options to organize release notes
The acorns/templates.yaml
configuration file recognizes several options and properties to organize release notes in your document.
The configuration file always requires the chapters
entry, which defines the initial, base organization level.
This level is called chapters
because it usually generates files that you include directly from your main-template.adoc
file. These generated files can either be reference modules or assemblies, depending on their content.
The chapters
entry has the following syntax:
chapters:
- title: "Bug fixes" (1)
filter: (2)
doc_type: (3)
- "Bug Fix" (4)
- title: "New features"
intro_abstract: "This part describes new features and major enhancements introduced in {Product}." (5)
filter:
doc_type:
- "Enhancement"
- "Feature" (6)
subsections: (7)
- *installer
- *networking
- *storage
- *virtualization
1 | The title (heading) of the generated AsciiDoc file. | ||
2 | Settings that define which tickets appear in this chapter or subsection. | ||
3 | The filter settings accept the following properties to select tickets:
|
||
4 | This chapter lists all tickets that have the Bug Fix doc type. |
||
5 | Optional: An abstract (introduction) of this chapter. The text appears directly under the title and can contain arbitrary AsciiDoc syntax, including attributes. | ||
6 | Optional: This chapter lists all tickets that have either the Enhancement or Feature doc type. You can group multiple values together and they do not have to be related. |
||
7 | Optional: To enable a deeper level of nesting, this chapter includes subsections with different organizing settings. This chapter starts with tickets of the Enhancement and Feature doc types, and divides them further by rules defined in the listed subsections.
The asterisk (
|
If you enable deeper levels of organization by specifying the subsections
(or sections
) option in chapters
, you must add the subsections
(or sections
) entry at the top of the templates.yaml
file.
The subsections
entry defines rules organizing at levels that you do not include yourself in the main-template.adoc
file, but rather, the base-level chapters include these generated files.
The subsections
entry has the following syntax, which is identical to the chapters
syntax, except for the addition of YaML anchors:
subsections:
- &networking (1)
title: "Networking" (2)
filter: (3)
subsystem:
- 'sst_networking' (4)
- &installer
title: "Installer and image creation"
intro_abstract: "Installing {Product} on physical and virtual systems."
filter:
subsystem:
- 'ssg_front_door'
- 'sst_front_door'
- 'sst_installer'
- 'sst_image_builder'
- 'sst_composer' (5)
1 | The ampersand (& ) character is the YaML anchor syntax that names this section, so that you can later reuse it elsewhere in the configuration file by referring to this name. |
2 | The title (heading) of the generated AsciiDoc file. |
3 | A filter that further limits the tickets that come from the parent chapter. |
4 | This section only lists tickets within the chapter that belong to the sst_networking subsystem. |
5 | This section only lists tickets within the chapter that belong to any of the listed subsystems. |
chapters:
- title: "New features"
intro_abstract: "This part describes new features and major enhancements introduced in {Product}."
filter:
doc_type:
- "Enhancement"
- "Release Note"
- "Feature"
- title: "Bug fixes"
intro_abstract: "This part describes bugs fixed in {Product} that have a significant impact on users."
filter:
doc_type:
- "Bug Fix"
- title: "Technology Previews"
intro_abstract: |
This part provides a list of all Technology Previews available in {Product}.
For information on the scope of support for Technology Preview features, see link:https://example.org/[Example]. (1)
filter:
doc_type:
- "Technology Preview"
- title: "Deprecated functionality"
intro_abstract: |
This part provides an overview of functionality that has been _deprecated_ in {Product}.
Deprecated functionality will likely not be supported in future major releases of this product and is not recommended for new deployments.
filter:
doc_type:
- "Deprecated Functionality"
- title: "Known issues"
intro_abstract: "This part describes known issues in {Product}."
filter:
doc_type:
- "Known Issue"
1 | The introduction can span several paragraphs. Use the | YaML syntax to start a multiline string, with blank lines to separate paragraphs. |
subsections:
- &web_console
title: "Web console"
filter:
component:
- "Management Console"
- &oc
title: "OpenShift CLI (oc)"
filter:
component:
- "oc"
- &images
title: "Images"
filter:
component:
- "Image Registry"
- &olm
title: "Operator"
filter:
component:
- "OLM"
- "Operator SDK"
chapters:
- title: "New features"
intro_abstract: "This part describes new features and major enhancements introduced in {Product}."
filter:
doc_type:
- "Enhancement"
- "Release Note"
- "Feature"
subsections: (1)
- *web_console
- *oc
- *images
- *olm
- title: "Bug fixes"
intro_abstract: "This part describes bugs fixed in {Product} that have a significant impact on users."
filter:
doc_type:
- "Bug Fix"
subsections:
- *web_console
- *oc
- *images
- *olm
- title: "Technology Previews"
intro_abstract: |
This part provides a list of all Technology Previews available in {Product}.
For information on the scope of support for Technology Preview features, see link:https://example.org/[Example].
filter:
doc_type:
- "Technology Preview"
subsections:
- *web_console
- *oc
- *images
- *olm
- title: "Deprecated functionality"
intro_abstract: |
This part provides an overview of functionality that has been _deprecated_ in {Product}.
Deprecated functionality will likely not be supported in future major releases of this product and is not recommended for new deployments.
filter:
doc_type:
- "Deprecated Functionality"
subsections:
- *web_console
- *oc
- *images
- *olm
- title: "Known issues" (2)
intro_abstract: "This part describes known issues in {Product}."
filter:
doc_type:
- "Known Issue"
1 | You must repeat the subsections list in each chapter configuration that you want to subdivide into deeper organizing levels. |
2 | This chapter does not list any subsections. As a result, all tickets in this chapter will appear together in the same chapter, with no further division into subsections. |
6.3. Organizing a ticket manually
aCoRNs organizes your release notes based on the ticket properties as defined in templates.yaml
. If a release note appears in the wrong section, but you cannot edit the ticket itself, you can override certain ticket properties in the tickets.yaml
file.
-
You have added tickets to your release notes project configuration.
-
You have defined release note templates.
-
Find the line that defines the ticket in
tickets.yaml
.Example 7. A ticket without overrides- [Jira, key: PROJECT-1234]
-
Add an override to adjust the release note organization:
Example 8. A ticket with an override- [Jira, key: PROJECT-1234, { overrides: {components: [CustomComponent]} }]
In the
overrides
block, you can use the following elements to override selected ticket properties:components: [Component1, Component2]
-
Set custom components for this ticket.
doc_type: Type
-
Set a custom doc type for this ticket.
subsystems: [SST1, SST2]
-
Set custom subsystems for this ticket.
-
Build an HTML preview of the internal document:
# asciidoctor --safe -vn internal.adoc
-
Open the preview and check where the release note appears.
6.4. Referring to another ticket from a release note
Every release note ends with a reference to the ticket that it comes from. You can extend this reference to also include other, related tickets. In the release note body, you can also refer to other release notes within the document.
-
You have added tickets to your release notes project configuration.
-
To refer to additional tickets at the end of the release note:
-
Find the line that defines the ticket in
tickets.yaml
.Example 9. A ticket without references- [Jira, key: PROJECT-1234]
-
Add references to other tickets.
Example 10. A ticket with references- [Jira, key: PROJECT-1234, { references: [[BZ, key: 123456], [Jira, key: PROJECT-2345]] }]
The
references
block is a list that specifies tickets using the same syntax as the main list intickets.yaml
.
-
-
To refer to another release note within the document, use the standard AsciiDoc
xref
syntax in the release note body.You can refer to any release note using an ID that corresponds to its ticket tracker and ticket key, separated by a dash. For example:
Example 11. References to release notesSee xref:BZ-123456[] and xref:Jira-PROJECT-1234[].
6.5. Documentation files generated from templates
Every chapter and section defined in the templates.yaml
file attempts to generate a matching AsciiDoc file. The generated file can either be a reference module or an assembly, depending on its content. The following rules decide the type and name of the generated file:
-
If this chapter or section includes no other
subsections
definitions, it generates a reference module. The file name of the module is:ref_lowercase-title-with-certain-replacements.adoc
-
If this chapter or section does include additional
subsections
definitions, it generates an assembly file, which then includes other modules or assemblies in the same directory. The file name of the assembly is:assembly_lowercase-title-with-certain-replacements.adoc
-
If a section is included from another chapter or a section, its file name lists the complete include path:
ref_title-of-section-title-of-its-including-parent.adoc
-
If no tickets in your project match the
filter
rules defined in this chapter or section, it does not generate any file.Top-level chapters are an exception to this rule. These chapters are generated even if they are empty of release notes, and in that case, they end up being completely empty files. This is a feature that ensures that include directives do not break in your main AsciiDoc file.
For example:
-
A Known issues chapter uses a filter that looks for tickets with the
Known Issue
doc type. However, none of your tickets in this project is aKnown Issue
. As a result, theassembly_known-issues.adoc
file is generated as empty. -
A chapter includes subsections that look for three specific components. However, none of your tickets belong to these components. As a result, the section modules are not generated, and the chapter assembly file is generated empty.
-
A chapter matches several tickets, the doc text status of all the tickets is incomplete. As a result, the file is generated for the
internal
version of the document with the release note content, but in theexternal
version, it is an empty file.
-
7. Adding an explanatory footnote to private tickets
Public ticket IDs contain a clickable link to the ticket. Private ticket IDs are non-clickable. If this is confusing to the readers, you can automatically generate a footnote next to private ticket IDs that explains why the ticket link is missing.
-
Prepare the text that you want to add to every private ticket ID as a footnote. For example:
This ticket is private.
-
In your release notes project, enter a footnote with the
PrivateTicketFootnote
ID in a manually written AsciiDoc file.The footnote must appear before you include the first file generated by aCoRNs, such as near the book introduction or at the start of the main file. This requirement is caused by a technical limitation in the deprecated
footnoteref
macro.You can store the footnote text in a separate attribute, so that it is more convenient to edit:
Example 12. Placement of the footnote in main-template.adoc:private-footnote-text: This ticket is private. = Release notes for {Product} {Version} This is the abstract paragraph. Release notes include links to access the original tracking tickets. Private tickets have no links and instead feature the following footnote{blank}footnoteref:[PrivateTicketFootnote,{private-footnote-text}]. <Include your modules here.>
-
Build the release notes project.
-
Open a preview.
-
Compare the IDs of public and private tickets. Verify that all private tickets feature the footnote.
For example:
-
Bugzilla:2216257[1]
-
If you want to hide all links to certain Jira projects and set them as private, see
private_projects
in Required and optional fields in tracker configuration.
8. Publishing previous releases in one continuous document
As a release notes maintainer, you can publish several releases or all release history in one document. Only the latest release is actively generated by acorns
, while the previous releases are archived as manual content. You can see an example of a similar setup in the RHEL 8.2 release notes.
-
You have a working
acorns
configuration in a Git repository, later called the source repository. -
A CI/CD pipeline runs
acorns
and saves the generated content in a separate, generated repository.If you do not use this workflow, you can still archive previous releases in one document, but the procedure is slightly different.
-
Generate your release notes for the current release as usual.
-
When the current release is published and done, you can archive it.
-
Open your generated RN repository.
-
Navigate to the
external
branch of the current release. -
Download the latest generated files.
-
In your source directory, create a new directory under the
manual-content/
directory. Name it such that it refers to the release that you are archiving: for example,manual-content/RHOSO-18.0-Beta/
. -
Move all the downloaded generated files into the newly created directory in your source repository.
-
In the same directory, create a
main.adoc
assembly. Set a title that refers to the archived version, such as RHOSO 18.0 Beta. -
In the assembly, include all the downloaded generated files.
Because you are including files in the same directory, specify only the file names with no directory path in the include directives.
-
Include the new assembly from your master file, such as the
master_template.adoc
file. For example:include::manual-content/RHOSO-18.0-Beta/main.adoc[leveloffset=+1]
-
You now have a RHOSO 18.0 Beta chapter in your RN document that includes all release notes for that specific release, saved as static, manual content that originated from the generated repository.
-
As
acorns
regenerates new release notes, they work towards the following release. In your master file, they are included from theacorns/generated/
directory, until you want to archive this release as a another static assembly. -
Optional: If you want your current, actively generated release to also appear in a separate chapter of the document:
-
Create a new assembly with a title appropriate to the current release.
-
Move the include directives that refer to
acorns/generated/
from your master file to the new assembly. -
Include the new assembly in your master file.
-
9. Differences between aCoRNs and CoRN 3
aCoRNs is a successor to the previous CoRN release notes generator, version 3. If you are migrating from CoRN 3 to aCoRNs, compare the different format of the configuration files and generated files:
CoRN 3 files | aCoRNs files |
---|---|
|
|
|
|
|
|
|
|
|
|
10. Troubleshooting
You might run into the following problems if you organize your chapters into subsections.
10.1. Ticket does not appear in subsection
If you created subsections in the templates.yaml
file and a ticket does not appear in the builds, the most common reason is that the ticket does not match the filter.
For example, the Component field of the ticket might not match the component filter of the subsection.
-
Check the ticket to ensure that the value of the Component field is correct, for example,
FIPS
. -
In your repository, check the filter of the subsection in the
acorns/templates.yaml
file:- &security title: "Security and authentication" filter component: ['Security','SCAP Plugin']
-
Add the ticket component to the subsection filter:
component: ['Security','SCAP Plugin','FIPS']
Alternatively, add a component override to the ticket in the
acorns/tickets.yaml
file:- [Jira, key: PROJECT-12345, { overrides: {components: ['Security']} }]
10.2. Chapter does not appear in build
The following error message in an aCoRNs build indicates that the file for a chapter was not generated:
Unresolved directive in master-template.adoc - include::acorns/generated/internal/assembly_deprecated-functionality.adoc[leveloffset=+1]
aCoRNs generates either an assembly or a reference module for a chapter, depending on the structure:
-
If a chapter contains subsections, aCoRNs generates an assembly:
acorns/generated/internal/assembly_deprecated-functionality.adoc
. -
If a chapter contains no subsections, aCoRNs generates a reference module:
acorns/generated/internal/ref_deprecated-functionality.adoc
.
If you change a section from no subsections to subsections or vice versa, you must manually update the master-template.adoc
file so that the included file is correct.
11. Known issues and limitations
See the issues in the aCoRNs repository: https://github.com/redhat-documentation/acorns/issues.