One of the things I find across the contracts I work on is the lack of attention to detail in getting spelling and grammar correct in OpenAPI documents. Sure, most developers don't care about this stuff, but it takes the shine of what should be a fundamental part of the product offering.
I've therefore knocked together this Spectral ruleset as a little proof-of-concept. It uses a Custom Function and the Atom package spellchecker
, which offers up some bindings to the system spell checker. Note no grammar features are implemented right now - to be implemented in due course.
It's just something for folks to pick up and use. The biggest drawback with the approach is the binding to the system dictionary, which may of course be in a different language to the one the OpenAPI document is being authored in. However, I'm sure clever folks out there can iron this wrinkle out (probably by swapping the spellchecker
dependency for something a bit more "flexible").
By way of exemplar, I've knocked together an OpenAPI document with a bunch of spelling mistakes. If you run the following:
yarn install
yarn run lint rulesets/spell-check.yaml test/misspelt-openapi.yaml # For convenience, ideally install Spectral globally
You should get the following output:
➜ spectral-spelling-grammar git:(master) ✗ yarn run lint rulesets/spell-check.yaml test/misspelt-openapi.yaml
yarn run v1.22.17
$ npx spectral lint --ruleset rulesets/spell-check.yaml test/misspelt-openapi.yaml
/Users/chris/Documents/git/github/api-stuff/spectral-spell-check/test/misspelt-openapi.yaml
3:10 warning check-title-spelling Misspelt words found in text: concpte info.title
4:16 warning check-description-spelling Misspelt words found in text: bdaly, smealt info.description
9:16 warning check-summary-spelling Misspelt words found in text: Defautl paths./test.get.summary
10:20 warning check-description-spelling Misspelt words found in text: speling, veeeryy paths./test.get.description
13:24 warning check-description-spelling Misspelt words found in text: Defalt paths./test.get.responses[200].description
✖ 5 problems (0 errors, 5 warnings, 0 infos, 0 hints)
✨ Done in 1.37s.
➜ spectral-spelling-grammar git:(master) ✗
Simple really.
The anatomy of this project is pretty basic and reflects the use of Custom Functions in Spectral.
If you are not familiar with Spectral and would like a deep dive checkout my soup to nuts example or my ASC presentation for a quick overview.
The fundamental parts are:
- A custom ruleset that implements rules based on finding any
description
,summary
ortitle
property in the OpenAPI document. The severity is set as a warning in this ruleset. - Each of those rules invokes the spell check custom function which splits the string into words and then runs the
spellchecker.isMisspelled
function on each to find the misspelt words. The words are returned in the message.
If you want to use this ruleset just clone this repository, grab the ruleset and function and reference them thus in your ruleset (I might package this stuff later if I add more functions):
extends:
- ./spell-check.yaml
Bobs your Uncle 👍.