Add many fields struct stress test
authorMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Sun, 16 Nov 2014 15:56:55 +0000 (16:56 +0100)
committerMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Sun, 16 Nov 2014 15:56:55 +0000 (16:56 +0100)
Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
tests/1.8/stress/stream/pass/struct-many-fields/param-list.txt [new file with mode: 0644]
tests/1.8/stress/stream/pass/struct-many-fields/test.py [new file with mode: 0755]

diff --git a/tests/1.8/stress/stream/pass/struct-many-fields/param-list.txt b/tests/1.8/stress/stream/pass/struct-many-fields/param-list.txt
new file mode 100644 (file)
index 0000000..6531ad1
--- /dev/null
@@ -0,0 +1,8 @@
+524288
+1048576
+2097152
+4194304
+8388608
+16777216
+33554432
+67108864
diff --git a/tests/1.8/stress/stream/pass/struct-many-fields/test.py b/tests/1.8/stress/stream/pass/struct-many-fields/test.py
new file mode 100755 (executable)
index 0000000..d4e4a26
--- /dev/null
@@ -0,0 +1,103 @@
+#!/usr/bin/env python3
+
+# Expects either "prepare" or "clean" argument
+
+import sys
+import os
+
+def arg_err():
+       print('Please specify "prepare <SIZE>" or "clean <SIZE>" as first argument.')
+       sys.exit(-1)
+
+if (len(sys.argv) <= 1):
+       arg_err()
+mode = sys.argv[1]
+if (len(sys.argv) <= 2):
+       arg_err()
+array_len = int(sys.argv[2])
+
+tracedir_name = './trace-' + str(array_len) + '/'
+output_metadata = tracedir_name + 'metadata'
+output_stream = tracedir_name + 'stream'
+
+
+def write_binary(f, arr):
+       f.write(bytes(arr))
+
+def generate_metadata(array_len):
+       # Generate metadata
+       metadata_str1 = \
+       ( '/* CTF 1.8 */\n'
+       '\n'
+       'typealias integer {{ size = 8; align = 8; signed = false; base = 10; }} := uint8_t;\n'
+       'typealias integer {{ size = 32; align = 32; signed = false; base = hex; }} := uint32_t;\n'
+       '\n'
+       'trace {{\n'
+       '       major = 0;\n'
+       '       minor = 0;\n'
+       '       uuid = "2a6422d0-6cee-11e0-8c08-cb07d7b3a564";\n'
+       '       byte_order = le;\n'
+       '       packet.header := struct {{\n'
+       '               uint32_t magic;\n'
+       '               uint8_t uuid[16];\n'
+       '       }};\n'
+       '}};\n'
+       '\n'
+       'event {{\n'
+       '       name = myevent;\n'
+       '       fields := struct {{\n').format()
+
+       metadata_str2 = \
+       '               uint8_t f{}; \n'
+
+       metadata_str3 = \
+       ( '     }};\n'
+       '}};\n').format()
+       metadata_f = open(output_metadata, 'w')
+       metadata_f.write(metadata_str1)
+       for i in range(array_len):
+               metadata_f.write(metadata_str2.format(i))
+       metadata_f.write(metadata_str3)
+       metadata_f.close()
+
+def generate_stream(array_len):
+       # Generate stream
+       stream_packet_header = [
+         0xC1, 0x1F, 0xFC, 0xC1,       # magic
+         0x2A, 0x64, 0x22, 0xD0, 0x6C, 0xEE, 0x11, 0xE0,
+         0x8C, 0x08, 0xCB, 0x07, 0xD7, 0xB3, 0xA5, 0x64, # uuid
+       ]
+       stream_f = open(output_stream, 'wb')
+       write_binary(stream_f, stream_packet_header)
+       # generate array as event content
+       os.ftruncate(stream_f.fileno(), len(stream_packet_header) + array_len)
+       stream_f.close()
+
+def test_prepare():
+       print('Preparing test for many field structure length ' + str(array_len) + ' fields')
+       os.mkdir(tracedir_name)
+       generate_metadata(array_len)
+       generate_stream(array_len)
+
+def test_clean():
+       print('Cleaning up test for many field structure length ' + str(array_len) + ' fields')
+       try:
+               os.remove(output_metadata)
+       except:
+               pass
+       try:
+               os.remove(output_stream)
+       except:
+               pass
+       try:
+               os.rmdir(tracedir_name)
+       except:
+               pass
+
+if (mode == "prepare"):
+       test_clean()
+       test_prepare()
+elif (mode == "clean"):
+       test_clean()
+else:
+       arg_err()
This page took 0.02405 seconds and 4 git commands to generate.