This document aims to assist maintainers.
As a guideline, concepts in Nighthawk that are derived from Envoy require
someone with Envoy domain expertise in review. Notable examples are the way
Nighthawk internally computes cluster configuration, its connection pool
derivations, the StreamDecoder
class, as well as anything related to the
Nighthawk test server.
See OWNERS.md to find maintainers with expertise of Envoy internals.
- Does the PR have breaking changes? Then that should be explicitly mentioned in the version history.
- New features should be added to the version history.
- Breaking changes to the protobuf APIs are not allowed.
- When merging, clean up the commit message so we get a nice history. By default, github will compile a message from all the commits that are squashed. The PR title and description should be a good starting point for the final commit message. (If it is not, it may be worth asking the PR author to update the description).
- Make sure that the DCO signoff is included in the final commit message.
- As a convention, it is appropriate to exclude content in the PR description that occurs after the signoff.
We aim to synchronize our Envoy dependency with the latest revision weekly. Nighthawk reuses large parts of Envoy's build system and codebase, so keeping Nighthawk up to date with Envoy's changes is an important maintenance task. When performing the update, follow this procedure:
- Create a fork of Nighthawk, or fetch upstream and merge changes into your fork if you already have one.
- Create a new branch from
main
, e.g.envoy-update
. - Edit bazel/repositories.bzl
- Update
ENVOY_COMMIT
to the latest Envoy's commit from this page. (Clicking on the short commit id opens a page that contains the fully expanded commit id). - Set
ENVOY_SHA
to an empty string initially, we will get the correct sha256 after the first bazel execution. Example content ofbazel/repositories.bzl
after the edits:ENVOY_COMMIT = "9753819331d1547c4b8294546a6461a3777958f5" ENVOY_SHA = ""
- Run
ci/do_ci.sh build
, notice the sha256 value at the top of the output, example:INFO: SHA256 (https://github.com/envoyproxy/envoy/archive/9753819331d1547c4b8294546a6461a3777958f5.tar.gz) = f4d26c7e78c0a478d959ea8bc877f260d4658a8b44e294e3a400f20ad44d41a3
- Update
ENVOY_SHA
in bazel/repositories.bzl to this value.
- Update
- Sync (copy) .bazelrc from
Envoy's version to
update our build configurations. Be sure to retain our local modifications,
all lines that are unique to Nighthawk are marked with comment
# unique
. - Sync (copy) .bazelversion from Envoy's version to ensure we are using the same build system version.
- Sync (copy) ci/run_envoy_docker.sh from
Envoy's version.
Be sure to retain our local modifications, all lines that are unique to
Nighthawk are marked with comment
# unique
. - Sync (copy) tools/gen_compilation_database.py from
Envoy's version to
update our build configurations. Be sure to retain our local modifications,
all lines that are unique to Nighthawk are marked with comment
# unique
. - Sync (copy) tools/code_format/config.yaml from
Envoy's version to
update our format checker configuration. Be sure to retain our local modifications,
all lines that are unique to Nighthawk are marked with comment
# unique
. - If requirements.txt has not been updated in the last 30 days (based on comment at top of file), check for major dependency updates. See Finding python dependencies below for instructions.
- Run
ci/do_ci.sh test
. Sometimes the dependency update comes with changes that break our build. Include any changes required to Nighthawk to fix that in the same PR. - If the PR ends up modifying any c++ files, execute
ci/do_ci.sh fix_format
to reformat the files and avoid a CI failure. - Execute
tools/update_cli_readme_documentation.sh --mode fix
to regenerate the portion of our documentation that captures the CLI help output. This will prevent a CI failure in case any flags changed in the PR or upstream. - Create a PR with a title like
Update Envoy to 9753819 (Jan 24th 2021)
, describe all performed changes in the PR's description.
We should check our python dependencies periodically for all version updates. We attempt to update these dependencies monthly. Here is an easy way to check for dependency updates:
-
Create and activate a virtual env:
virtualenv pip_update_env source pip_update_env/bin/activate
NOTE: if
pip_update_env/bin/activate
appears to not exist, try settingexport DEB_PYTHON_INSTALL_LAYOUT='deb'
and recreating the virtualenv. -
Install dependencies:
pip install -r requirements.txt
-
Check for outdated dependencies:
pip list --outdated
This will likely show both outdated dependencies based on requirements.txt and other outdated dependencies you may have in addition, such as to
pip
itself. Here, we are only interested in cross-referencing the ones that appear with the ones in requirements.txt. -
If you find any dependency updates, you can either try updating the dependency in requirements.txt yourself or create an issue for the change and assign it to one of the nighthawk maintainers. If you do it yourself, note that all versions must be pinned to conform with rules_python.
If there are not any dependency updates, please update the timestamp at the top of the file.
-
When done, clean up the virtual env:
deactivate rm -rf pip_update_env
If you encounter an error that looks like:
ERROR: REDACTED/nighthawk/test/integration/BUILD:32:11: no such package '@python_pip_deps//pypi__more_itertools':
BUILD file not found in directory 'pypi__more_itertools' of external repository @python_pip_deps. Add a BUILD
file to a directory to mark it as a package. and referenced by '//test/integration:integration_test_base_lean'
Then we are missing a dependency from requirements.txt. This may happen due to changing other dependencies.
The name of the dependency to add is everything after pypi__
, in the above case more_itertools
.
Sometimes CI tests fail after updating Nighthawk to an Envoy dependency. If the root cause is hard to be identified, the bisect could be worth a try.
The bisect is used to find the problematic Envoy commit between the commit from the last successful Nighthawk update and the current commit that Nighthawk needs to be updated to.
Following the
update process to update Nighthawk to a
specific Envoy commit for each Envoy commit being tested in the bisect. Generally, you can
do this by only changing the ENVOY_COMMIT
and leaving ENVOY_SHA
blank in the
repositories.bzl
file.
- Usually the local
do_ci.sh
test is enough and the most efficient. - If you do need to test in github CI (e.g. the local
do_ci.sh
passes while the github CI fails), creating a draft PR to execute the CI tests. See an example PR for bisecting here.
-
You can just test the failed tests by commenting out the others. For testing locally, modifying
ci/do_ci.sh
. For testing in the github CI, modifying.azure-pipelines/pipelines.yml
(See this example). -
If it is the unit test or integration test that fails, you can modify the test code to only run the failure tests. See
test/python_test.cc
in this PR for running the selected Nighthawk python integration tests.