Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create text file to document contribution guidelines #34

Open
skyfenton opened this issue Oct 27, 2024 · 6 comments
Open

Create text file to document contribution guidelines #34

skyfenton opened this issue Oct 27, 2024 · 6 comments
Labels
documentation Improvements or additions to documentation

Comments

@skyfenton
Copy link
Collaborator

As we keep deciding on how tests should be constructed, naming schemes, formatting tools, docstrings, etc. we should have a markdown text file (a "CONTRIBUTING.md") to define our guidelines for writing code, submitting PRs, etc. that we can refer newcomers to and use to remind ourselves.

This way we also have a list of conventions to double check for in PR reviews to maintain consistency and confidence a PR has checked all the boxes.

@skyfenton skyfenton added the documentation Improvements or additions to documentation label Oct 27, 2024
@skyfenton skyfenton changed the title Add text file to document contribution guidelines Create text file to document contribution guidelines Oct 27, 2024
@jhanley634
Copy link
Collaborator

jhanley634 commented Oct 27, 2024

I can share things that I have seen are effective at "herding cats" when working with teams having between two and two dozen engineers of diverse skill levels.

  • tests: $ make test is Green, and we have decent coverage. When adding a new feature function, expect that test code will exercise at least one line of that function. Or queue up a subsequent PR to add a test.
  • naming: PEP 8. It's easy to do, and it's universal within the python community. Linters and reviewers can flag issues.
  • formatting: black, then verify a clean $ ruff check. One can get ruff to write fixes, but I find that makes it harder to communicate an idea to newbies than a simple "black + ruff", "write + read", would be. Even simpler: $ make lint, and have that group imports with isort. I tend to assume that modern python code shall have type annotations -- no reason to omit them.
  • docstrings: This is the only topic that is "hard".

We conduct a code review during the PR process to assess two things:

  1. Is it correct?
  2. Is it maintainable?

The easy-to-run $ make lint test gives an objective answer to the first. I offer this example.

The author likely believes that anyone in the team could fix a bug or add a feature to the code they just wrote. But only another teammate could give an answer of, "yes! I think I grok this new code and could maintain it." That's why we do reviews, to helpfully reveal blind spots in the author's thinking. What is obvious to the author won't be universally obvious, so we give other folks an opportunity to chime in, before they're stuck with supporting that code.

We desire that functions should compose, so each author takes care to spell out a new function's contract. Sometimes the pre- and post- conditions are clear from the signature. If not, we need at least a one-sentence docstring. A reviewer should be able to articulate what the contract is. Imagine there is no unit test. By examining the function's signature and contract (but not its source code), a reviewer should be able to write meaningful unit tests. If not, it is appropriate to push back, to suggest improvements to the PR prior to merging down to main.

@skyfenton
Copy link
Collaborator Author

Those all sound solid to me, I imagine this document would be 70-80% standard python practices with just a little bit of our own preferences for communication and workflow.

@audiodude
Copy link
Collaborator

@skyfenton would you like to take a crack at it? There's probably templates you can use to get started.

@skyfenton
Copy link
Collaborator Author

Sure, I'll draft something up. I'll def want to review it next week with everyone to make sure there aren't any important gaps.

@audiodude
Copy link
Collaborator

Awesome, sg

@audiodude
Copy link
Collaborator

Let's document:

  • Adding descriptive commit messages for individual commits
  • Merging main instead of rebasing
  • Not force pushing active PRs
  • Linking issues from PRs

And much much more!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Improvements or additions to documentation
Projects
None yet
Development

No branches or pull requests

3 participants