I tried ADR-tools, and in 10 minutes I was able to document on my personal projects (my pinewood derby project, soon to be added to github). Installing was easy on a Mac:
brew install olleolleolle/adr-tools/adr_tools
Pages already contain the markup needed for github and gitlab (which is probably more than what I need). Running the command:
adr list
Lists all ADR in the local directory. Adding a new ADR:
adr new Add new Component
Creates a page and opens the editor (configured in your EDITOR env variable). Notice the markup is ready to go. Doing the following:
adr new -s 2 Add super new Component
Allows you to supersede an ADR and updates the ADR markup pages automatically. This is a sample of a superseded page:
Date: 28/04/2017
Superceded by 6. Add mailchimp as default contact me page provider
Context here...
Decision here...
Consequences here...
This is a superseding page:
Date: 28/04/2017
Accepted
Supercedes 5. Add custom contact me page to site
Context here...
Decision here...
Consequences here...
Documenting architecture decisions may be harder than most people think, and I'd concede that this approach may be too simplistic, and almost impossible for monolith apps. In designing and archictecting systems, I'm finding that in the process of "innovation and creativity", if I can't describe a system, or tell the story or how we got "there", I'm simply over-architecting.
I'm going to continue to experiment with this small tool, however I'm already feeling like I may have found something useful to keep up with my architecture decisions.
No comments:
Post a Comment