Skip to main content

Pair script that manage a pair programming session using git.

Project description

Dev Pair

Illustration by: popsy

Python Test PyPI Version Python Version

It's a tool to facilitate the remote pair programming session. Instead of make a lot of git add, git commit, git push, git pull, you can make it more quickly only running devpair start <timer optional> to start coding and devpair next to send the code to another person.

Very useful for teams that like to make pair sessions often. If you never was a driver or a navigator feel free to read here to have a context.

Install

pip install devpair

Commands

  • devpair start <time in minutes optional> Start a new session inside the current branch.
  • devpair next Save everything and send to the next person.
  • devpair done Finish and put all the work in the original branch.
  • devpair summary Show a simple resume of commit counts and last developer.
  • devpair cow It's cow.
  • devpair timer <time in minutes> Create a simple timer for any purposal.
  • devpair --help I like to have a help some times.

We recommend to create some alias if you want, like: dvs to run devpair start, dvn to run devpair next and dvd to run devpair done.

Example of use

# Dev A
main $ devpair start 10 # Will start the new branch with a 10 minutes timer
pair/main $ echo "hello" > welcome.txt
pair/main $ devpair next

# Dev B
main $ devpair start
pair/main $ cat welcome.txt # shows "hello"
pair/main $ echo " world" >> welcome.txt
pair/main $ devpair next

# Dev A
pair/main $ devpair start
pair/main $ cat welcome.txt # shows "hello world"
pair/main $ echo "!" >> welcome.txt
pair/main $ devpair done

main $ git commit -m "feat: created hello world feature"
main $ git push

# Dev B
pair/main $ devpair done # just to come back to the original branch
main

How it works internally?

You will work inside a temporary pair branch that in the end all the commits will be squashed to be added to the feature branch.

More details!

Ok ok! Under the hood the devpair start will take your current branch and create a copy with the same name but with the prefix pair

After make your code changes the devpair next will add, commit and push your code using an internal commit message. This step will be more easier to understand checking the example step by step

In the end, we have the devpair done that will add, commit, push and delete the branch. Don't worry we will make a squash commit of everything that you did for the current branch.

Recommendations

  • Before the pair programming
    • Define the end of the session. How many time do you want pair?
    • Define the break time.
  • Use a timer, maybe devpair timer or any other one, the important thing is to keep the pair rotation:
  • The driver need to share the screen avoiding to use tools like vscode live share, even they are good it can create some hard moments that you want to show the browser or create a quickly diagram. The preference is that the driver ever need to share the screen.
  • Antipatterns: https://tuple.app/pair-programming-guide/antipatterns

Contributing

Fork, create a branch from main with the pattern feat/my-feature and make a pull request with your proposal.

Local env

We are using poetry and pyenv to manage all the python versions and dependencies.

# Install all the dependencies
poetry install
# Install the pre-commit
poetry run pre-commit install
# Set the version of the `.python-version`
pyenv local
# Run all the tests
make unit

Publishing

sh ./scripts/tag-new-version.bash v0.0.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

devpair-1.1.15.tar.gz (8.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

devpair-1.1.15-py3-none-any.whl (8.7 kB view details)

Uploaded Python 3

File details

Details for the file devpair-1.1.15.tar.gz.

File metadata

  • Download URL: devpair-1.1.15.tar.gz
  • Upload date:
  • Size: 8.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for devpair-1.1.15.tar.gz
Algorithm Hash digest
SHA256 10d4ba23af00b7d243f4fe04f70802b9d6a2fca73fcd0928f35ce6d07c77dbf9
MD5 593ee3801a5a0c5bc00e1143c708f763
BLAKE2b-256 947afb56115976beca3958e6c4d6022a4efaf2900fa1cf8faed2b90e22fd0244

See more details on using hashes here.

File details

Details for the file devpair-1.1.15-py3-none-any.whl.

File metadata

  • Download URL: devpair-1.1.15-py3-none-any.whl
  • Upload date:
  • Size: 8.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for devpair-1.1.15-py3-none-any.whl
Algorithm Hash digest
SHA256 9001e2c9895f0b654c4c20423215302069e8aa3bb09c07bb5faa9bbe686cbac8
MD5 f89d483ffe25d189c7e6c60e6c3516e9
BLAKE2b-256 00337a08e93bc517e9307f6d32e4a2a606a7b5411dcd246d7393752c72be9b01

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page