Merge pull request #11838 from ncteisen/tracer-sanity

Tracer Sanity
pull/11848/head
Noah Eisen 8 years ago committed by GitHub
commit 64977778bf
  1. 3
      doc/environment_variables.md
  2. 46
      tools/run_tests/sanity/check_tracer_sanity.py
  3. 1
      tools/run_tests/sanity/sanity_tests.yaml

@ -54,6 +54,7 @@ some configuration as environment variables that can be set.
- op_failure - traces error information when failure is pushed onto a
completion queue
- round_robin - traces the round_robin load balancing policy
- pick_first - traces the pick first load balancing policy
- resource_quota - trace resource quota objects internals
- glb - traces the grpclb load balancer
- queue_pluck
@ -64,6 +65,7 @@ some configuration as environment variables that can be set.
- timer_check - more detailed trace of timer logic in grpc internals
- transport_security - traces metadata about secure channel establishment
- tcp - traces bytes in and out of a channel
- tsi - traces tsi transport security
The following tracers will only run in binaries built in DEBUG mode. This is
accomplished by invoking `CONFIG=dbg make <target>`
@ -76,6 +78,7 @@ some configuration as environment variables that can be set.
- stream_refcount
- workqueue_refcount
- fd_refcount
- cq_refcount
- auth_context_refcount
- security_connector_refcount
- resolver_refcount

@ -0,0 +1,46 @@
#!/usr/bin/env python
# Copyright 2017 gRPC authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from __future__ import print_function
import os
import sys
import re
os.chdir(os.path.join(os.path.dirname(sys.argv[0]), '../../..'))
errors = 0
tracers = []
pattern = re.compile("GRPC_TRACER_INITIALIZER\((true|false), \"(.*)\"\)")
for root, dirs, files in os.walk('src/core'):
for filename in files:
path = os.path.join(root, filename)
if os.path.splitext(path)[1] != '.c': continue
with open(path) as f:
text = f.read()
for o in pattern.findall(text):
tracers.append(o[1])
with open('doc/environment_variables.md') as f:
text = f.read()
for t in tracers:
if t not in text:
print("ERROR: tracer \"%s\" is not mentioned in doc/environment_variables.md" % t)
errors += 1
assert errors == 0

@ -4,6 +4,7 @@
- script: tools/run_tests/sanity/check_sources_and_headers.py
- script: tools/run_tests/sanity/check_submodules.sh
- script: tools/run_tests/sanity/check_test_filtering.py
- script: tools/run_tests/sanity/check_tracer_sanity.py
- script: tools/run_tests/sanity/core_banned_functions.py
- script: tools/buildgen/generate_projects.sh -j 3
cpu_cost: 3

Loading…
Cancel
Save