Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code...

15
DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

Transcript of Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code...

Page 1: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

DevOps meets Docs:Documentation as Code

OSSummit Europe 2018

Robert Krátký, @rkratkyPrincipal Technical Writer, Red Hat

Page 2: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

1. What does ‘Docs as Code’ mean? a. What is it?b. What’s involved?

2. Benefits a. For writers and developersb. For organizations or projects

3. Challenges a. For writers and developersb. Technical

IN THIS PRESENTATION

LOGO

CHALLENGE

Page 3: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

Writing, testing, publishing, and maintaining documentation using the same tools developers use for software code.

WHAT DOES ‘DOCS AS CODE’ MEAN?

Goals❏ Content authoring❏ Formatting, styling❏ Version control❏ Issue tracking❏ Testing, validation❏ Publishing

Tools➔ Text editors➔ Markup languages➔ Git, SVN, Mercurial, ...➔ JIRA, BugZilla, Mantis, …➔ Scripts, linters, spell-checks➔ Site builders, CMS, ...

Page 4: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

● Writers have freedom of choice● Advanced batch operations● Using external tools to process text

CONTENT AUTHORING➙ TEXT EDITORS

Page 5: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

FORMATTING, STYLING➙ MARKUP LANGUAGES

● Universal readability (plain text)● Syntax validation● (More or less) semantic, i.e. parseable

Page 6: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

VERSION CONTROL➙ GIT AND CO.

● Distributed, decentralized (Git)● Integral peer-review workflows● Docs can share space with code● Public hosting & on-premise deployment

https://github.com/redhat-documentation/

Page 7: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

ISSUE TRACKING➙ BUGZILLA, JIRA, ...

● Integration with version control● API hooks (e.g. generating ‘release notes’)● Agile facilitation

Page 8: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

TESTING, VALIDATION➙ SCRIPTS, LINTERS

● Continuous integration● Customizable, extendable● Link validity, component checking● Semantic syntax parsing

https://github.com/emender/emender

Page 9: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

PUBLISHING➙ SITE GENERATORS, CMS, ...

● Continuous deployment● Local and on-production building● Containerized toolchains (multi-platform)

Page 10: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

BENEFITSFOR WRITERS & DEVELOPERS

● Developers familiar with toolchain○ Contributions from developers○ Fly-by contributions○ Community contributions

● Integration with developer teams○ Involved with product planning○ Included in the definition of done○ Easier collaboration with QA○ Sense of common responsibility

Page 11: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

BENEFITSFOR ORGANIZATION, PROJECT

● No vendor lock-in○ Future-proof format & tools○ Easy switching to different formats & tools

● Tighter collaboration between teams, depts.○ Unified, streamlined workflows○ Efficiency (automation)○ Aligning releases with publishing

Page 12: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

CHALLENGESFOR WRITERS & DEVELOPERS

● Resistance from writers○ Training for writers may be needed○ Steep learning curve○ Many tools with single-purpose function (vs monolithic docs system) - tools may seem too difficult, yet simple

● Resistance from developers○ Documentation slows down ‘done’○ Corrections more visible; hurt pride

Page 13: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

CHALLENGESTECHNICAL

● Content preparation○ (Potentially) non-trivial conversion○ Release disruption

● Technical support & administration(depending on scope)○ IT resources○ IT staff

Page 14: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

DISCUSSION

● Your experience?● Tools of choice?● Development models?● When adopting a new system

○ Convert existing?○ Start from scratch?

● Metadata?● Peer-review approaches?

Page 15: Documentation as Code DevOps meets Docs: OSSummit …...DevOps meets Docs: Documentation as Code OSSummit Europe 2018 Robert Krátký, @rkratky Principal Technical Writer, Red Hat

THANK YOU

[email protected]@rkratky