The QUADS project welcomes contributions from everyone! Please read the below steps to see how you can contribute to QUADS.
-
We do not use the Github Pull Request system.
-
We use Gerrit for code review instead.
-
You can also find us on IRC at #quads on
irc.libera.chat
webchat
-
Clone
development
branch.git clone --single-branch --branch development https://github.com/redhat-performance/quads
-
Change directory to the code and create your own branch to work
cd quads git checkout -b name_of_change
- Create virtualenv, install dependencies and the QUADS package
python3 -m venv venv source venv/bin/activate pip install -r requirements.txt pip install -e .
- Relocate configuration files to the correct location
mkdir -p /opt/quads/conf cp -r conf/* /opt/quads/conf/
- Install pre-commit
dnf -y install pre-commit
- Install the pre-commit hooks
pre-commit install
-
Instantiate a PostgreSQL container via podman
podman run -e POSTGRES_PASSWORD=postgres -p 5432:5432 postgres
-
This will not background the podman container, so open other terminals to work.
-
Initialize the database with the quads model
SQLALCHEMY_DATABASE_URI=postgresql://postgres:postgres@localhost:5432/quads flask --app src/quads/server/app.py init-db
NOTE: If you're using Docker on Mac OSX you may want to switch to the overlay2 driver This is not strictly a requirement but can significantly improve performance on a Mac for the local driver. For more details see this article. Local driver mapped content is stored in ~/Library/Containers/com.docker.docker/Data/vms/0/ in a disk image.
- Start the Flask development server instance
gunicorn quads.server.app:create_app\(\) -b :5000 -w 4 -k gthread --max-requests=5000 --max-requests-jitter=500 --log-level=DEBUG
- You can now access the QUADS API at
http://localhost:5000/api/v3/
- You can also use the
quads-cli
to interact with the APIquads --ls-hosts
- Create the directory for the web app to load dynamic content
mkdir -p /opt/quads/web
- Start the Flask development server instance
gunicorn quads.web.app:create_app\(\) -b :5001 -w 4 -k gthread --max-requests=5000 --max-requests-jitter=500 --log-level=DEBUG
- You can now access the QUADS Web UI at
http://localhost:5001/
- After all steps on the Running QUADS Locally section have been completed, you can run the tests.
- To run the full suite of tests, you can use the
tox
commandSQLALCHEMY_DATABASE_URI=postgresql://postgres:postgres@localhost:5432/quads tox
- To run a specific test environment, you can use the
-e
flagSQLALCHEMY_DATABASE_URI=postgresql://postgres:postgres@localhost:5432/quads tox -e py312
- Create a Github issue to track your work.
- Provide a meaningful explanation, citing code lines when relevant.
- Explain what you are trying to fix, or what you're trying to contribute.
-
This is a one-time only setup step
-
You'll need a Github account to proceed.
-
Setup username/email for Github and Gerrithub (one time only):
- Ensure Github and Gerrithub are linked by signing into Gerrithub via Github
- match
gitreview.username
to your Github username - match
user.name
to your real name or how you want credit for commits to display in Git history. - match
user.email
to your email address associated with Github.
-
Setup Inside Cloned QUADS Repo
- Setup your username, email address as needed
- Set your
gitreview.username
git config user.email "[email protected]"
git config user.name "Venril Sathir"
git config --add gitreview.username "vsathir"
- Add a local commit with a meaningful, short title followed by a space and a summary (you can check our commit history for examples.
- Add a line that relates to a new or existing github issue, e.g.
fixes: https://github.com/redhat-performance/quads/issues/5
orrelated-to: https://github.com/redhat-performance/quads/issues/25
- First make your commit
- Leave an extra few lines of space at the bottom of the commit message
git add quads/api_v2.py
git commit
- Now you need to amend your comment so a Gerrit Change-ID gets appended.
git commit --amend
- This is a one-time only setup step
- Install git-review and run it for first time.
yum install git-review
git review -s
- Now submit your patchset with git review (future patches you only need to run
git review
)
git review
- If you are adding new functionality or methods you'll need to also include unit tests or CI will get upset.
- If you want to make changes to your patchset you can run the
git commit --amend
command.
vim src/quads/cli/cli.py
git add src/quads/cli/cli.py
git commit --amend
git review development
- If you just want to check out an existing patchset in Gerrit you can use the
git review -d $CHANGEID
command.
git review -d $CHANGEID
- Keep an eye on your patchset in Gerrithub, this is where CI will run, where we'll provide feedback and where you can monitor changes and status. Your git review command will print the correct URL to your patchset.
- This is usually done by QUADS maintainers, but to promote your change to production via the
latest
branch we now use git cherry-pick - This will require an up-to-date checkout of the
latest
branch.
Let's say your patch into development
has commit hash e6fcc94732266568f72d22e0cd24d9f06d9060c7
and it's the latest commit in the branch, we will use this as an example:
git checkout development
git pull
git log | head -1
commit e6fcc94732266568f72d22e0cd24d9f06d9060c7
- Now
git cherry-pick
your change against thelatest
branch and submit review.
git checkout latest
git pull
git cherry-pick e6fcc94732266568f72d22e0cd24d9f06d9060c7
git review latest
The CI pipeline currently checks the following for every submitted patchset:
- shellcheck - checks for common shell syntax errors and issues
- flake8 - checks Python tools for common syntax errors and issues
- unit tests
- You can trigger CI to run again by commenting on your patchset in gerrit with
retrigger