api: crchcecker ignore version < 1.0.0 and outside of src directory
- For check patchset ignore files outside of src directory - For check patchset ignore files that have version < 1.0.0 - fix Pylint warnings - Modify vppapigen_crc to include version in JSON output Type: fix Signed-off-by: Ole Troan <ot@cisco.com> Change-Id: I93f7bebeeaeedc19b2b1e5e135ea1035517d7f76 Signed-off-by: Ole Troan <ot@cisco.com>
This commit is contained in:
Ole Troan
committed by
Andrew Yourtchenko
parent
49d601a70f
commit
510aaa8911
@ -580,6 +580,7 @@ Binary API Compiler for Python
|
||||
I: vppapigen
|
||||
M: Ole Troan <otroan@employees.org>
|
||||
F: src/tools/vppapigen/
|
||||
F: extras/scripts/crcchecker.py
|
||||
|
||||
API trace tool
|
||||
I: vppapitrace
|
||||
|
2
Makefile
2
Makefile
@ -631,7 +631,7 @@ fixstyle:
|
||||
|
||||
.PHONY: checkstyle-api
|
||||
checkstyle-api:
|
||||
@extras/scripts/crcchecker.py --check-patch
|
||||
@extras/scripts/crcchecker.py --check-patchset
|
||||
|
||||
# necessary because Bug 1696324 - Update to python3.6 breaks PyYAML dependencies
|
||||
# Status: CLOSED CANTFIX
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -55,7 +55,7 @@ verify_check_patchset_fails
|
||||
|
||||
echo "TEST 7: Verify we can delete deprecated message"
|
||||
git commit -a -m "reset"
|
||||
cat >crccheck.api <<EOL
|
||||
cat >src/crccheck.api <<EOL
|
||||
option version="1.0.0";
|
||||
autoreply define crccheck
|
||||
{
|
||||
@ -63,22 +63,22 @@ autoreply define crccheck
|
||||
bool foo;
|
||||
};
|
||||
EOL
|
||||
git add crccheck.api
|
||||
git add src/crccheck.api
|
||||
git commit -m "deprecated api";
|
||||
# delete API
|
||||
cat >crccheck.api <<EOL
|
||||
cat >src/crccheck.api <<EOL
|
||||
option version="1.0.0";
|
||||
autoreply define crccheck_2
|
||||
{
|
||||
bool foo;
|
||||
};
|
||||
EOL
|
||||
git add crccheck.api
|
||||
git add src/crccheck.api
|
||||
git commit -m "deprecated api";
|
||||
extras/scripts/crcchecker.py --check-patchset
|
||||
|
||||
echo "TEST 7.1: Verify we can delete deprecated message (old/confused style)"
|
||||
cat >crccheck_dep.api <<EOL
|
||||
cat >src/crccheck_dep.api <<EOL
|
||||
option version="1.0.0";
|
||||
autoreply define crccheck
|
||||
{
|
||||
@ -86,31 +86,31 @@ autoreply define crccheck
|
||||
bool foo;
|
||||
};
|
||||
EOL
|
||||
git add crccheck_dep.api
|
||||
git add src/crccheck_dep.api
|
||||
git commit -m "deprecated api";
|
||||
# delete API
|
||||
cat >crccheck_dep.api <<EOL
|
||||
cat >src/crccheck_dep.api <<EOL
|
||||
option version="1.0.0";
|
||||
autoreply define crccheck_2
|
||||
{
|
||||
bool foo;
|
||||
};
|
||||
EOL
|
||||
git add crccheck_dep.api
|
||||
git add src/crccheck_dep.api
|
||||
git commit -m "deprecated api";
|
||||
extras/scripts/crcchecker.py --check-patchset
|
||||
|
||||
echo "TEST 8: Verify that we can not rename a non-deprecated message"
|
||||
sed -i -e 's/crccheck_2/crccheck_3/g' crccheck.api
|
||||
git add crccheck.api
|
||||
sed -i -e 's/crccheck_2/crccheck_3/g' src/crccheck.api
|
||||
git add src/crccheck.api
|
||||
git commit -m "renamed api";
|
||||
verify_check_patchset_fails
|
||||
# fix it.
|
||||
sed -i -e 's/crccheck_3/crccheck_2/g' crccheck.api
|
||||
sed -i -e 's/crccheck_3/crccheck_2/g' src/crccheck.api
|
||||
git commit -a --amend -m "empty commit after we renamed api back" --allow-empty
|
||||
|
||||
echo "TEST 9: Verify that the check fails if the changes are not committed"
|
||||
cat >>crccheck.api <<EOL
|
||||
cat >>src/crccheck.api <<EOL
|
||||
autoreply define crc_new_check_in_progress
|
||||
{
|
||||
option status="in_progress";
|
||||
@ -120,31 +120,31 @@ EOL
|
||||
verify_check_patchset_fails
|
||||
|
||||
echo "TEST10: Verify that the in-progress message can be added"
|
||||
git add crccheck.api
|
||||
git add src/crccheck.api
|
||||
git commit -m "added a new in-progress api";
|
||||
extras/scripts/crcchecker.py --check-patchset
|
||||
|
||||
echo "TEST11: Verify we can rename an in-progress API"
|
||||
sed -i -e 's/crc_new_check_in_progress/crc_new_check_in_progress_2/g' crccheck.api
|
||||
git add crccheck.api
|
||||
sed -i -e 's/crc_new_check_in_progress/crc_new_check_in_progress_2/g' src/crccheck.api
|
||||
git add src/crccheck.api
|
||||
git commit -m "renamed in-progress api";
|
||||
extras/scripts/crcchecker.py --check-patchset
|
||||
|
||||
echo "TEST11.1: Switch to new designation of in-progress API"
|
||||
sed -i -e 's/status="in_progress"/in_progress/g' crccheck.api
|
||||
git add crccheck.api
|
||||
sed -i -e 's/status="in_progress"/in_progress/g' src/crccheck.api
|
||||
git add src/crccheck.api
|
||||
git commit -m "new designation of in-progress api";
|
||||
extras/scripts/crcchecker.py --check-patchset
|
||||
|
||||
|
||||
echo "TEST12: Verify we can add a field to an in-progress API"
|
||||
sed -i -e 's/foobar;/foobar; bool new_baz;/g' crccheck.api
|
||||
git add crccheck.api
|
||||
sed -i -e 's/foobar;/foobar; bool new_baz;/g' src/crccheck.api
|
||||
git add src/crccheck.api
|
||||
git commit -m "new field added in in-progress api";
|
||||
extras/scripts/crcchecker.py --check-patchset
|
||||
|
||||
echo "TEST13: Verify we fail the check if the file can not be compiled"
|
||||
cat >crccheck2.api <<EOL
|
||||
cat >src/crccheck2.api <<EOL
|
||||
option version="0.0.1";
|
||||
autoreply define spot_the_error
|
||||
{
|
||||
@ -152,7 +152,7 @@ autoreply define spot_the_error
|
||||
bool something_important;
|
||||
};
|
||||
EOL
|
||||
git add crccheck2.api
|
||||
git add src/crccheck2.api
|
||||
git commit -m "a new message with a syntax error";
|
||||
verify_check_patchset_fails
|
||||
|
||||
@ -160,13 +160,13 @@ verify_check_patchset_fails
|
||||
git reset --hard HEAD~1
|
||||
|
||||
echo "TEST14: Verify we handle new .api file"
|
||||
cat >crccheck3.api <<EOL
|
||||
cat >src/crccheck3.api <<EOL
|
||||
autoreply define foo
|
||||
{
|
||||
bool bar;
|
||||
};
|
||||
EOL
|
||||
git add crccheck3.api
|
||||
git add src/crccheck3.api
|
||||
git commit -m "a new message in new file";
|
||||
extras/scripts/crcchecker.py --check-patchset
|
||||
|
||||
|
@ -10,9 +10,12 @@ process_imports = True
|
||||
def run(args, input_filename, s):
|
||||
j = {}
|
||||
major = 0
|
||||
minor = 0
|
||||
patch = 0
|
||||
if 'version' in s['Option']:
|
||||
v = s['Option']['version']
|
||||
(major, minor, patch) = v.split('.')
|
||||
j['_version'] = {'major': major, 'minor': minor, 'patch': patch}
|
||||
for t in s['Define']:
|
||||
j[t.name] = {'crc': f'{t.crc:#08x}', 'version': major,
|
||||
'options': t.options}
|
||||
|
@ -13,6 +13,7 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
option version="0.0.0";
|
||||
import "vnet/ip/ip_types.api";
|
||||
|
||||
autoreply define test_prefix {
|
||||
|
Reference in New Issue
Block a user