diff options
| author | Samuel O'Brien <sam.obrien@ni.com> | 2020-07-01 09:00:53 -0500 | 
|---|---|---|
| committer | Aaron Rossetto <aaron.rossetto@ni.com> | 2020-07-16 09:59:25 -0500 | 
| commit | 9a75dcf3a3c0f71b49b4d2a7a7f154d008979159 (patch) | |
| tree | 42f84d5d052739f6ea04219ee49081e14724c1a2 | |
| parent | 919a147afcbecace5107a4d0a4da556cfd56df92 (diff) | |
| download | uhd-9a75dcf3a3c0f71b49b4d2a7a7f154d008979159.tar.gz uhd-9a75dcf3a3c0f71b49b4d2a7a7f154d008979159.tar.bz2 uhd-9a75dcf3a3c0f71b49b4d2a7a7f154d008979159.zip | |
python: Document CHDR Test Generation
The script_test.py script is used to generate data .cpp files from a
wireshark trace for the C++ CHDR Parser tests. This commit expands the
script to also generate the data .py files for the Python CHDR Parser
tests.
Signed-off-by: Samuel O'Brien <sam.obrien@ni.com>
| -rw-r--r-- | host/tests/common/chdr_resource/README.md | 2 | ||||
| -rwxr-xr-x | host/tests/common/chdr_resource/format_trace.py | 61 | 
2 files changed, 44 insertions, 19 deletions
| diff --git a/host/tests/common/chdr_resource/README.md b/host/tests/common/chdr_resource/README.md index 5664cd132..869b7cb5f 100644 --- a/host/tests/common/chdr_resource/README.md +++ b/host/tests/common/chdr_resource/README.md @@ -21,4 +21,4 @@ It contains many Data packets, as well as some Stream Status and Stream Command  5. Save the trace with a descriptive name in the `host/tests/common/chdr_resource` directory as a `.c` file  6. In the `host/tests/common/chdr_resource` directory, run `./format_trace.py {filename}`, where `{filename}` is the name of the `.c` file you save the trace as. -This will create a `.cpp` file of the same name, which contains the trace data inside a namespace matching the filename. The trace can now be accessed in unit tests with `#include <chdr_resource/{filename}.cpp>`. +This will create a `.cpp` file and a `.py` file of the same name, which contains the trace data inside a namespace matching the filename. The trace can now be accessed in unit tests with `#include <chdr_resource/{filename}.cpp>` in C++ and `from chdr_resource import {filename}` in Python. diff --git a/host/tests/common/chdr_resource/format_trace.py b/host/tests/common/chdr_resource/format_trace.py index 37659668c..ebaa75f70 100755 --- a/host/tests/common/chdr_resource/format_trace.py +++ b/host/tests/common/chdr_resource/format_trace.py @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright 2017 Ettus Research, a National Instruments Company +# Copyright 2020 Ettus Research, a National Instruments Brand  #  # SPDX-License-Identifier: GPL-3.0-or-later  # @@ -10,20 +10,21 @@ import re  if len(sys.argv) < 2:      print("Please supply an input filename!") -    exit() +    sys.exit()  input_arg = sys.argv[1]  filename_pat = re.compile(r"(.*)\.c")  m = filename_pat.match(input_arg)  if not m:      print("Please supply a .c file as input!") -    exit() +    sys.exit()  filename = m.group(1)  input_file = open(filename + ".c", "r") -output_file = open(filename + ".cpp", "w") +cpp_file = open(filename + ".cpp", "w") +python_file = open(filename + ".py", "w") -output_header = """// +OUTPUT_HEADER_CPP = """//  // Copyright 2020 Ettus Research, a National Instruments Brand  //  // SPDX-License-Identifier: GPL-3.0-or-later @@ -33,6 +34,14 @@ output_header = """//  """ +OUTPUT_HEADER_PYTHON = """# +# Copyright 2020 Ettus Research, a National Instruments Company +# +# SPDX-License-Identifier: GPL-3.0-or-later +# + +""" +  # Matches a line defining a new packet, e.g  # char peer1_19[] = { /* Packet 3153 */  # Group 1 is the array name, e.g. "peer1_19" @@ -40,7 +49,7 @@ output_header = """//  define_pat = re.compile(r"^char (peer[0|1]_\d+)\[\] = \{ \/\* (Packet \d+) \*\/$")  # Matches a line in the middle of a packet or at the end, e.g. -# 0x01, 0x00, 0x18, 0x00, 0x02, 0x00, 0x80, 0x00,  +# 0x01, 0x00, 0x18, 0x00, 0x02, 0x00, 0x80, 0x00,  # 0x08, 0x00, 0x0f, 0x00 };  # No groups, use full match  other_pat = re.compile(r"^((?:0x[0-9a-f]{2}, )*(?:0x[0-9a-f]{2}))(?: \};|, )$") @@ -48,8 +57,10 @@ other_pat = re.compile(r"^((?:0x[0-9a-f]{2}, )*(?:0x[0-9a-f]{2}))(?: \};|, )$")  # Used to seperate the two parties in the conversation (peer0 and peer1)  var_sort_pat = re.compile(r"^peer0_\d+$") -output_file.write(output_header) -output_file.write("namespace {} {{\n\n".format(filename)) +cpp_file.write(OUTPUT_HEADER_CPP) +cpp_file.write("namespace {} {{\n\n".format(filename)) + +python_file.write(OUTPUT_HEADER_PYTHON)  var_names_peer_0 = []  var_names_peer_1 = [] @@ -60,7 +71,8 @@ while True:          break      m = define_pat.match(line)      if m: -        output_file.write("uint8_t {}[] = {{ // {}\n".format(m.group(1), m.group(2))) +        cpp_file.write("uint8_t {}[] = {{ // {}\n".format(m.group(1), m.group(2))) +        python_file.write("{} = bytes([ # {}\n".format(m.group(1), m.group(2)))          var_sort_match = var_sort_pat.match(m.group(1))          if var_sort_match:              var_names_peer_0.append(m.group(1)) @@ -69,18 +81,31 @@ while True:          continue      m = other_pat.match(line)      if m: -        output_file.write(line) +        cpp_file.write(line) +        python_file.write(line.replace("};", "])"))          continue      print("Encountered unexpected line:\n{}".format(line)) -    exit() +    sys.exit()  for peer_name, var_names in [("peer0", var_names_peer_0), ("peer1", var_names_peer_1)]: -    output_file.write("\n") -    output_file.write("size_t {}_len = {};\n".format(peer_name, len(var_names))) -    output_file.write("std::tuple<uint8_t*, size_t> {}[] = {{\n".format(peer_name)) +    cpp_file.write("\n") +    cpp_file.write("size_t {}_len = {};\n".format(peer_name, len(var_names))) +    cpp_file.write("std::tuple<uint8_t*, size_t> {}[] = {{\n".format(peer_name)) + +    python_file.write("\n") +    python_file.write("{} = [\n\t".format(peer_name)) +      for var_name in var_names: -        output_file.write("\tstd::make_tuple({0}, sizeof({0})),\n".format(var_name)) -    output_file.write("};\n") +        cpp_file.write("\tstd::make_tuple({0}, sizeof({0})),\n".format(var_name)) +    cpp_file.write("};\n") + +    for i, var_name in enumerate(var_names): +        python_file.write(var_name) +        if i + 1 < len(var_names): +            python_file.write(",\t") +            if (i + 1) % 10 == 0: +                python_file.write("\n\t") +    python_file.write("\n]\n") -output_file.write("\n") -output_file.write("}} // namespace {}\n".format(filename)) +cpp_file.write("\n") +cpp_file.write("}} // namespace {}\n".format(filename)) | 
