Codify Architectural Decision Records and Changelog
Use Case
Consumers should know where the project has come and gone and contributors should clearly document changes.
Scope of Work
Formalize the process by which changelogs and decision logs are generated, and document this process.
Contextual Information
- Orchestrator has decision logs as a first iteration toward Architectural Decision Records.
- Orchestrator has a milestone file which is incomplete
- Orchestrator should have a changelog as part of the release process we are designing.
Acceptance Criteria
- Document how the decision records will be stored and organized
- Document the changelog process and requirements
Outputs
Designs
- Show closed items
Relates to
Activity
-
Newest first Oldest first
-
Show all activity Show comments only Show history only
- Robert Marshall added Orchestrator devopssystems groupdistribution spike labels
added Orchestrator devopssystems groupdistribution spike labels
- Robert Marshall marked this issue as related to #216 (closed)
marked this issue as related to #216 (closed)
- Author Maintainer
I've talked about this a bit over the last few weeks and realized that I'd not gone back to create an issue to allow asynchronous discussion. It's coming more into mind as the release process is defined.
cc @WarheadsSE , @ghickey and @mnielsen
Edited by Robert Marshall - Robert Marshall changed title from Codify Decision Logs and Changelog to Codify Architectural Decision Records and Changelog
changed title from Codify Decision Logs and Changelog to Codify Architectural Decision Records and Changelog
- Developer
Document the changelog process and requirements
For the process, you should be able to follow that already outlined by various projects throughout GitLab (bin/changlog, scripts/changelog ...) as you're likely familiar with in gitlab-org/gitlab & gitlab-org/charts/gitlab.
Clarity should be collected regarding what changes require an entry, and those that do not.
- Developer
Document how the decision records will be stored and organized
I like this "MADR" proposal. https://adr.github.io/madr/
I do want to call out that we don't have to go full tilt. The key items needed for record are:
- title
- status
- context
- decision
- consequence / impact
Within the Helm charts, we implemented a minimal form of ADR, which has served us well. Here in this project, I think it may make sense to have individual documents, which are referenced from an index.
- Author Maintainer
Weight Calculation
- 4 from Distribution
- 1 from Quality Assurance
- 1 from Docs
- 1 from Product
- Documentation Unclear or Partial
- No Known Definition of Done
- Requires Architectural Decisions
(4 + 1 + 1 + 1 + 12 + 12 + 4 ) * 4 = 140
- Robert Marshall set weight to 140
set weight to 140
- Robert Marshall added OrchestratorCodex label
added OrchestratorCodex label
- Robert Marshall added to epic &4042 (closed)
added to epic &4042 (closed)
- Author Maintainer
I was looking at the tools that generate ADRs and it seems like the work on them all stopped in 2018.
I think a minimal thing to do for this project would be to make something simple that can:
- generate an adr file
- generate the decisions list page
- understand that if B supercedes A, then C cannot supercede A too
- Author Maintainer
Iterations
- do the files manually after figuring out the format
- figure out how to make a simplistic tool that does the above to maintain it automatically
- Robert Marshall marked this issue as related to #265
marked this issue as related to #265
- Robert Marshall mentioned in issue #265
mentioned in issue #265
- Author Maintainer
Opened #265 to discuss the automation part.
Manually converting existing decisions to this model:
Filename:
/doc/architecture/decisions/0001_my_decision_record.md
per documentation standards for markdown names and standards for file paths extending to createarchitecture
.# 0001. My Decision Record Proposed: YYYY-MM-DD Accepted|Rejected: YYYY-MM-DD Deprecated|Superceded: YYYY-MM-DD ## Status Accepted|Proposed|Rejected|Deprecated|Superceded ## Context Link to initial issue to discuss Prose describing contexts and constraints that impacted the decision making process. ## Decision Document the outcome of the change proposal. ## Consequences List tradeoffs made in this decision.
To handle relationships between decisions, we will do a JSON file named
/doc/architecture/decisions/metadata.json
that is manually edited until we have a better scope for how to make this more automated.{ "superseded": { new_decision: old_decision } }
Collapse replies - Author Maintainer
Opened gitlab!38102 (closed) to add the
doc/architecture
standard to our style guide.
- Robert Marshall mentioned in commit gitlab@5496e37b
mentioned in commit gitlab@5496e37b
- Robert Marshall mentioned in merge request gitlab!38102 (closed)
mentioned in merge request gitlab!38102 (closed)
- Robert Marshall mentioned in commit efb370a8
mentioned in commit efb370a8
- Robert Marshall mentioned in merge request !66 (merged)
mentioned in merge request !66 (merged)
- Author Maintainer
Opened !66 (merged) to follow the GitLab style guidelines and put our docs in the
doc/
directory instead of thedocs/
directory. - Robert Marshall added Deliverable priority3 severity3 labels
added Deliverable priority3 severity3 labels
- Robert Marshall changed milestone to %13.3
changed milestone to %13.3
- Robert Marshall mentioned in commit f646d2c1
mentioned in commit f646d2c1
- Robert Marshall mentioned in commit 2a6680e7
mentioned in commit 2a6680e7
- Robert Marshall mentioned in merge request !67 (merged)
mentioned in merge request !67 (merged)
- Robert Marshall mentioned in commit a05d7a3b
mentioned in commit a05d7a3b
- Robert Marshall mentioned in commit 0d4e4b20
mentioned in commit 0d4e4b20
- Robert Marshall mentioned in commit 8a4044f6
mentioned in commit 8a4044f6
- Robert Marshall mentioned in merge request !68 (merged)
mentioned in merge request !68 (merged)
- Robert Marshall mentioned in commit 2240a37b
mentioned in commit 2240a37b
- Robert Marshall mentioned in commit ea350a4c
mentioned in commit ea350a4c
- Author Maintainer
Looking at changelog scripts:
These are slightly different, is this intentional, and do we have a source of truth?
Collapse replies - Author Maintainer
Looks like the main difference here is the file it writes changelogs to when differentiating Community versus Enterprise Editions.
- Author Maintainer
I opened !70 (merged) and posted questions to @axil and @yorickpeterse regarding the changelog process and where I'd like to put Orchestrator's changelog files.
1
- Robert Marshall mentioned in commit omnibus-gitlab@f44e6728
mentioned in commit omnibus-gitlab@f44e6728
- Robert Marshall mentioned in merge request omnibus-gitlab!4464 (closed)
mentioned in merge request omnibus-gitlab!4464 (closed)
- Robert Marshall mentioned in commit 3e4317a5
mentioned in commit 3e4317a5
- Robert Marshall mentioned in merge request !70 (merged)
mentioned in merge request !70 (merged)
- Robert Marshall mentioned in commit 8d3613e9
mentioned in commit 8d3613e9
- Robert Marshall mentioned in commit 18f834db
mentioned in commit 18f834db
- Robert Marshall mentioned in commit 11d7e4ea
mentioned in commit 11d7e4ea
- Robert Marshall changed the description
Compare with previous version changed the description
- Robert Marshall assigned to @rmarshall
assigned to @rmarshall
- Robert Marshall mentioned in commit 98b427d6
mentioned in commit 98b427d6
- Robert Marshall mentioned in merge request !75 (merged)
mentioned in merge request !75 (merged)
- Robert Marshall changed the description
Compare with previous version changed the description
- Author Maintainer
Opened !75 (merged) to document changelog and start a Contributor's guide.
When it merges, this deliverable is concluded.
- Robert Marshall mentioned in commit 7e3d004b
mentioned in commit 7e3d004b
- Author Maintainer
All work is merged; this can now be closed.
- Robert Marshall closed
closed
- Robert Marshall set weight to 18
set weight to 18