mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-05 22:34:22 +03:00
96e8028c01
Most of our span names were in the format `snake_case` and usually reflected `name_of_the_function`. This is unfriendly, so we've changed it to match the format used by data connectors, which use a format like "Database request" or "Waiting for connection". It would be nice if `Execute request plan for query field` could be `Execute request plan for query field "person"` but it seems changing the currently used `&'static str` for `String` causes all sorts of other lifetime issues, so I suppose we're better including more information as span attributes instead. Therefore, all our span names need to be pretty much static (or at least, dynamically chosen from a list of static names). Note: I have not changed the `SpanVisibility::Internal` span names for now. Most of these reflect function names and this is pretty useful IMO. Happy to change this later if other feel strongly though. V3_GIT_ORIGIN_REV_ID: f2226b2466e8592676f3f4635d483289f0e3f6aa
153 lines
5.0 KiB
Makefile
153 lines
5.0 KiB
Makefile
set positional-arguments
|
|
|
|
CLIPPY_ARGS := "-A clippy::result_large_err -D clippy::complexity -A clippy::too_many_arguments -D clippy::style"
|
|
CLIPPY_FIX_ARGS := "-A clippy::result_large_err -A clippy::too_many_arguments"
|
|
|
|
# This produces "-p engine -p lang-graphql -p ...".
|
|
# See https://github.com/rust-lang/cargo/issues/4463 for why we build each
|
|
# package explicitly instead of `cargo build --workspace --all-targets`.
|
|
PACKAGE_SELECTOR := `ls crates | sed 's/^/-p /' | xargs echo`
|
|
|
|
default:
|
|
just --list
|
|
|
|
# run commands in a rust docker environment with source code only without starting any dependencies.
|
|
docker_with_source_only +args:
|
|
#!/usr/bin/env sh
|
|
DOCKER_BUILDKIT=1 COMPOSE_DOCKER_CLI_BUILD=1 docker compose -f ci.docker-compose.yaml run --build --rm source_only "$@"
|
|
exit_code=$?
|
|
docker compose -f ci.docker-compose.yaml down
|
|
exit $exit_code
|
|
|
|
# run commands in a rust docker environment including test dependencies and then removes the container dependencies
|
|
# while emiting the exit code of the docker command
|
|
docker_with_test_env +args:
|
|
#!/usr/bin/env sh
|
|
DOCKER_BUILDKIT=1 COMPOSE_DOCKER_CLI_BUILD=1 docker compose -f ci.docker-compose.yaml run --build --rm test_setup "$@"
|
|
exit_code=$?
|
|
docker compose -f ci.docker-compose.yaml down
|
|
exit $exit_code
|
|
|
|
# build used by CI
|
|
ci-build:
|
|
just docker_with_source_only \
|
|
cargo build {{ PACKAGE_SELECTOR }} --release --all-targets
|
|
|
|
build-local:
|
|
cargo build {{ PACKAGE_SELECTOR }} --release --all-targets
|
|
|
|
# linting run by CI
|
|
ci-lint:
|
|
just docker_with_source_only sh -c \
|
|
"cargo clippy --no-deps -- {{ CLIPPY_ARGS }}"
|
|
|
|
fix:
|
|
just docker_with_source_only sh -c "cargo clippy --no-deps --fix --allow-no-vcs -- {{ CLIPPY_FIX_ARGS }}; cargo fmt"
|
|
|
|
fix-local:
|
|
cargo clippy --no-deps --fix --allow-no-vcs -- {{ CLIPPY_FIX_ARGS }}; cargo fmt
|
|
|
|
# tests run by CI
|
|
ci-test:
|
|
just docker_with_test_env cargo nextest run
|
|
|
|
test *TESTNAME:
|
|
if [ -z {{TESTNAME}} ]; then \
|
|
just docker_with_test_env cargo nextest run -E 'all()'; \
|
|
else \
|
|
just docker_with_test_env cargo nextest run -E 'test(={{TESTNAME}})'; \
|
|
fi
|
|
|
|
# tests using cargo test and not nextest.
|
|
# The nextest binary pulled in the docker image only works on linux hosts.
|
|
cargo-test *args:
|
|
just docker_with_test_env cargo test {{args}}
|
|
|
|
update-golden-files:
|
|
DOCKER_BUILDKIT=1 COMPOSE_DOCKER_CLI_BUILD=1 docker compose -f ci.docker-compose.yaml run --build --rm -e REGENERATE_GOLDENFILES=1 test_setup cargo test
|
|
|
|
# Benchmarks run by CI
|
|
ci-bench:
|
|
# Only bench what is required
|
|
just docker_with_test_env cargo bench \
|
|
-p lang-graphql --bench validation --bench parser \
|
|
-p engine --bench generate_ir --bench execute
|
|
|
|
drill:
|
|
just docker_with_test_env drill --benchmark drill.yml -s -q
|
|
|
|
# optional argument to show coverage only for files matched by {{filterexp}} i.e. grep -E filterexp
|
|
coverage *filterexp:
|
|
just docker_with_source_only bash coverage.sh '{{filterexp}}'
|
|
|
|
generate-benchmarks gh-issue gh-token:
|
|
just docker_with_test_env bash benchmark.sh {{gh-issue}} {{gh-token}}
|
|
|
|
dev:
|
|
docker compose run --build --rm dev_setup bash
|
|
docker compose down
|
|
|
|
# start all the docker deps for running tests (not engine, auth_hook, jaeger)
|
|
start-docker-test-deps:
|
|
# start connectors and wait for health
|
|
docker compose -f ci.docker-compose.yaml \
|
|
up --wait postgres custom_connector
|
|
# start auth_hook
|
|
docker compose up --wait auth_hook
|
|
# start everything else (don't wait for postgres connector, it doesn't seem
|
|
# to work)
|
|
docker compose -f ci.docker-compose.yaml \
|
|
up -d
|
|
|
|
# start all the docker run time deps for the engine
|
|
start-docker-run-deps:
|
|
# start auth_hook and jaeger
|
|
docker compose up --wait auth_hook jaeger
|
|
|
|
# stop all the docker deps
|
|
stop-docker:
|
|
docker compose -f ci.docker-compose.yaml down -v
|
|
docker compose down -v
|
|
|
|
# local development commands
|
|
|
|
# these work by running tests locally rather than in Docker
|
|
# to make them work, add the following lines to your `/etc/hosts` file
|
|
# (without the '#' at the start):
|
|
# 127.0.0.1 postgres_connector
|
|
# 127.0.0.1 custom_connector
|
|
|
|
# run the tests using local engine (once)
|
|
test-local: start-docker-test-deps
|
|
cargo test
|
|
|
|
# run a watch process that runs the tests locally
|
|
watch-local: start-docker-test-deps start-docker-run-deps
|
|
RUST_LOG=DEBUG \
|
|
cargo watch \
|
|
-x test \
|
|
-x 'clippy --no-deps -- {{ CLIPPY_ARGS }}' \
|
|
-x 'run --bin engine -- \
|
|
--otlp-endpoint http://localhost:4317 \
|
|
--authn-config-path auth_config.json \
|
|
--metadata-path crates/engine/tests/schema.json'
|
|
|
|
# check the code is fine
|
|
lint-local:
|
|
cargo clippy --no-deps -- {{ CLIPPY_ARGS }}
|
|
|
|
# ensure we don't have unused dependencies:
|
|
machete:
|
|
cargo machete --with-metadata
|
|
|
|
# update golden tests
|
|
update-golden-files-local: start-docker-test-deps
|
|
REGENERATE_GOLDENFILES=1 cargo test
|
|
|
|
# run the engine using schema from tests
|
|
run-local: start-docker-test-deps start-docker-run-deps
|
|
RUST_LOG=DEBUG cargo run --bin engine -- \
|
|
--otlp-endpoint http://localhost:4317 \
|
|
--authn-config-path auth_config.json \
|
|
--metadata-path crates/engine/tests/schema.json
|