Our application is in Node, Express, React, & Next. We are using a "subject folder" pattern. Each folder represents a major capability of the docs.github.com. To learn more about each subject, check the README.md file in the folder.
We used to organize our code more by role. Client, stylesheets, server middleware, shared files, tests, and so on. As the site grew, we had difficulty finding all the pieces that made a single feature work across the code base. Instead, we're moving to organize by subject. Subjects are easier to find all the related code for a single capability in one place.
Run script/create-subject.js --name x
to create a new subject folder.
Subjects do not need every element below. Not every element needs to be a folder. A subject folder looks like:
src/
xsubject/
README.md
docs/
lib/
middleware/
pages/
components/
stylesheets/
scripts/
tests/
If subject depends on another subject, please make this explicit in the README.
Choose the most specific subject folder available when organizing code.
A capability should have its own subject folder when it has its own specific tests.
A few things are harder to categorize, so there's some broad folders:
content/
, for things that make thecontent/
ordata/
directories work. And there's no more specific option.environments/
, for things that make local, testing, preview, staging, production work. And there's no more specific option.frame/
, for things that make the header, footer, global sidebar functional. And there's no more specific option.
But don't hestitate to make a new subject folder if there's at least a few files related.
Check the README.md in the subject folder for questions specific to a subject.
For internal folks, please ask in the Docs Engineering Slack or repository.
For open source folks, please ask on the discussion board.
Most subject folders have their own mention in .github/workflows/test.yml
.
Open the file to see the beginning of it. It's manually maintained but
it's important to point out two things:
- It's manually entered so creating a
src/foo/tests/*.js
doesn't automatically start running those tests. - When you add an entry to
.github/workflows/test.yml
, and it's gone intomain
, don't forget to add it to the branch protection's required checks.