Add a test for includes without paths (#28532)
* Add a test for includes without paths * fix path * fix * Automated change: Fix sanity tests Co-authored-by: ctiller <ctiller@users.noreply.github.com>pull/28541/head
parent
98999225be
commit
e29bdfe4e8
7 changed files with 79 additions and 5 deletions
@ -0,0 +1,72 @@ |
|||||||
|
#!/usr/bin/env python3 |
||||||
|
|
||||||
|
# Copyright 2022 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. |
||||||
|
|
||||||
|
# Check for includes of the form `#include "bar.h"` - i.e. not including the subdirectory. We require instead `#include "foo/bar.h"`. |
||||||
|
|
||||||
|
import argparse |
||||||
|
import os |
||||||
|
import re |
||||||
|
import sys |
||||||
|
|
||||||
|
# find our home |
||||||
|
ROOT = os.path.abspath(os.path.join(os.path.dirname(sys.argv[0]), '../..')) |
||||||
|
os.chdir(ROOT) |
||||||
|
|
||||||
|
# parse command line |
||||||
|
argp = argparse.ArgumentParser(description='include guard checker') |
||||||
|
argp.add_argument('-f', '--fix', default=False, action='store_true') |
||||||
|
args = argp.parse_args() |
||||||
|
|
||||||
|
# error count |
||||||
|
errors = 0 |
||||||
|
|
||||||
|
CHECK_SUBDIRS = [ |
||||||
|
'src/core', |
||||||
|
'src/cpp', |
||||||
|
'test/core', |
||||||
|
'test/cpp', |
||||||
|
] |
||||||
|
|
||||||
|
for subdir in CHECK_SUBDIRS: |
||||||
|
for root, dirs, files in os.walk(subdir): |
||||||
|
for f in files: |
||||||
|
if f.endswith('.h') or f.endswith('.cc'): |
||||||
|
fpath = os.path.join(root, f) |
||||||
|
output = open(fpath, 'r').readlines() |
||||||
|
changed = False |
||||||
|
for (i, line) in enumerate(output): |
||||||
|
m = re.match(r'^#include "([^"]*)"(.*)', line) |
||||||
|
if not m: |
||||||
|
continue |
||||||
|
include = m.group(1) |
||||||
|
if '/' in include: |
||||||
|
continue |
||||||
|
expect_path = os.path.join(root, include) |
||||||
|
trailing = m.group(2) |
||||||
|
if not os.path.exists(expect_path): |
||||||
|
continue |
||||||
|
changed = True |
||||||
|
errors += 1 |
||||||
|
output[i] = '#include "{0}"{1}\n'.format( |
||||||
|
expect_path, trailing) |
||||||
|
print("Found naked include '{0}' in {1}".format( |
||||||
|
include, fpath)) |
||||||
|
if changed and args.fix: |
||||||
|
open(fpath, 'w').writelines(output) |
||||||
|
|
||||||
|
if errors > 0: |
||||||
|
print('{} errors found.'.format(errors)) |
||||||
|
sys.exit(1) |
Loading…
Reference in new issue