KEMBAR78
Update new_library.md by dvyukov · Pull Request #29 · google/oss-fuzz · GitHub
Skip to content

Conversation

dvyukov
Copy link
Contributor

@dvyukov dvyukov commented Oct 13, 2016

fix a typo

@mikea mikea merged commit 5f36ffd into master Oct 13, 2016
@mikea mikea deleted the dvyukov-patch-3 branch October 13, 2016 15:33
mhlakhani added a commit to mhlakhani/oss-fuzz that referenced this pull request Sep 25, 2019
The corresponding github issue has more detail on the problem.

This code is not in any meaningful state to be committed -- it contains a bunch of hacks I had to make to get the binary to build statically -- libunwind is linked in (via folly), and I had to make changes to include liblzma as well (which libunwind depends on) as well as fix some other unrelated cmake issues.

Reproduction instructions below.

First, build it with `python infra/helper.py build_fuzzers --sanitizer address proxygen`
Then, check the build (it will pass): `python infra/helper.py check_build proxygen`
Then, run the fuzzer: `python infra/helper.py run_fuzzer proxygen ProxygenHTTP1xFuzzer`

It will fail in about ~30 seconds with the below trace. If the fuzzer goes down another path, I've had it reproduce easily by pulling up the shell, running `base64 -d`, pushing that input to a file, and then running the fuzzer directly on that file.

```
terminating with uncaught exception of type folly::ConversionError: Non-digit character found: "OPY"
AddressSanitizer:DEADLYSIGNAL
=================================================================
==11==ERROR: AddressSanitizer: ABRT on unknown address 0x00000000000b (pc 0x7fc166eb7428 bp 0x000000000001 sp 0x7ffcff0a6c78 T0)
SCARINESS: 10 (signal)
    #0 0x7fc166eb7427 in gsignal (/lib/x86_64-linux-gnu/libc.so.6+0x35427)
    google#1 0x7fc166eb9029 in abort (/lib/x86_64-linux-gnu/libc.so.6+0x37029)
    google#2 0x9ab7fa in abort_message (/out/ProxygenHTTP1xFuzzer+0x9ab7fa)
    google#3 0x9b009d in demangling_terminate_handler() (/out/ProxygenHTTP1xFuzzer+0x9b009d)
    google#4 0x9ab282 in std::__terminate(void (*)()) (/out/ProxygenHTTP1xFuzzer+0x9ab282)
    google#5 0x9adebd in __cxxabiv1::call_terminate(bool, _Unwind_Exception*) (/out/ProxygenHTTP1xFuzzer+0x9adebd)
    google#6 0x9ade60 in __cxxabiv1::scan_eh_tab(__cxxabiv1::(anonymous namespace)::scan_results&, _Unwind_Action, bool, _Unwind_Exception*, _Unwind_Context*) (/out/ProxygenHTTP1xFuzzer+0x9ade60)
    google#7 0x9ad5c6 in __gxx_personality_v0 (/out/ProxygenHTTP1xFuzzer+0x9ad5c6)
    google#8 0x7fc16725c262 in _Unwind_RaiseException (/lib/x86_64-linux-gnu/libgcc_s.so.1+0x10262)
    google#9 0x9acfd6 in __cxa_throw (/out/ProxygenHTTP1xFuzzer+0x9acfd6)
    google#10 0x5cedab in void folly::throw_exception<folly::ConversionError>(folly::ConversionError&&) /src/proxygen/proxygen/_build/deps/include/folly/lang/Exception.h:36:3
    google#11 0x5eea03 in _ZZN5folly2toItEENSt3__19enable_ifIXntsr3std7is_sameINS_5RangeIPKcEET_EE5valueES7_E4typeES6_ENKUlNS_14ConversionCodeEE_clESA_ /src/proxygen/proxygen/_build/deps/include/folly/Conv.h:1581:26
    google#12 0x5eea03 in _ZN5folly15expected_detail30expected_detail_ExpectedHelper14ExpectedHelper12thenOrThrow_IRNS0_15ExpectedStorageINS_5RangeIPKcEENS_14ConversionCodeELNS0_11StorageTypeE1EEENS_6detail18CheckTrailingSpaceEZNS_2toItEENSt3__19enable_ifIXntsr3std7is_sameIS8_T_EE5valueESI_E4typeES8_EUlS9_E_NS_8ExpectedINS_4UnitES9_EEvLb0ELi0EEET2_OSI_OT0_OT1_ /src/proxygen/proxygen/_build/deps/include/folly/Expected.h:610:5
    google#13 0x5ed846 in _ZNR5folly8ExpectedINS_5RangeIPKcEENS_14ConversionCodeEE11thenOrThrowINS_6detail18CheckTrailingSpaceEZNS_2toItEENSt3__19enable_ifIXntsr3std7is_sameIS4_T_EE5valueESD_E4typeES4_EUlS5_E_EEDTclclsr3stdE7declvalISD_EEclL_ZNSB_7declvalIRS4_EEDTclsr3std3__1E9__declvalISD_ELi0EEEvEEEEOSD_OT0_ /src/proxygen/proxygen/_build/deps/include/folly/Expected.h:1226:16
    google#14 0x5ed846 in _ZN5folly2toItEENSt3__19enable_ifIXntsr3std7is_sameINS_5RangeIPKcEET_EE5valueES7_E4typeES6_ /src/proxygen/proxygen/_build/deps/include/folly/Conv.h:1579:8
    google#15 0x5ed445 in proxygen::ParseURL::parseAuthority() /src/proxygen/proxygen/lib/utils/ParseURL.cpp:155:15
    google#16 0x5ec5e9 in proxygen::ParseURL::parseNonFully() /src/proxygen/proxygen/lib/utils/ParseURL.cpp:140:8
    google#17 0x5ea87a in proxygen::ParseURL::parse() /src/proxygen/proxygen/lib/utils/ParseURL.cpp:96:5
    google#18 0x59a99c in proxygen::ParseURL::init(folly::Range<char const*>) /src/proxygen/proxygen/lib/utils/ParseURL.h:34:5
    google#19 0x58add1 in proxygen::ParseURL::ParseURL(folly::Range<char const*>) /src/proxygen/proxygen/lib/utils/ParseURL.h:28:5
    google#20 0x58add1 in proxygen::ParseURL proxygen::HTTPMessage::setURL<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > >(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> >&&) /src/proxygen/proxygen/lib/http/HTTPMessage.h:202:14
    google#21 0x5795f0 in proxygen::HTTP1xCodec::onHeadersComplete(unsigned long) /src/proxygen/proxygen/lib/http/codec/HTTP1xCodec.cpp:976:31
    google#22 0x58e2a3 in proxygen::HTTP1xCodec::onHeadersCompleteCB(proxygen::http_parser*, char const*, unsigned long) /src/proxygen/proxygen/lib/http/codec/HTTP1xCodec.cpp:1315:19
    google#23 0x5f2222 in proxygen::http_parser_execute(proxygen::http_parser*, proxygen::http_parser_settings const*, char const*, unsigned long) /src/proxygen/proxygen/external/http_parser/http_parser_cpp.cpp:1868:17
    google#24 0x577783 in proxygen::HTTP1xCodec::onIngress(folly::IOBuf const&) /src/proxygen/proxygen/lib/http/codec/HTTP1xCodec.cpp:200:26
    google#25 0x55b728 in unsigned long proxygen::parse<proxygen::HTTP1xCodec>(proxygen::HTTP1xCodec*, unsigned char const*, unsigned int, int, std::__1::function<bool ()>) /src/proxygen/proxygen/lib/http/codec/test/TestUtils.h:57:23
    google#26 0x55a6ef in LLVMFuzzerTestOneInput /src/proxygen/proxygen/fuzzers/ProxygenHTTP1xFuzzer.cpp:23:3
    google#27 0x460771 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm/projects/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:554:15
    google#28 0x45fe95 in fuzzer::Fuzzer::RunOne(unsigned char const*, unsigned long, bool, fuzzer::InputInfo*, bool*) /src/llvm/projects/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:470:3
    google#29 0x462247 in fuzzer::Fuzzer::MutateAndTestOne() /src/llvm/projects/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:696:19
    google#30 0x462fe5 in fuzzer::Fuzzer::Loop(std::Fuzzer::vector<fuzzer::SizedFile, fuzzer::fuzzer_allocator<fuzzer::SizedFile> >&) /src/llvm/projects/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:832:5
    google#31 0x450dd8 in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm/projects/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:825:6
    google#32 0x47b442 in main /src/llvm/projects/compiler-rt/lib/fuzzer/FuzzerMain.cpp:19:10
    google#33 0x7fc166ea282f in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x2082f)
    google#34 0x424468 in _start (/out/ProxygenHTTP1xFuzzer+0x424468)

AddressSanitizer can not provide additional info.
SUMMARY: AddressSanitizer: ABRT (/lib/x86_64-linux-gnu/libc.so.6+0x35427) in gsignal
==11==ABORTING
MS: 3 CrossOver-ChangeBit-EraseBytes-; base unit: 467e3fbf38770044dea566169b84c60cb269c89a
0x43,0x4f,0x50,0x59,0x20,0x43,0x3a,0x4f,0x50,0x59,0x2f,0x4f,0xff,0xa,0x43,0x4f,0x50,0x59,0x20,0x2f,0x4f,0xff,0xa,0x43,0x4f,0x50,0x59,0x20,0x2f,0x6f,0x20,0xff,0x50,0x59,0x0,0x43,0xcf,0x50,0x59,0xff,0x4f,0x50,0x33,
COPY C:OPY/O\xff\x0aCOPY /O\xff\x0aCOPY /o \xffPY\x00C\xcfPY\xffOP3
artifact_prefix='./'; Test unit written to ./crash-2cd12847d55ebf08ec2eaee4e814c52e545e7f92
Base64: Q09QWSBDOk9QWS9P/wpDT1BZIC9P/wpDT1BZIC9vIP9QWQBDz1BZ/09QMw==
```

This seems wrong to me since the code is inside a try/catch block: https://github.com/facebook/proxygen/blob/master/proxygen/lib/utils/ParseURL.cpp#L159-L164

I can confirm that the same input does not crash the fuzzer in the version being built on oss-fuzz trunk (and indeed it would have also reported this as a test-case by now given it's been running over a day)
DavidKorczynski pushed a commit that referenced this pull request Jul 7, 2025
Output from `infra/experimental/chronos/check_tests.sh libssh c`:

```
Running tests...
Test project /work/build
      Start  1: torture_bignum
 1/40 Test  #1: torture_bignum ......................   Passed    0.01 sec
      Start  2: torture_buffer
 2/40 Test  #2: torture_buffer ......................   Passed    0.79 sec
      Start  3: torture_bytearray
 3/40 Test  #3: torture_bytearray ...................   Passed    0.01 sec
      Start  4: torture_callbacks
 4/40 Test  #4: torture_callbacks ...................   Passed    0.01 sec
      Start  5: torture_crypto
 5/40 Test  #5: torture_crypto ......................   Passed    0.01 sec
      Start  6: torture_init
 6/40 Test  #6: torture_init ........................   Passed    0.01 sec
      Start  7: torture_list
 7/40 Test  #7: torture_list ........................   Passed    0.01 sec
      Start  8: torture_misc
 8/40 Test  #8: torture_misc ........................   Passed    0.29 sec
      Start  9: torture_config
 9/40 Test  #9: torture_config ......................   Passed    0.03 sec
      Start 10: torture_options
10/40 Test #10: torture_options .....................   Passed    0.18 sec
      Start 11: torture_isipaddr
11/40 Test #11: torture_isipaddr ....................   Passed    0.01 sec
      Start 12: torture_knownhosts_parsing
12/40 Test #12: torture_knownhosts_parsing ..........   Passed    0.03 sec
      Start 13: torture_hashes
13/40 Test #13: torture_hashes ......................   Passed    0.01 sec
      Start 14: torture_packet_filter
14/40 Test #14: torture_packet_filter ...............   Passed    0.03 sec
      Start 15: torture_temp_dir
15/40 Test #15: torture_temp_dir ....................   Passed    0.01 sec
      Start 16: torture_temp_file
16/40 Test #16: torture_temp_file ...................   Passed    0.01 sec
      Start 17: torture_push_pop_dir
17/40 Test #17: torture_push_pop_dir ................   Passed    0.01 sec
      Start 18: torture_session_keys
18/40 Test #18: torture_session_keys ................   Passed    0.01 sec
      Start 19: torture_string
19/40 Test #19: torture_string ......................   Passed    0.01 sec
      Start 20: torture_tokens
20/40 Test #20: torture_tokens ......................   Passed    0.01 sec
      Start 21: torture_packet
21/40 Test #21: torture_packet ......................   Passed    0.40 sec
      Start 22: torture_keyfiles
22/40 Test #22: torture_keyfiles ....................   Passed    0.02 sec
      Start 23: torture_pki
23/40 Test #23: torture_pki .........................   Passed    0.87 sec
      Start 24: torture_pki_rsa
24/40 Test #24: torture_pki_rsa .....................   Passed    1.67 sec
      Start 25: torture_pki_dsa
25/40 Test #25: torture_pki_dsa .....................   Passed    0.02 sec
      Start 26: torture_pki_ed25519
26/40 Test #26: torture_pki_ed25519 .................   Passed    1.39 sec
      Start 27: torture_channel
27/40 Test #27: torture_channel .....................   Passed    0.01 sec
      Start 28: torture_config_match_localnetwork
28/40 Test #28: torture_config_match_localnetwork ...   Passed    0.01 sec
      Start 29: torture_bind_config
29/40 Test #29: torture_bind_config .................   Passed    0.32 sec
      Start 30: torture_moduli
30/40 Test #30: torture_moduli ......................   Passed    0.01 sec
      Start 31: torture_pki_ecdsa
31/40 Test #31: torture_pki_ecdsa ...................   Passed    1.21 sec
      Start 32: torture_rand
32/40 Test #32: torture_rand ........................   Passed    2.18 sec
      Start 33: torture_threads_init
33/40 Test #33: torture_threads_init ................   Passed    0.02 sec
      Start 34: torture_threads_buffer
34/40 Test #34: torture_threads_buffer ..............   Passed   87.26 sec
      Start 35: torture_threads_crypto
35/40 Test #35: torture_threads_crypto ..............   Passed    0.05 sec
      Start 36: torture_threads_pki_rsa
36/40 Test #36: torture_threads_pki_rsa .............   Passed    3.34 sec
      Start 37: torture_unit_server
37/40 Test #37: torture_unit_server .................   Passed    0.01 sec
      Start 38: torture_server_x11
38/40 Test #38: torture_server_x11 ..................   Passed    0.10 sec
      Start 39: torture_forwarded_tcpip_callback
39/40 Test #39: torture_forwarded_tcpip_callback ....   Passed    0.28 sec
      Start 40: torture_server_direct_tcpip
40/40 Test #40: torture_server_direct_tcpip .........   Passed    0.20 sec
```

Signed-off-by: Adam Korczynski <adam@adalogics.com>
DavidKorczynski pushed a commit that referenced this pull request Jul 8, 2025
Results of `infra/experimental/chronos/check_tests.sh brotli c`:
```
Test project /src/brotli
      Start  1: roundtrip/tests/testdata/alice29.txt/1
 1/73 Test  #1: roundtrip/tests/testdata/alice29.txt/1 ........................   Passed    0.03 sec
      Start  2: roundtrip/tests/testdata/alice29.txt/6
 2/73 Test  #2: roundtrip/tests/testdata/alice29.txt/6 ........................   Passed    0.05 sec
      Start  3: roundtrip/tests/testdata/alice29.txt/9
 3/73 Test  #3: roundtrip/tests/testdata/alice29.txt/9 ........................   Passed    0.07 sec
      Start  4: roundtrip/tests/testdata/alice29.txt/11
 4/73 Test  #4: roundtrip/tests/testdata/alice29.txt/11 .......................   Passed    0.77 sec
      Start  5: roundtrip/tests/testdata/asyoulik.txt/1
 5/73 Test  #5: roundtrip/tests/testdata/asyoulik.txt/1 .......................   Passed    0.03 sec
      Start  6: roundtrip/tests/testdata/asyoulik.txt/6
 6/73 Test  #6: roundtrip/tests/testdata/asyoulik.txt/6 .......................   Passed    0.04 sec
      Start  7: roundtrip/tests/testdata/asyoulik.txt/9
 7/73 Test  #7: roundtrip/tests/testdata/asyoulik.txt/9 .......................   Passed    0.07 sec
      Start  8: roundtrip/tests/testdata/asyoulik.txt/11
 8/73 Test  #8: roundtrip/tests/testdata/asyoulik.txt/11 ......................   Passed    0.62 sec
      Start  9: roundtrip/tests/testdata/lcet10.txt/1
 9/73 Test  #9: roundtrip/tests/testdata/lcet10.txt/1 .........................   Passed    0.04 sec
      Start 10: roundtrip/tests/testdata/lcet10.txt/6
10/73 Test #10: roundtrip/tests/testdata/lcet10.txt/6 .........................   Passed    0.08 sec
      Start 11: roundtrip/tests/testdata/lcet10.txt/9
11/73 Test #11: roundtrip/tests/testdata/lcet10.txt/9 .........................   Passed    0.14 sec
      Start 12: roundtrip/tests/testdata/lcet10.txt/11
12/73 Test #12: roundtrip/tests/testdata/lcet10.txt/11 ........................   Passed    2.11 sec
      Start 13: roundtrip/tests/testdata/plrabn12.txt/1      
13/73 Test #13: roundtrip/tests/testdata/plrabn12.txt/1 .......................   Passed    0.05 sec
      Start 14: roundtrip/tests/testdata/plrabn12.txt/6
14/73 Test #14: roundtrip/tests/testdata/plrabn12.txt/6 .......................   Passed    0.09 sec
      Start 15: roundtrip/tests/testdata/plrabn12.txt/9
15/73 Test #15: roundtrip/tests/testdata/plrabn12.txt/9 .......................   Passed    0.19 sec
      Start 16: roundtrip/tests/testdata/plrabn12.txt/11
16/73 Test #16: roundtrip/tests/testdata/plrabn12.txt/11 ......................   Passed    2.19 sec
      Start 17: roundtrip/c/enc/encode.c/1
17/73 Test #17: roundtrip/c/enc/encode.c/1 ....................................   Passed    0.02 sec
      Start 18: roundtrip/c/enc/encode.c/6
18/73 Test #18: roundtrip/c/enc/encode.c/6 ....................................   Passed    0.03 sec
      Start 19: roundtrip/c/enc/encode.c/9
19/73 Test #19: roundtrip/c/enc/encode.c/9 ....................................   Passed    0.04 sec
      Start 20: roundtrip/c/enc/encode.c/11
20/73 Test #20: roundtrip/c/enc/encode.c/11 ...................................   Passed    0.35 sec
      Start 21: roundtrip/c/common/dictionary.h/1
21/73 Test #21: roundtrip/c/common/dictionary.h/1 .............................   Passed    0.02 sec
      Start 22: roundtrip/c/common/dictionary.h/6
22/73 Test #22: roundtrip/c/common/dictionary.h/6 .............................   Passed    0.02 sec
      Start 23: roundtrip/c/common/dictionary.h/9
23/73 Test #23: roundtrip/c/common/dictionary.h/9 .............................   Passed    0.02 sec
      Start 24: roundtrip/c/common/dictionary.h/11
24/73 Test #24: roundtrip/c/common/dictionary.h/11 ............................   Passed    0.04 sec
      Start 25: roundtrip/c/dec/decode.c/1
25/73 Test #25: roundtrip/c/dec/decode.c/1 ....................................   Passed    0.02 sec
      Start 26: roundtrip/c/dec/decode.c/6
26/73 Test #26: roundtrip/c/dec/decode.c/6 ....................................   Passed    0.03 sec
      Start 27: roundtrip/c/dec/decode.c/9
27/73 Test #27: roundtrip/c/dec/decode.c/9 ....................................   Passed    0.05 sec
      Start 28: roundtrip/c/dec/decode.c/11
28/73 Test #28: roundtrip/c/dec/decode.c/11 ...................................   Passed    0.49 sec
      Start 29: compatibility/tests/testdata/10x10y.compressed
29/73 Test #29: compatibility/tests/testdata/10x10y.compressed ................   Passed    0.01 sec
      Start 30: compatibility/tests/testdata/64x.compressed
30/73 Test #30: compatibility/tests/testdata/64x.compressed ...................   Passed    0.01 sec
      Start 31: compatibility/tests/testdata/alice29.txt.compressed
31/73 Test #31: compatibility/tests/testdata/alice29.txt.compressed ...........   Passed    0.02 sec
      Start 32: compatibility/tests/testdata/asyoulik.txt.compressed
32/73 Test #32: compatibility/tests/testdata/asyoulik.txt.compressed ..........   Passed    0.01 sec
      Start 33: compatibility/tests/testdata/backward65536.compressed
33/73 Test #33: compatibility/tests/testdata/backward65536.compressed .........   Passed    0.01 sec
      Start 34: compatibility/tests/testdata/compressed_file.compressed
34/73 Test #34: compatibility/tests/testdata/compressed_file.compressed .......   Passed    0.01 sec
      Start 35: compatibility/tests/testdata/compressed_repeated.compressed
35/73 Test #35: compatibility/tests/testdata/compressed_repeated.compressed ...   Passed    0.01 sec
      Start 36: compatibility/tests/testdata/cp1251-utf16le.compressed
36/73 Test #36: compatibility/tests/testdata/cp1251-utf16le.compressed ........   Passed    0.01 sec
      Start 37: compatibility/tests/testdata/cp852-utf8.compressed
37/73 Test #37: compatibility/tests/testdata/cp852-utf8.compressed ............   Passed    0.01 sec
      Start 38: compatibility/tests/testdata/empty.compressed
38/73 Test #38: compatibility/tests/testdata/empty.compressed .................   Passed    0.01 sec
      Start 39: compatibility/tests/testdata/empty.compressed.00
39/73 Test #39: compatibility/tests/testdata/empty.compressed.00 ..............   Passed    0.01 sec
      Start 40: compatibility/tests/testdata/empty.compressed.01
40/73 Test #40: compatibility/tests/testdata/empty.compressed.01 ..............   Passed    0.01 sec
      Start 41: compatibility/tests/testdata/empty.compressed.02
41/73 Test #41: compatibility/tests/testdata/empty.compressed.02 ..............   Passed    0.01 sec
      Start 42: compatibility/tests/testdata/empty.compressed.03
42/73 Test #42: compatibility/tests/testdata/empty.compressed.03 ..............   Passed    0.01 sec
      Start 43: compatibility/tests/testdata/empty.compressed.04
43/73 Test #43: compatibility/tests/testdata/empty.compressed.04 ..............   Passed    0.01 sec
      Start 44: compatibility/tests/testdata/empty.compressed.05
44/73 Test #44: compatibility/tests/testdata/empty.compressed.05 ..............   Passed    0.01 sec
      Start 45: compatibility/tests/testdata/empty.compressed.06
45/73 Test #45: compatibility/tests/testdata/empty.compressed.06 ..............   Passed    0.01 sec
      Start 46: compatibility/tests/testdata/empty.compressed.07
46/73 Test #46: compatibility/tests/testdata/empty.compressed.07 ..............   Passed    0.01 sec
      Start 47: compatibility/tests/testdata/empty.compressed.08
47/73 Test #47: compatibility/tests/testdata/empty.compressed.08 ..............   Passed    0.01 sec
      Start 48: compatibility/tests/testdata/empty.compressed.09
48/73 Test #48: compatibility/tests/testdata/empty.compressed.09 ..............   Passed    0.01 sec
      Start 49: compatibility/tests/testdata/empty.compressed.10
49/73 Test #49: compatibility/tests/testdata/empty.compressed.10 ..............   Passed    0.01 sec
      Start 50: compatibility/tests/testdata/empty.compressed.11
50/73 Test #50: compatibility/tests/testdata/empty.compressed.11 ..............   Passed    0.01 sec
      Start 51: compatibility/tests/testdata/empty.compressed.12
51/73 Test #51: compatibility/tests/testdata/empty.compressed.12 ..............   Passed    0.01 sec
      Start 52: compatibility/tests/testdata/empty.compressed.13
52/73 Test #52: compatibility/tests/testdata/empty.compressed.13 ..............   Passed    0.01 sec
      Start 53: compatibility/tests/testdata/empty.compressed.14
53/73 Test #53: compatibility/tests/testdata/empty.compressed.14 ..............   Passed    0.01 sec
      Start 54: compatibility/tests/testdata/empty.compressed.15
54/73 Test #54: compatibility/tests/testdata/empty.compressed.15 ..............   Passed    0.01 sec
      Start 55: compatibility/tests/testdata/empty.compressed.16
55/73 Test #55: compatibility/tests/testdata/empty.compressed.16 ..............   Passed    0.01 sec
      Start 56: compatibility/tests/testdata/empty.compressed.17
56/73 Test #56: compatibility/tests/testdata/empty.compressed.17 ..............   Passed    0.03 sec
      Start 57: compatibility/tests/testdata/empty.compressed.18
57/73 Test #57: compatibility/tests/testdata/empty.compressed.18 ..............   Passed    0.04 sec
      Start 58: compatibility/tests/testdata/lcet10.txt.compressed
58/73 Test #58: compatibility/tests/testdata/lcet10.txt.compressed ............   Passed    0.02 sec
      Start 59: compatibility/tests/testdata/mapsdatazrh.compressed
59/73 Test #59: compatibility/tests/testdata/mapsdatazrh.compressed ...........   Passed    0.02 sec
      Start 60: compatibility/tests/testdata/monkey.compressed
60/73 Test #60: compatibility/tests/testdata/monkey.compressed ................   Passed    0.01 sec
      Start 61: compatibility/tests/testdata/plrabn12.txt.compressed
61/73 Test #61: compatibility/tests/testdata/plrabn12.txt.compressed ..........   Passed    0.02 sec
      Start 62: compatibility/tests/testdata/quickfox.compressed
62/73 Test #62: compatibility/tests/testdata/quickfox.compressed ..............   Passed    0.01 sec
      Start 63: compatibility/tests/testdata/quickfox_repeated.compressed
63/73 Test #63: compatibility/tests/testdata/quickfox_repeated.compressed .....   Passed    0.01 sec
      Start 64: compatibility/tests/testdata/random_org_10k.bin.compressed
64/73 Test #64: compatibility/tests/testdata/random_org_10k.bin.compressed ....   Passed    0.01 sec
      Start 65: compatibility/tests/testdata/ukkonooa.compressed
65/73 Test #65: compatibility/tests/testdata/ukkonooa.compressed ..............   Passed    0.01 sec
      Start 66: compatibility/tests/testdata/x.compressed
66/73 Test #66: compatibility/tests/testdata/x.compressed .....................   Passed    0.01 sec
      Start 67: compatibility/tests/testdata/x.compressed.00
67/73 Test #67: compatibility/tests/testdata/x.compressed.00 ..................   Passed    0.01 sec
      Start 68: compatibility/tests/testdata/x.compressed.01
68/73 Test #68: compatibility/tests/testdata/x.compressed.01 ..................   Passed    0.02 sec
      Start 69: compatibility/tests/testdata/x.compressed.02
69/73 Test #69: compatibility/tests/testdata/x.compressed.02 ..................   Passed    0.01 sec
      Start 70: compatibility/tests/testdata/x.compressed.03
70/73 Test #70: compatibility/tests/testdata/x.compressed.03 ..................   Passed    0.01 sec
      Start 71: compatibility/tests/testdata/xyzzy.compressed
71/73 Test #71: compatibility/tests/testdata/xyzzy.compressed .................   Passed    0.01 sec
      Start 72: compatibility/tests/testdata/zeros.compressed
72/73 Test #72: compatibility/tests/testdata/zeros.compressed .................   Passed    0.01 sec
      Start 73: compatibility/tests/testdata/zerosukkanooa.compressed
73/73 Test #73: compatibility/tests/testdata/zerosukkanooa.compressed .........   Passed    0.02 sec

100% tests passed, 0 tests failed out of 73

Total Test time (real) =   8.35 sec
```

Signed-off-by: Adam Korczynski <adam@adalogics.com>
DavidKorczynski pushed a commit that referenced this pull request Jul 9, 2025
Adds `run_tests.sh` for the libtiff project.

`run_tests.sh` is used as part of Chronos with cached builds:
https://github.com/google/oss-fuzz/tree/master/infra/experimental/chronos#check-tests

The last lines of `infra/experimental/chronos/check_tests.sh libtiff c`
are:

```
Running tests...
Test project /src/libtiff
        Start   1: test_signed_tags
  1/159 Test   #1: test_signed_tags ............................................   Passed    0.02 sec
        Start   2: ascii_tag
  2/159 Test   #2: ascii_tag ...................................................   Passed    0.01 sec
        Start   3: long_tag
  3/159 Test   #3: long_tag ....................................................   Passed    0.01 sec
        Start   4: short_tag
  4/159 Test   #4: short_tag ...................................................   Passed    0.01 sec
        Start   5: strip_rw
  5/159 Test   #5: strip_rw ....................................................   Passed    0.02 sec
        Start   6: rewrite
  6/159 Test   #6: rewrite .....................................................   Passed    0.02 sec
        Start   7: raw_decode
  7/159 Test   #7: raw_decode ..................................................   Passed    0.01 sec
        Start   8: custom_dir
  8/159 Test   #8: custom_dir ..................................................   Passed    0.01 sec
        Start   9: rational_precision2double
  9/159 Test   #9: rational_precision2double ...................................   Passed    0.02 sec
        Start  10: test_write_read_tags
 10/159 Test  #10: test_write_read_tags ........................................   Passed    0.03 sec
        Start  11: test_transferfunction_write_read
 11/159 Test  #11: test_transferfunction_write_read ............................   Passed    0.02 sec
        Start  12: custom_dir_EXIF_231
 12/159 Test  #12: custom_dir_EXIF_231 .........................................   Passed    0.02 sec
        Start  13: defer_strile_loading
 13/159 Test  #13: defer_strile_loading ........................................   Passed    0.33 sec
        Start  14: defer_strile_writing
 14/159 Test  #14: defer_strile_writing ........................................   Passed    0.02 sec
        Start  15: test_directory
 15/159 Test  #15: test_directory ..............................................   Passed    0.09 sec
        Start  16: test_IFD_enlargement
 16/159 Test  #16: test_IFD_enlargement ........................................   Passed    0.17 sec
        Start  17: testtypes
 17/159 Test  #17: testtypes ...................................................   Passed    0.01 sec
        Start  18: test_open_options
 18/159 Test  #18: test_open_options ...........................................   Passed    0.01 sec
        Start  19: test_append_to_strip
 19/159 Test  #19: test_append_to_strip ........................................   Passed    0.01 sec
        Start  20: test_ifd_loop_detection
 20/159 Test  #20: test_ifd_loop_detection .....................................   Passed    0.02 sec
        Start  21: test_RGBAImage
 21/159 Test  #21: test_RGBAImage ..............................................   Passed    3.89 sec
        Start  22: ppm2tiff-miniswhite-miniswhite-1c-1b
 22/159 Test  #22: ppm2tiff-miniswhite-miniswhite-1c-1b ........................   Passed    0.63 sec
        Start  23: ppm2tiff-minisblack-minisblack-1c-8b
 23/159 Test  #23: ppm2tiff-minisblack-minisblack-1c-8b ........................   Passed    0.02 sec
        Start  24: ppm2tiff-rgb-rgb-3c-16b
 24/159 Test  #24: ppm2tiff-rgb-rgb-3c-16b .....................................   Passed    0.02 sec
        Start  25: ppm2tiff-rgb-rgb-3c-8b
 25/159 Test  #25: ppm2tiff-rgb-rgb-3c-8b ......................................   Passed    0.02 sec
        Start  26: tiffcp-TIFFIMG-custom_dir_EXIF_GPS
 26/159 Test  #26: tiffcp-TIFFIMG-custom_dir_EXIF_GPS ..........................   Passed    0.02 sec
        Start  27: tiffcp-TIFFIMG-logluv-3c-16b
 27/159 Test  #27: tiffcp-TIFFIMG-logluv-3c-16b ................................   Passed    0.02 sec
        Start  28: tiffcp-TIFFIMG-minisblack-1c-16b
 28/159 Test  #28: tiffcp-TIFFIMG-minisblack-1c-16b ............................   Passed    0.03 sec
        Start  29: tiffcp-TIFFIMG-minisblack-1c-8b
 29/159 Test  #29: tiffcp-TIFFIMG-minisblack-1c-8b .............................   Passed    0.03 sec
        Start  30: tiffcp-TIFFIMG-minisblack-2c-8b-alpha
 30/159 Test  #30: tiffcp-TIFFIMG-minisblack-2c-8b-alpha .......................   Passed    0.02 sec
        Start  31: tiffcp-TIFFIMG-miniswhite-1c-1b
 31/159 Test  #31: tiffcp-TIFFIMG-miniswhite-1c-1b .............................   Passed    0.02 sec
        Start  32: tiffcp-TIFFIMG-palette-1c-1b
 32/159 Test  #32: tiffcp-TIFFIMG-palette-1c-1b ................................   Passed    0.02 sec
        Start  33: tiffcp-TIFFIMG-palette-1c-4b
 33/159 Test  #33: tiffcp-TIFFIMG-palette-1c-4b ................................   Passed    0.02 sec
        Start  34: tiffcp-TIFFIMG-palette-1c-8b
 34/159 Test  #34: tiffcp-TIFFIMG-palette-1c-8b ................................   Passed    0.02 sec
        Start  35: tiffcp-TIFFIMG-rgb-3c-16b
 35/159 Test  #35: tiffcp-TIFFIMG-rgb-3c-16b ...................................   Passed    0.02 sec
        Start  36: tiffcp-TIFFIMG-rgb-3c-8b
 36/159 Test  #36: tiffcp-TIFFIMG-rgb-3c-8b ....................................   Passed    0.02 sec
        Start  37: tiffcp-TIFFIMG-quad-lzw-compat
 37/159 Test  #37: tiffcp-TIFFIMG-quad-lzw-compat ..............................   Passed    0.04 sec
        Start  38: tiffcp-TIFFIMG-lzw-single-strip
 38/159 Test  #38: tiffcp-TIFFIMG-lzw-single-strip .............................   Passed    0.05 sec
        Start  39: tiffcp-TIFFIMG-testfax4
 39/159 Test  #39: tiffcp-TIFFIMG-testfax4 .....................................   Passed    0.05 sec
        Start  40: tiffcp-TIFFIMG-testfax3_bug_513
 40/159 Test  #40: tiffcp-TIFFIMG-testfax3_bug_513 .............................   Passed    0.02 sec
        Start  41: tiffcp-TIFFIMG-32bpp-None
 41/159 Test  #41: tiffcp-TIFFIMG-32bpp-None ...................................   Passed    0.02 sec
        Start  42: tiffcp-TIFFIMG-quad-tile
 42/159 Test  #42: tiffcp-TIFFIMG-quad-tile ....................................   Passed    0.03 sec
        Start  43: tiffcp-g3-miniswhite-1c-1b
 43/159 Test  #43: tiffcp-g3-miniswhite-1c-1b ..................................   Passed    0.01 sec
        Start  44: tiffcp-g31d-miniswhite-1c-1b
 44/159 Test  #44: tiffcp-g31d-miniswhite-1c-1b ................................   Passed    0.02 sec
        Start  45: tiffcp-g31dfill-miniswhite-1c-1b
 45/159 Test  #45: tiffcp-g31dfill-miniswhite-1c-1b ............................   Passed    0.01 sec
        Start  46: tiffcp-g32d-miniswhite-1c-1b
 46/159 Test  #46: tiffcp-g32d-miniswhite-1c-1b ................................   Passed    0.02 sec
        Start  47: tiffcp-g32dfill-miniswhite-1c-1b
 47/159 Test  #47: tiffcp-g32dfill-miniswhite-1c-1b ............................   Passed    0.01 sec
        Start  48: tiffcp-g4-miniswhite-1c-1b
 48/159 Test  #48: tiffcp-g4-miniswhite-1c-1b ..................................   Passed    0.02 sec
        Start  49: tiffcp-logluv-logluv-3c-16b
 49/159 Test  #49: tiffcp-logluv-logluv-3c-16b .................................   Passed    0.02 sec
        Start  50: tiffcp-thumbnail-miniswhite-1c-1b
 50/159 Test  #50: tiffcp-thumbnail-miniswhite-1c-1b ...........................   Passed    0.03 sec
        Start  51: tiffcp-none-quad-lzw-compat
 51/159 Test  #51: tiffcp-none-quad-lzw-compat .................................   Passed    0.02 sec
        Start  52: tiffcp-noner1-lzw-single-strip
 52/159 Test  #52: tiffcp-noner1-lzw-single-strip ..............................   Passed    0.03 sec
        Start  53: tiffcp-float64_lzw_2_le-test_float64_predictor2_le_lzw
 53/159 Test  #53: tiffcp-float64_lzw_2_le-test_float64_predictor2_le_lzw ......   Passed    0.01 sec
        Start  54: tiffcp-float64_lzw_2_be-test_float64_predictor2_be_lzw
 54/159 Test  #54: tiffcp-float64_lzw_2_be-test_float64_predictor2_be_lzw ......   Passed    0.01 sec
        Start  55: tiff2rgba-32BPP-32bpp-None
 55/159 Test  #55: tiff2rgba-32BPP-32bpp-None ..................................   Passed    0.02 sec
        Start  56: tiffcp-32BPP-JPEG-32bpp-None-jpeg
 56/159 Test  #56: tiffcp-32BPP-JPEG-32bpp-None-jpeg ...........................   Passed    0.02 sec
        Start  57: tiffcp-jbig-lzw-single-strip
 57/159 Test  #57: tiffcp-jbig-lzw-single-strip ................................   Passed    0.18 sec
        Start  58: tiffdump-miniswhite-1c-1b
 58/159 Test  #58: tiffdump-miniswhite-1c-1b ...................................   Passed    0.01 sec
        Start  59: tiffinfo-custom_dir_EXIF_GPS
 59/159 Test  #59: tiffinfo-custom_dir_EXIF_GPS ................................   Passed    0.02 sec
        Start  60: tiffinfo-minisblack-1c-16b
 60/159 Test  #60: tiffinfo-minisblack-1c-16b ..................................   Passed    0.02 sec
        Start  61: tiffinfo-tiff_with_subifd_chain
 61/159 Test  #61: tiffinfo-tiff_with_subifd_chain .............................   Passed    0.01 sec
        Start  62: tiffcp-split
 62/159 Test  #62: tiffcp-split ................................................   Passed    0.03 sec
        Start  63: tiffcp-split-join
 63/159 Test  #63: tiffcp-split-join ...........................................   Passed    0.04 sec
        Start  64: tiff2pdf-miniswhite-1c-1b
 64/159 Test  #64: tiff2pdf-miniswhite-1c-1b ...................................   Passed    0.02 sec
        Start  65: tiff2ps-miniswhite-1c-1b-ps-1
 65/159 Test  #65: tiff2ps-miniswhite-1c-1b-ps-1 ...............................   Passed    0.02 sec
        Start  66: tiff2ps-miniswhite-1c-1b-ps-2 
 66/159 Test  #66: tiff2ps-miniswhite-1c-1b-ps-2 ...............................   Passed    0.01 sec
        Start  67: tiff2ps-miniswhite-1c-1b-ps-3
 67/159 Test  #67: tiff2ps-miniswhite-1c-1b-ps-3 ...............................   Passed    0.02 sec
        Start  68: tiff2ps-miniswhite-1c-1b-eps-1     
 68/159 Test  #68: tiff2ps-miniswhite-1c-1b-eps-1 ..............................   Passed    0.01 sec
        Start  69: tiff2bw-default-palette-1c-8b       
 69/159 Test  #69: tiff2bw-default-palette-1c-8b ...............................   Passed    0.02 sec
        Start  70: tiff2bw-default-rgb-3c-8b   
 70/159 Test  #70: tiff2bw-default-rgb-3c-8b ...................................   Passed    0.02 sec
        Start  71: tiff2bw-default-quad-lzw-compat     
 71/159 Test  #71: tiff2bw-default-quad-lzw-compat .............................   Passed    0.03 sec
        Start  72: tiff2rgba-default-custom_dir_EXIF_GPS
 72/159 Test  #72: tiff2rgba-default-custom_dir_EXIF_GPS .......................   Passed    0.03 sec
        Start  73: tiff2rgba-default-logluv-3c-16b
 73/159 Test  #73: tiff2rgba-default-logluv-3c-16b .............................   Passed    0.02 sec
        Start  74: tiff2rgba-default-minisblack-1c-16b 
 74/159 Test  #74: tiff2rgba-default-minisblack-1c-16b .........................   Passed    0.03 sec
        Start  75: tiff2rgba-default-minisblack-1c-8b
 75/159 Test  #75: tiff2rgba-default-minisblack-1c-8b ..........................   Passed    0.02 sec
        Start  76: tiff2rgba-default-minisblack-2c-8b-alpha
 76/159 Test  #76: tiff2rgba-default-minisblack-2c-8b-alpha ....................   Passed    0.02 sec
        Start  77: tiff2rgba-default-miniswhite-1c-1b
 77/159 Test  #77: tiff2rgba-default-miniswhite-1c-1b ..........................   Passed    0.03 sec
        Start  78: tiff2rgba-default-palette-1c-1b        
 78/159 Test  #78: tiff2rgba-default-palette-1c-1b .............................   Passed    0.02 sec
        Start  79: tiff2rgba-default-palette-1c-4b  
 79/159 Test  #79: tiff2rgba-default-palette-1c-4b .............................   Passed    0.03 sec
        Start  80: tiff2rgba-default-palette-1c-8b
 80/159 Test  #80: tiff2rgba-default-palette-1c-8b .............................   Passed    0.03 sec
        Start  81: tiff2rgba-default-rgb-3c-16b  
 81/159 Test  #81: tiff2rgba-default-rgb-3c-16b ................................   Passed    0.03 sec
        Start  82: tiff2rgba-default-rgb-3c-8b   
 82/159 Test  #82: tiff2rgba-default-rgb-3c-8b .................................   Passed    0.03 sec
        Start  83: tiff2rgba-default-quad-lzw-compat
 83/159 Test  #83: tiff2rgba-default-quad-lzw-compat ...........................   Passed    0.04 sec
        Start  84: tiff2rgba-default-lzw-single-strip
 84/159 Test  #84: tiff2rgba-default-lzw-single-strip ..........................   Passed    0.39 sec
        Start  85: tiff2rgba-default-testfax4      
 85/159 Test  #85: tiff2rgba-default-testfax4 ..................................   Passed    0.19 sec
        Start  86: tiff2rgba-default-testfax3_bug_513
 86/159 Test  #86: tiff2rgba-default-testfax3_bug_513 ..........................   Passed    0.03 sec
        Start  87: tiff2rgba-default-32bpp-None
 87/159 Test  #87: tiff2rgba-default-32bpp-None ................................   Passed    0.02 sec
        Start  88: tiff2rgba-default-quad-tile      
 88/159 Test  #88: tiff2rgba-default-quad-tile .................................   Passed    0.04 sec
        Start  89: tiff2rgba-default-ojpeg_zackthecat_subsamp22_single_strip 
 89/159 Test  #89: tiff2rgba-default-ojpeg_zackthecat_subsamp22_single_strip ...   Passed    0.03 sec
        Start  90: tiff2rgba-default-ojpeg_chewey_subsamp21_multi_strip
 90/159 Test  #90: tiff2rgba-default-ojpeg_chewey_subsamp21_multi_strip ........   Passed    0.05 sec
        Start  91: tiff2rgba-default-ojpeg_single_strip_no_rowsperstrip
 91/159 Test  #91: tiff2rgba-default-ojpeg_single_strip_no_rowsperstrip ........   Passed    0.03 sec
        Start  92: tiffcrop-R90-custom_dir_EXIF_GPS 
 92/159 Test  #92: tiffcrop-R90-custom_dir_EXIF_GPS ............................   Passed    0.02 sec
        Start  93: tiffcrop-R90-logluv-3c-16b
 93/159 Test  #93: tiffcrop-R90-logluv-3c-16b ..................................   Passed    0.02 sec
        Start  94: tiffcrop-R90-minisblack-1c-16b
 94/159 Test  #94: tiffcrop-R90-minisblack-1c-16b ..............................   Passed    0.02 sec
        Start  95: tiffcrop-R90-minisblack-1c-8b
 95/159 Test  #95: tiffcrop-R90-minisblack-1c-8b ...............................   Passed    0.03 sec
        Start  96: tiffcrop-R90-minisblack-2c-8b-alpha 
 96/159 Test  #96: tiffcrop-R90-minisblack-2c-8b-alpha .........................   Passed    0.02 sec
        Start  97: tiffcrop-R90-miniswhite-1c-1b
 97/159 Test  #97: tiffcrop-R90-miniswhite-1c-1b ...............................   Passed    0.03 sec
        Start  98: tiffcrop-R90-palette-1c-1b
 98/159 Test  #98: tiffcrop-R90-palette-1c-1b ..................................   Passed    0.03 sec
        Start  99: tiffcrop-R90-palette-1c-4b
 99/159 Test  #99: tiffcrop-R90-palette-1c-4b ..................................   Passed    0.03 sec
        Start 100: tiffcrop-R90-palette-1c-8b
100/159 Test #100: tiffcrop-R90-palette-1c-8b ..................................   Passed    0.02 sec
        Start 101: tiffcrop-R90-rgb-3c-16b
101/159 Test #101: tiffcrop-R90-rgb-3c-16b .....................................   Passed    0.03 sec
        Start 102: tiffcrop-R90-rgb-3c-8b
102/159 Test #102: tiffcrop-R90-rgb-3c-8b ......................................   Passed    0.02 sec
        Start 103: tiffcrop-R90-quad-lzw-compat
103/159 Test #103: tiffcrop-R90-quad-lzw-compat ................................   Passed    0.04 sec
        Start 104: tiffcrop-R90-lzw-single-strip
104/159 Test #104: tiffcrop-R90-lzw-single-strip ...............................   Passed    0.21 sec
        Start 105: tiffcrop-R90-testfax4
105/159 Test #105: tiffcrop-R90-testfax4 .......................................   Passed    0.12 sec
        Start 106: tiffcrop-R90-testfax3_bug_513 
106/159 Test #106: tiffcrop-R90-testfax3_bug_513 ...............................   Passed    0.02 sec
        Start 107: tiffcrop-R90-32bpp-None
107/159 Test #107: tiffcrop-R90-32bpp-None .....................................   Passed    0.02 sec
        Start 108: tiffcrop-R90-quad-tile
108/159 Test #108: tiffcrop-R90-quad-tile ......................................   Passed    0.03 sec
        Start 109: tiffcrop-doubleflip-custom_dir_EXIF_GPS
109/159 Test #109: tiffcrop-doubleflip-custom_dir_EXIF_GPS .....................   Passed    0.02 sec
        Start 110: tiffcrop-doubleflip-logluv-3c-16b
110/159 Test #110: tiffcrop-doubleflip-logluv-3c-16b ...........................   Passed    0.02 sec
        Start 111: tiffcrop-doubleflip-minisblack-1c-16b
111/159 Test #111: tiffcrop-doubleflip-minisblack-1c-16b .......................   Passed    0.02 sec
        Start 112: tiffcrop-doubleflip-minisblack-1c-8b
112/159 Test #112: tiffcrop-doubleflip-minisblack-1c-8b ........................   Passed    0.02 sec
        Start 113: tiffcrop-doubleflip-minisblack-2c-8b-alpha
113/159 Test #113: tiffcrop-doubleflip-minisblack-2c-8b-alpha ..................   Passed    0.02 sec
        Start 114: tiffcrop-doubleflip-miniswhite-1c-1b
114/159 Test #114: tiffcrop-doubleflip-miniswhite-1c-1b ........................   Passed    0.03 sec
        Start 115: tiffcrop-doubleflip-palette-1c-1b
115/159 Test #115: tiffcrop-doubleflip-palette-1c-1b ...........................   Passed    0.02 sec
        Start 116: tiffcrop-doubleflip-palette-1c-4b
116/159 Test #116: tiffcrop-doubleflip-palette-1c-4b ...........................   Passed    0.03 sec
        Start 117: tiffcrop-doubleflip-palette-1c-8b
117/159 Test #117: tiffcrop-doubleflip-palette-1c-8b ...........................   Passed    0.02 sec
        Start 118: tiffcrop-doubleflip-rgb-3c-16b
118/159 Test #118: tiffcrop-doubleflip-rgb-3c-16b ..............................   Passed    0.03 sec
        Start 119: tiffcrop-doubleflip-rgb-3c-8b
119/159 Test #119: tiffcrop-doubleflip-rgb-3c-8b ...............................   Passed    0.02 sec
        Start 120: tiffcrop-doubleflip-quad-lzw-compat
120/159 Test #120: tiffcrop-doubleflip-quad-lzw-compat .........................   Passed    0.04 sec
        Start 121: tiffcrop-doubleflip-lzw-single-strip
121/159 Test #121: tiffcrop-doubleflip-lzw-single-strip ........................   Passed    0.21 sec
        Start 122: tiffcrop-doubleflip-testfax4
122/159 Test #122: tiffcrop-doubleflip-testfax4 ................................   Passed    0.11 sec
        Start 123: tiffcrop-doubleflip-testfax3_bug_513
123/159 Test #123: tiffcrop-doubleflip-testfax3_bug_513 ........................   Passed    0.02 sec
        Start 124: tiffcrop-doubleflip-32bpp-None
124/159 Test #124: tiffcrop-doubleflip-32bpp-None ..............................   Passed    0.03 sec
        Start 125: tiffcrop-doubleflip-quad-tile
125/159 Test #125: tiffcrop-doubleflip-quad-tile ...............................   Passed    0.03 sec
        Start 126: tiffcrop-extract-custom_dir_EXIF_GPS
126/159 Test #126: tiffcrop-extract-custom_dir_EXIF_GPS ........................   Passed    0.03 sec
        Start 127: tiffcrop-extract-logluv-3c-16b
127/159 Test #127: tiffcrop-extract-logluv-3c-16b ..............................   Passed    0.02 sec
        Start 128: tiffcrop-extract-minisblack-1c-16b
128/159 Test #128: tiffcrop-extract-minisblack-1c-16b ..........................   Passed    0.03 sec
        Start 129: tiffcrop-extract-minisblack-1c-8b
129/159 Test #129: tiffcrop-extract-minisblack-1c-8b ...........................   Passed    0.02 sec
        Start 130: tiffcrop-extract-minisblack-2c-8b-alpha
130/159 Test #130: tiffcrop-extract-minisblack-2c-8b-alpha .....................   Passed    0.02 sec
        Start 131: tiffcrop-extract-miniswhite-1c-1b
131/159 Test #131: tiffcrop-extract-miniswhite-1c-1b ...........................   Passed    0.03 sec
        Start 132: tiffcrop-extract-palette-1c-1b
132/159 Test #132: tiffcrop-extract-palette-1c-1b ..............................   Passed    0.02 sec
        Start 133: tiffcrop-extract-palette-1c-4b
133/159 Test #133: tiffcrop-extract-palette-1c-4b ..............................   Passed    0.02 sec
        Start 134: tiffcrop-extract-palette-1c-8b
134/159 Test #134: tiffcrop-extract-palette-1c-8b ..............................   Passed    0.02 sec
        Start 135: tiffcrop-extract-rgb-3c-16b
135/159 Test #135: tiffcrop-extract-rgb-3c-16b .................................   Passed    0.02 sec
        Start 136: tiffcrop-extract-rgb-3c-8b
136/159 Test #136: tiffcrop-extract-rgb-3c-8b ..................................   Passed    0.02 sec
        Start 137: tiffcrop-extract-quad-lzw-compat
137/159 Test #137: tiffcrop-extract-quad-lzw-compat ............................   Passed    0.03 sec
        Start 138: tiffcrop-extract-lzw-single-strip
138/159 Test #138: tiffcrop-extract-lzw-single-strip ...........................   Passed    0.03 sec
        Start 139: tiffcrop-extract-testfax4
139/159 Test #139: tiffcrop-extract-testfax4 ...................................   Passed    0.03 sec
        Start 140: tiffcrop-extract-testfax3_bug_513
140/159 Test #140: tiffcrop-extract-testfax3_bug_513 ...........................   Passed    0.02 sec
        Start 141: tiffcrop-extract-32bpp-None
141/159 Test #141: tiffcrop-extract-32bpp-None .................................   Passed    0.02 sec
        Start 142: tiffcrop-extract-quad-tile
142/159 Test #142: tiffcrop-extract-quad-tile ..................................   Passed    0.03 sec
        Start 143: tiffcrop-extractz14-custom_dir_EXIF_GPS
143/159 Test #143: tiffcrop-extractz14-custom_dir_EXIF_GPS .....................   Passed    0.02 sec
        Start 144: tiffcrop-extractz14-logluv-3c-16b
144/159 Test #144: tiffcrop-extractz14-logluv-3c-16b ...........................   Passed    0.02 sec
        Start 145: tiffcrop-extractz14-minisblack-1c-16b
145/159 Test #145: tiffcrop-extractz14-minisblack-1c-16b .......................   Passed    0.03 sec
        Start 146: tiffcrop-extractz14-minisblack-1c-8b
146/159 Test #146: tiffcrop-extractz14-minisblack-1c-8b ........................   Passed    0.02 sec
        Start 147: tiffcrop-extractz14-minisblack-2c-8b-alpha
147/159 Test #147: tiffcrop-extractz14-minisblack-2c-8b-alpha ..................   Passed    0.03 sec
        Start 148: tiffcrop-extractz14-miniswhite-1c-1b
148/159 Test #148: tiffcrop-extractz14-miniswhite-1c-1b ........................   Passed    0.02 sec
        Start 149: tiffcrop-extractz14-palette-1c-1b
149/159 Test #149: tiffcrop-extractz14-palette-1c-1b ...........................   Passed    0.02 sec
        Start 150: tiffcrop-extractz14-palette-1c-4b
150/159 Test #150: tiffcrop-extractz14-palette-1c-4b ...........................   Passed    0.02 sec
        Start 151: tiffcrop-extractz14-palette-1c-8b
151/159 Test #151: tiffcrop-extractz14-palette-1c-8b ...........................   Passed    0.02 sec
        Start 152: tiffcrop-extractz14-rgb-3c-16b
152/159 Test #152: tiffcrop-extractz14-rgb-3c-16b ..............................   Passed    0.02 sec
        Start 153: tiffcrop-extractz14-rgb-3c-8b
153/159 Test #153: tiffcrop-extractz14-rgb-3c-8b ...............................   Passed    0.03 sec
        Start 154: tiffcrop-extractz14-quad-lzw-compat
154/159 Test #154: tiffcrop-extractz14-quad-lzw-compat .........................   Passed    0.03 sec
        Start 155: tiffcrop-extractz14-lzw-single-strip
155/159 Test #155: tiffcrop-extractz14-lzw-single-strip ........................   Passed    0.18 sec
        Start 156: tiffcrop-extractz14-testfax4
156/159 Test #156: tiffcrop-extractz14-testfax4 ................................   Passed    0.09 sec
        Start 157: tiffcrop-extractz14-testfax3_bug_513
157/159 Test #157: tiffcrop-extractz14-testfax3_bug_513 ........................   Passed    0.02 sec
        Start 158: tiffcrop-extractz14-32bpp-None
158/159 Test #158: tiffcrop-extractz14-32bpp-None ..............................   Passed    0.02 sec
        Start 159: tiffcrop-extractz14-quad-tile
159/159 Test #159: tiffcrop-extractz14-quad-tile ...............................   Passed    0.03 sec

100% tests passed, 0 tests failed out of 159

Total Test time (real) =  10.33 sec
```

Signed-off-by: Adam Korczynski <adam@adalogics.com>
AdamKorcz pushed a commit that referenced this pull request Jul 13, 2025
run_tests.sh is used as part of Chronos with cached builds:
https://github.com/google/oss-fuzz/tree/master/infra/experimental/chronos#check-tests


```
$ ./infra/experimental/chronos/check_tests.sh brunsli c++

      Start 18: HuffmanTree.Limited                                                                                                                                                                          
18/29 Test #18: HuffmanTree.Limited ................................   Passed    0.01 sec                                                                                                                                                      
      Start 19: HuffmanTree.SimpleLiteral                                                                                                                                                                    
19/29 Test #19: HuffmanTree.SimpleLiteral ..........................   Passed    0.01 sec                                                                                                                                                      
      Start 20: HuffmanTree.StableBitDepth                                                                                                                                                                   
20/29 Test #20: HuffmanTree.StableBitDepth .........................   Passed    0.01 sec                                                                                                                                                      
      Start 21: HuffmanTree.ConvertBitDepthsToSymbols                                                                                                                                                        
21/29 Test #21: HuffmanTree.ConvertBitDepthsToSymbols ..............   Passed    0.01 sec                                                                                                                                                      
      Start 22: HuffmanTree.ConvertBitDepthsToSymbols2                                                                                                                                                       
22/29 Test #22: HuffmanTree.ConvertBitDepthsToSymbols2 .............   Passed    0.01 sec                                                                                                                                                      
      Start 23: HuffmanTree.WriteHuffmanTree                                                                                                                                                                 
23/29 Test #23: HuffmanTree.WriteHuffmanTree .......................   Passed    0.01 sec                                                                                                                                                      
      Start 24: HuffmanTree.WriteHuffmanTreeSparse                                                                                                                                                           
24/29 Test #24: HuffmanTree.WriteHuffmanTreeSparse .................   Passed    0.01 sec                                                                                                                                                      
      Start 25: HuffmanTree.WriteHuffmanTreeManyZeros                                                                                                                                                        
25/29 Test #25: HuffmanTree.WriteHuffmanTreeManyZeros ..............   Passed    0.01 sec                                                                                                                    
      Start 26: HuffmanTree.WriteHuffmanTreeShortStipeOfNonZeros                                                                                                                                             
26/29 Test #26: HuffmanTree.WriteHuffmanTreeShortStipeOfNonZeros ...   Passed    0.01 sec                                                                                                                                                      
      Start 27: HuffmanTree.WriteHuffmanTreeManyNonZeros                                                                                                                                                     
27/29 Test #27: HuffmanTree.WriteHuffmanTreeManyNonZeros ...........   Passed    0.01 sec                                                                                                                                                      
      Start 28: LehmerCodeTest.TestPermutation                                                                                                                                                               
28/29 Test #28: LehmerCodeTest.TestPermutation .....................   Passed    0.01 sec                                                                                                                                                      
      Start 29: QuantMatrixTest.TestFindQ                                                                              
29/29 Test #29: QuantMatrixTest.TestFindQ ..........................   Passed    0.01 sec                                                                                                                                                      

100% tests passed, 0 tests failed out of 29    
```

Signed-off-by: David Korczynski <david@adalogics.com>
DavidKorczynski pushed a commit that referenced this pull request Jul 17, 2025
Adds `run_tests.sh` to the libigl project.

`run_tests.sh` is used as part of Chronos with cached builds:
https://github.com/google/oss-fuzz/tree/master/infra/experimental/chronos#check-tests

Output of ./infra/experimental/chronos/check_tests.sh libigl c++:
```
Test project /src/libigl/build-dir
        Start   1: AABB: find_2d
        Start   2: AABB: find_3d
        Start   3: AABB: insert
        Start   4: AABB: dynamic
        Start   5: MshLoader
        Start   6: MshSaver
        Start   7: accumarray: matlab_help
        Start   8: accumarray: scalar
  1/214 Test   #3: AABB: insert ............................................   Passed    0.11 sec
        Start   9: adjacency_list: simple
  2/214 Test   #1: AABB: find_2d ...........................................   Passed    0.46 sec
        Start  10: avg_edge_length: cube
  3/214 Test   #2: AABB: find_3d ...........................................   Passed    0.14 sec
        Start  11: barycentric_interpolation: two-triangles
  4/214 Test   #8: accumarray: scalar ......................................   Passed    0.13 sec
        Start  12: bbw: decimated_knight
  5/214 Test   #7: accumarray: matlab_help .................................   Passed    0.14 sec
        Start  13: bezier: ease
  6/214 Test   #9: adjacency_list: simple ..................................   Passed    0.12 sec
        Start  14: blkdiag: 3-matrices
  7/214 Test  #13: bezier: ease ............................................   Passed    0.10 sec
        Start  15: boundary_facets: single_tet_volume
  8/214 Test  #11: barycentric_interpolation: two-triangles ................   Passed    0.13 sec
        Start  16: boundary_facets: single_tet
  9/214 Test   #5: MshLoader ...............................................   Passed    0.27 sec
        Start  17: boundary_facets: single_cube
 10/214 Test  #10: avg_edge_length: cube ...................................   Passed    0.16 sec
        Start  18: boundary_facets: non-manifold
 11/214 Test  #14: blkdiag: 3-matrices .....................................   Passed    0.10 sec
        Start  19: boundary_loop: cube
 12/214 Test  #17: boundary_facets: single_cube ............................   Passed    0.10 sec
        Start  20: boundary_loop: bunny
 13/214 Test  #18: boundary_facets: non-manifold ...........................   Passed    0.11 sec
        Start  21: cat: rows
 14/214 Test  #15: boundary_facets: single_tet_volume ......................   Passed    0.15 sec
        Start  22: cat: cols
 15/214 Test  #16: boundary_facets: single_tet .............................   Passed    0.15 sec
        Start  23: centroid: 
 16/214 Test   #6: MshSaver ................................................   Passed    0.45 sec
        Start  24: circulation: single_edge
 17/214 Test  #19: boundary_loop: cube .....................................   Passed    0.15 sec
        Start  25: circumradius: equilateral-triangle
 18/214 Test  #22: cat: cols ...............................................   Passed    0.09 sec
        Start  26: circumradius: right-triangle
 19/214 Test  #23: centroid:  ..............................................   Passed    0.11 sec
        Start  27: circumradius: obtuse-triangle
 20/214 Test  #24: circulation: single_edge ................................   Passed    0.08 sec
        Start  28: circumradius: equilateral-tetrahedra
 21/214 Test  #21: cat: rows ...............................................   Passed    0.20 sec
        Start  29: circumradius: right-tetrahedra
 22/214 Test  #26: circumradius: right-triangle ............................   Passed    0.11 sec
        Start  30: circumradius: obtuse-tetrahedra
 23/214 Test  #25: circumradius: equilateral-triangle ......................   Passed    0.13 sec
        Start  31: cotmatrix: poly
 24/214 Test  #27: circumradius: obtuse-triangle ...........................   Passed    0.12 sec
        Start  32: cotmatrix: constant_in_null_space
 25/214 Test  #28: circumradius: equilateral-tetrahedra ....................   Passed    0.14 sec
        Start  33: cotmatrix: cube
 26/214 Test  #29: circumradius: right-tetrahedra ..........................   Passed    0.13 sec
        Start  34: cotmatrix: tetrahedron
 27/214 Test  #30: circumradius: obtuse-tetrahedra .........................   Passed    0.19 sec
        Start  35: cotmatrix_entries: simple
 28/214 Test  #34: cotmatrix: tetrahedron ..................................   Passed    0.09 sec
        Start  36: cotmatrix_entries: intrinsic
 29/214 Test  #33: cotmatrix: cube .........................................   Passed    0.17 sec
        Start  37: cotmatrix_intrinsic: periodic
 30/214 Test  #35: cotmatrix_entries: simple ...............................   Passed    0.11 sec
        Start  38: cotmatrix_intrinsic: manifold_meshes
 31/214 Test  #36: cotmatrix_entries: intrinsic ............................   Passed    0.10 sec
        Start  39: cr_vector_curvature_correction: cube
 32/214 Test  #37: cotmatrix_intrinsic: periodic ...........................   Passed    0.11 sec
        Start  40: cr_vector_curvature_correction: annulus
 33/214 Test  #39: cr_vector_curvature_correction: cube ....................   Passed    0.14 sec
        Start  41: cr_vector_curvature_correction: hemisphere
 34/214 Test  #41: cr_vector_curvature_correction: hemisphere ..............   Passed    0.54 sec
        Start  42: cr_vector_laplacian: cube
 35/214 Test  #42: cr_vector_laplacian: cube ...............................   Passed    0.15 sec
        Start  43: cumprod: col_factorial
 36/214 Test  #43: cumprod: col_factorial ..................................   Passed    0.12 sec
        Start  44: cumprod: row_factorial
 37/214 Test  #44: cumprod: row_factorial ..................................   Passed    0.12 sec
        Start  45: cumsum: col
 38/214 Test  #20: boundary_loop: bunny ....................................   Passed    1.74 sec
        Start  46: cumsum: row
 39/214 Test  #45: cumsum: col .............................................   Passed    0.13 sec
        Start  47: curved_hessian_energy: cube
 40/214 Test  #46: cumsum: row .............................................   Passed    0.11 sec
        Start  48: curved_hessian_energy: annulus
 41/214 Test  #47: curved_hessian_energy: cube .............................   Passed    0.14 sec
        Start  49: cut_mesh: seperate mesh
 42/214 Test  #49: cut_mesh: seperate mesh .................................   Passed    0.11 sec
        Start  50: cut_mesh: single edge
 43/214 Test  #50: cut_mesh: single edge ...................................   Passed    0.26 sec
        Start  51: cut_mesh: two triangles
 44/214 Test  #48: curved_hessian_energy: annulus ..........................   Passed    0.46 sec
        Start  52: cut_to_disk: simple_tet
 45/214 Test  #52: cut_to_disk: simple_tet .................................   Passed    0.14 sec
        Start  53: cut_to_disk: two_disconnected_tet
 46/214 Test  #51: cut_mesh: two triangles .................................   Passed    0.18 sec
        Start  54: cut_to_disk: simple_square
 47/214 Test  #54: cut_to_disk: simple_square ..............................   Passed    0.08 sec
        Start  55: cut_to_disk: torus
 48/214 Test  #53: cut_to_disk: two_disconnected_tet .......................   Passed    0.21 sec
        Start  56: cut_to_disk: cube
 49/214 Test  #55: cut_to_disk: torus ......................................   Passed    0.14 sec
        Start  57: cut_to_disk: annulus
 50/214 Test  #56: cut_to_disk: cube .......................................   Passed    0.18 sec
        Start  58: decimate: hemisphere
 51/214 Test  #58: decimate: hemisphere ....................................   Passed    0.29 sec
        Start  59: decimate: closed
 52/214 Test  #59: decimate: closed ........................................   Passed    0.32 sec
        Start  60: delaunay_triangulation_issue_521
 53/214 Test  #60: delaunay_triangulation_issue_521 ........................   Passed    0.08 sec
        Start  61: dijkstra: cube
 54/214 Test  #61: dijkstra: cube ..........................................   Passed    0.09 sec
        Start  62: dijkstra: discrete distances
 55/214 Test  #57: cut_to_disk: annulus ....................................   Passed    0.99 sec
        Start  63: direct_delta_mush: cube
 56/214 Test  #62: dijkstra: discrete distances ............................   Passed    0.10 sec
        Start  64: dirname: examples
 57/214 Test  #64: dirname: examples .......................................   Passed    0.10 sec
        Start  65: doublearea: VF_vs_ABC
 58/214 Test  #63: direct_delta_mush: cube .................................   Passed    0.27 sec
        Start  66: ears: grid
 59/214 Test  #66: ears: grid ..............................................   Passed    0.15 sec
        Start  67: ears: two-boundary
 60/214 Test  #32: cotmatrix: constant_in_null_space .......................   Passed    4.15 sec
        Start  68: edge_exists_near: tet
 61/214 Test  #68: edge_exists_near: tet ...................................   Passed    0.09 sec
        Start  69: edge_flaps: verify
 62/214 Test  #38: cotmatrix_intrinsic: manifold_meshes ....................   Passed    5.39 sec
        Start  70: edge_lengths: cube
 63/214 Test  #70: edge_lengths: cube ......................................   Passed    0.11 sec
        Start  71: edges_to_path: simple
 64/214 Test  #71: edges_to_path: simple ...................................   Passed    0.12 sec
        Start  72: euler_characteristic: cube
 65/214 Test  #72: euler_characteristic: cube ..............................   Passed    0.08 sec
        Start  73: euler_characteristic: triangle
 66/214 Test  #73: euler_characteristic: triangle ..........................   Passed    0.10 sec
        Start  74: euler_characteristic: square
 67/214 Test  #74: euler_characteristic: square ............................   Passed    0.11 sec
        Start  75: euler_characteristic: torus
 68/214 Test  #75: euler_characteristic: torus .............................   Passed    0.13 sec
        Start  76: exact_geodesic: square
 69/214 Test  #76: exact_geodesic: square ..................................   Passed    0.15 sec
        Start  77: facet_components: two_triangles
 70/214 Test  #77: facet_components: two_triangles .........................   Passed    0.17 sec
        Start  78: facet_components: truck
 71/214 Test  #78: facet_components: truck .................................   Passed    0.29 sec
        Start  79: fast_winding_number: one_point_cloud
 72/214 Test  #79: fast_winding_number: one_point_cloud ....................   Passed    0.09 sec
        Start  80: fast_winding_number: meshes
 73/214 Test  #65: doublearea: VF_vs_ABC ...................................   Passed    3.84 sec
        Start  81: fit_cubic_bezier: hemicircle
 74/214 Test  #81: fit_cubic_bezier: hemicircle ............................   Passed    0.46 sec
        Start  82: grad: laplace_grid
 75/214 Test  #82: grad: laplace_grid ......................................   Passed    0.28 sec
        Start  83: grad_intrinsic: laplace_grid
 76/214 Test  #83: grad_intrinsic: laplace_grid ............................   Passed    0.20 sec
        Start  84: grid: 3d
 77/214 Test  #84: grid: 3d ................................................   Passed    0.36 sec
        Start  85: grid: 2d
 78/214 Test  #85: grid: 2d ................................................   Passed    0.42 sec
        Start  86: guess_extension: all_meshes
 79/214 Test  #86: guess_extension: all_meshes .............................   Passed    0.29 sec
        Start  87: heat_geodesic: upsampled cube
 80/214 Test  #87: heat_geodesic: upsampled cube ...........................   Passed    0.45 sec
        Start  88: icosahedron: simple
 81/214 Test  #88: icosahedron: simple .....................................   Passed    0.19 sec
        Start  89: internal_angles: 1e-7
 82/214 Test  #89: internal_angles: 1e-7 ...................................   Passed    0.24 sec
        Start  90: intersection_blocking_collapse_edge_callbacks: simple
 83/214 Test  #90: intersection_blocking_collapse_edge_callbacks: simple ...   Passed    0.20 sec
        Start  91: intrinsic_delaunay_cotmatrix: skewed_grid
 84/214 Test  #91: intrinsic_delaunay_cotmatrix: skewed_grid ...............   Passed    0.32 sec
        Start  92: intrinsic_delaunay_cotmatrix: manifold_meshes
 85/214 Test  #69: edge_flaps: verify ......................................   Passed    7.18 sec
        Start  93: intrinsic_delaunay_triangulation: two_triangles
 86/214 Test  #93: intrinsic_delaunay_triangulation: two_triangles .........   Passed    0.21 sec
        Start  94: intrinsic_delaunay_triangulation: skewed_grid
 87/214 Test  #94: intrinsic_delaunay_triangulation: skewed_grid ...........   Passed    0.20 sec
        Start  95: intrinsic_delaunay_triangulation: peaks
 88/214 Test  #95: intrinsic_delaunay_triangulation: peaks .................   Passed    0.20 sec
        Start  96: intrinsic_delaunay_triangulation: tet
 89/214 Test  #96: intrinsic_delaunay_triangulation: tet ...................   Passed    0.22 sec
        Start  97: is_delaunay: two_triangles
 90/214 Test  #97: is_delaunay: two_triangles ..............................   Passed    0.13 sec
        Start  98: is_edge_manifold: positive
 91/214 Test  #40: cr_vector_curvature_correction: annulus .................   Passed   14.72 sec
        Start  99: is_edge_manifold: negative
 92/214 Test  #99: is_edge_manifold: negative ..............................   Passed    0.74 sec
        Start 100: is_intrinsic_delaunay: two_triangles
 93/214 Test #100: is_intrinsic_delaunay: two_triangles ....................   Passed    0.35 sec
        Start 101: is_irregular_vertex: simple
 94/214 Test #101: is_irregular_vertex: simple .............................   Passed    0.62 sec
        Start 102: is_symmetric: sparse
 95/214 Test #102: is_symmetric: sparse ....................................   Passed    0.27 sec
        Start 103: is_symmetric: dense
 96/214 Test #103: is_symmetric: dense .....................................   Passed    0.29 sec
        Start 104: ismember: simple
 97/214 Test #104: ismember: simple ........................................   Passed    0.21 sec
        Start 105: isolines: broken-sphere
 98/214 Test #105: isolines: broken-sphere .................................   Passed    1.03 sec
        Start 106: iterative_closest_point: identity
 99/214 Test  #98: is_edge_manifold: positive ..............................   Passed    9.01 sec
        Start 107: knn
100/214 Test #107: knn .....................................................   Passed    0.22 sec
        Start 108: linprog: 2D-inequality
101/214 Test #108: linprog: 2D-inequality ..................................   Passed    0.21 sec
        Start 109: linprog: 2D-inequality+2-equality
102/214 Test #109: linprog: 2D-inequality+2-equality .......................   Passed    0.41 sec
        Start 110: linprog: 2D-inequality+1-equality
103/214 Test #110: linprog: 2D-inequality+1-equality .......................   Passed    0.14 sec
        Start 111: ListToMatrixTest: matrix
104/214 Test #111: ListToMatrixTest: matrix ................................   Passed    0.12 sec
        Start 112: lscm: lscm_energy_check
105/214 Test  #67: ears: two-boundary ......................................   Passed   20.95 sec
        Start 113: massmatrix: full
106/214 Test  #92: intrinsic_delaunay_cotmatrix: manifold_meshes ...........   Passed   15.85 sec
        Start 114: massmatrix: barycentric
107/214 Test #112: lscm: lscm_energy_check .................................   Passed    4.52 sec
        Start 115: massmatrix: cube_barycentric
108/214 Test #115: massmatrix: cube_barycentric ............................   Passed    0.21 sec
        Start 116: massmatrix: cube_full
109/214 Test #116: massmatrix: cube_full ...................................   Passed    0.33 sec
        Start 117: min_quad_with_fixed: dense
110/214 Test #117: min_quad_with_fixed: dense ..............................   Passed    0.22 sec
        Start 118: min_quad_with_fixed: Aeq
111/214 Test #118: min_quad_with_fixed: Aeq ................................   Passed    0.16 sec
        Start 119: moments: tet
112/214 Test #119: moments: tet ............................................   Passed    0.12 sec
        Start 120: orient_halfedges: sanity checks
113/214 Test  #12: bbw: decimated_knight ...................................   Passed   29.92 sec
        Start 121: igl_path_to_edges: basic_test
114/214 Test #121: igl_path_to_edges: basic_test ...........................   Passed    0.34 sec
        Start 122: igl_path_to_edges: loop_test
115/214 Test #122: igl_path_to_edges: loop_test ............................   Passed    0.25 sec
        Start 123: igl_path_to_edges: vector_basic_test
116/214 Test #123: igl_path_to_edges: vector_basic_test ....................   Passed    0.23 sec
        Start 124: igl_path_to_edges: vector_loop_test
117/214 Test #124: igl_path_to_edges: vector_loop_test .....................   Passed    0.25 sec
        Start 125: path_to_executable: example
118/214 Test #125: path_to_executable: example .............................   Passed    0.22 sec
        Start 126: pathinfo: examples
119/214 Test #126: pathinfo: examples ......................................   Passed    0.28 sec
        Start 127: per_face_normals: dot
120/214 Test #113: massmatrix: full ........................................   Passed    6.49 sec
        Start 128: polygon_corners: quads
121/214 Test #128: polygon_corners: quads ..................................   Passed    0.29 sec
        Start 129: principal_curvature: cylinder
122/214 Test #129: principal_curvature: cylinder ...........................   Passed    0.75 sec
        Start 130: procrustes
123/214 Test #130: procrustes ..............................................   Passed    0.26 sec
        Start 131: qslim: cylinder
124/214 Test #114: massmatrix: barycentric .................................   Passed    6.59 sec
        Start 132: quadprog: box3
125/214 Test #132: quadprog: box3 ..........................................   Passed    0.33 sec
        Start 133: quadprog: box2
126/214 Test #133: quadprog: box2 ..........................................   Passed    0.29 sec
        Start 134: random_points_on_mesh: decimated-knight
127/214 Test #134: random_points_on_mesh: decimated-knight .................   Passed    0.41 sec
        Start 135: random_points_on_mesh: minstd_rand0_reproduce
128/214 Test #131: qslim: cylinder .........................................   Passed    1.98 sec
        Start 136: random_points_on_mesh: minstd_rand_reproduce
129/214 Test #136: random_points_on_mesh: minstd_rand_reproduce ............   Passed    0.25 sec
        Start 137: random_points_on_mesh: mt19937_reproduce
130/214 Test #135: random_points_on_mesh: minstd_rand0_reproduce ...........   Passed    0.47 sec
        Start 138: random_points_on_mesh: mt19937_64_reproduce
131/214 Test   #4: AABB: dynamic ...........................................   Passed   35.76 sec
        Start 139: randperm: default_rng_reproduce_identity
132/214 Test #138: random_points_on_mesh: mt19937_64_reproduce .............   Passed    0.22 sec
        Start 140: randperm: minstd_rand0_reproduce_identity
133/214 Test #137: random_points_on_mesh: mt19937_reproduce ................   Passed    0.46 sec
        Start 141: randperm: minstd_rand_reproduce_identity
134/214 Test #139: randperm: default_rng_reproduce_identity ................   Passed    0.28 sec
        Start 142: randperm: mt19937_reproduce_identity
135/214 Test #140: randperm: minstd_rand0_reproduce_identity ...............   Passed    0.28 sec
        Start 143: randperm: mt19937_64_reproduce_identity
136/214 Test #141: randperm: minstd_rand_reproduce_identity ................   Passed    0.22 sec
        Start 144: randperm: default_identity
137/214 Test #142: randperm: mt19937_reproduce_identity ....................   Passed    0.21 sec
        Start 145: ray_mesh_intersect: one_triangle
138/214 Test #143: randperm: mt19937_64_reproduce_identity .................   Passed    0.30 sec
        Start 146: ray_mesh_intersect: corner-case
139/214 Test #145: ray_mesh_intersect: one_triangle ........................   Passed    0.23 sec
        Start 147: ray_mesh_intersect: corner-case2
140/214 Test #144: randperm: default_identity ..............................   Passed    0.30 sec
        Start 148: readDMAT: Comp
141/214 Test #146: ray_mesh_intersect: corner-case .........................   Passed    0.22 sec
        Start 149: readMESH: single-tet
142/214 Test #147: ray_mesh_intersect: corner-case2 ........................   Passed    0.21 sec
        Start 150: readMESH: no-triangles-line
143/214 Test #148: readDMAT: Comp ..........................................   Passed    0.25 sec
        Start 151: readMESH: mesh-version-formatted-2
144/214 Test #149: readMESH: single-tet ....................................   Passed    0.23 sec
        Start 152: readMSH
145/214 Test #150: readMESH: no-triangles-line .............................   Passed    0.21 sec
        Start 153: readOBJ: simple
146/214 Test #153: readOBJ: simple .........................................   Passed    0.16 sec
        Start 154: readOBJ: Obj with material
147/214 Test #151: readMESH: mesh-version-formatted-2 ......................   Passed    0.35 sec
        Start 155: readOFF: simple
148/214 Test #152: readMSH .................................................   Passed    0.47 sec
        Start 156: readPLY: cube_with_fold.ply
149/214 Test #154: readOBJ: Obj with material ..............................   Passed    0.25 sec
        Start 157: readPLY: bunny.ply
150/214 Test #155: readOFF: simple .........................................   Passed    0.30 sec
        Start 158: readPLY: mesh_error.ply
151/214 Test #156: readPLY: cube_with_fold.ply .............................   Passed    0.17 sec
        Start 159: readPLY: quad_cube.ply
152/214 Test #158: readPLY: mesh_error.ply .................................   Passed    0.24 sec
        Start 160: remesh_along_isoline: triangle_mesh
153/214 Test #159: readPLY: quad_cube.ply ..................................   Passed    0.26 sec
        Start 161: repmat: sparse rowMajor
154/214 Test #160: remesh_along_isoline: triangle_mesh .....................   Passed    0.17 sec
        Start 162: repmat: sparse colMajor
155/214 Test #127: per_face_normals: dot ...................................   Passed    6.25 sec
        Start 163: rigid_alignment: identity
156/214 Test #161: repmat: sparse rowMajor .................................   Passed    0.29 sec
        Start 164: seam_edges: tet
157/214 Test #162: repmat: sparse colMajor .................................   Passed    0.29 sec
        Start 165: segment_segment_intersect: examples
158/214 Test #163: rigid_alignment: identity ...............................   Passed    0.31 sec
        Start 166: setdiff: matrix
159/214 Test #164: seam_edges: tet .........................................   Passed    0.19 sec
        Start 167: slice: eigen-simple
160/214 Test #166: setdiff: matrix .........................................   Passed    0.18 sec
        Start 168: slice: eigen-random
161/214 Test #165: segment_segment_intersect: examples .....................   Passed    0.30 sec
        Start 169: slice: dense_identity
162/214 Test #167: slice: eigen-simple .....................................   Passed    0.22 sec
        Start 170: slice: sparse_identity
163/214 Test #168: slice: eigen-random .....................................   Passed    0.26 sec
        Start 171: slice: density_reverse
164/214 Test #170: slice: sparse_identity ..................................   Passed    0.20 sec
        Start 172: slice: random
165/214 Test #169: slice: dense_identity ...................................   Passed    0.29 sec
        Start 173: slice_into: eigen-random
166/214 Test #120: orient_halfedges: sanity checks .........................   Passed   10.01 sec
        Start 174: slice_into: dense_identity
167/214 Test #171: slice: density_reverse ..................................   Passed    0.22 sec
        Start 175: slice_into: density_reverse
168/214 Test #172: slice: random ...........................................   Passed    0.21 sec
        Start 176: slice_into: sparse_identity
169/214 Test #173: slice_into: eigen-random ................................   Passed    0.26 sec
        Start 177: slice_into: every-other
170/214 Test #174: slice_into: dense_identity ..............................   Passed    0.26 sec
171/214 Test #175: slice_into: density_reverse .............................   Passed    0.24 sec
        Start 178: slice_mask/find: random
        Start 179: slice_sorted: correctness
172/214 Test #176: slice_into: sparse_identity .............................   Passed    0.28 sec
        Start 180: SortTest: random
173/214 Test #177: slice_into: every-other .................................   Passed    0.27 sec
        Start 181: sparse_voxel_grid: unique
174/214 Test #180: SortTest: random ........................................   Passed    0.21 sec
        Start 182: split_nonmanifold: edge-fan
175/214 Test #178: slice_mask/find: random .................................   Passed    0.31 sec
        Start 183: split_nonmanifold: vertex-boundary
176/214 Test #181: sparse_voxel_grid: unique ...............................   Passed    0.26 sec
        Start 184: split_nonmanifold: edge-disk-flap
177/214 Test #157: readPLY: bunny.ply ......................................   Passed    2.22 sec
        Start 185: split_nonmanifold: edge-disk-tent
178/214 Test #183: split_nonmanifold: vertex-boundary ......................   Passed    0.19 sec
        Start 186: split_nonmanifold: vertex-kiss
179/214 Test #182: split_nonmanifold: edge-fan .............................   Passed    0.25 sec
        Start 187: split_nonmanifold: non-orientable
180/214 Test #179: slice_sorted: correctness ...............................   Passed    0.53 sec
        Start 188: split_nonmanifold: flap
181/214 Test #185: split_nonmanifold: edge-disk-tent .......................   Passed    0.19 sec
        Start 189: split_nonmanifold: crosses
182/214 Test #187: split_nonmanifold: non-orientable .......................   Passed    0.19 sec
        Start 190: squared_edge_lengths: cube
183/214 Test #184: split_nonmanifold: edge-disk-flap .......................   Passed    0.32 sec
        Start 191: super_fibonacci: simple
184/214 Test #186: split_nonmanifold: vertex-kiss ..........................   Passed    0.29 sec
        Start 192: tet_tet_adjacency: dot
185/214 Test #188: split_nonmanifold: flap .................................   Passed    0.27 sec
        Start 193: tri_tri_intersection_test_3d intersect
186/214 Test #191: super_fibonacci: simple .................................   Passed    0.21 sec
        Start 194: tri_tri_intersection_test_3d not intersect
187/214 Test #190: squared_edge_lengths: cube ..............................   Passed    0.34 sec
        Start 195: tri_tri_intersection_test_3d coplanar
188/214 Test #193: tri_tri_intersection_test_3d intersect ..................   Passed    0.33 sec
        Start 196: triangle_triangle_adjacency: dot
189/214 Test #192: tet_tet_adjacency: dot ..................................   Passed    0.38 sec
190/214 Test #194: tri_tri_intersection_test_3d not intersect ..............   Passed    0.22 sec
        Start 197: triangle_triangle_intersect: shared-edge
        Start 198: triangulated_grid: area
191/214 Test #195: tri_tri_intersection_test_3d coplanar ...................   Passed    0.26 sec
        Start 199: turning_number: pentagon
192/214 Test #189: split_nonmanifold: crosses ..............................   Passed    0.70 sec
        Start 200: turning_number: heptagram
193/214 Test #198: triangulated_grid: area .................................   Passed    0.18 sec
        Start 201: unique: matrix
194/214 Test #197: triangle_triangle_intersect: shared-edge ................   Passed    0.25 sec
        Start 202: unique_rows: matrix
195/214 Test #201: unique: matrix ..........................................   Passed    0.13 sec
        Start 203: igl_unique_simplices: duplicate_triangles
196/214 Test #199: turning_number: pentagon ................................   Passed    0.21 sec
        Start 204: upsample: single_triangle
197/214 Test #202: unique_rows: matrix .....................................   Passed    0.14 sec
        Start 205: upsample: V_comes_first_F_ordering
198/214 Test #200: turning_number: heptagram ...............................   Passed    0.29 sec
        Start 206: voronoi_mass: equilateral-tetrahedra
199/214 Test #204: upsample: single_triangle ...............................   Passed    0.17 sec
        Start 207: voronoi_mass: right-tetrahedra
200/214 Test #203: igl_unique_simplices: duplicate_triangles ...............   Passed    0.24 sec
        Start 208: voronoi_mass: obtuse-tetrahedra
201/214 Test #206: voronoi_mass: equilateral-tetrahedra ....................   Passed    0.20 sec
        Start 209: winding_number: bunny
202/214 Test #207: voronoi_mass: right-tetrahedra ..........................   Passed    0.16 sec
        Start 210: writeMSH
203/214 Test #208: voronoi_mass: obtuse-tetrahedra .........................   Passed    0.17 sec
        Start 211: writeOFF: quads
204/214 Test #211: writeOFF: quads .........................................   Passed    0.13 sec
        Start 212: writePLY: bunny.ply
205/214 Test #106: iterative_closest_point: identity .......................   Passed   22.78 sec
        Start 213: writePLY: bunny.ply float
206/214 Test #210: writeMSH ................................................   Passed    1.14 sec
        Start 214: eigs: grid
207/214 Test #214: eigs: grid ..............................................   Passed    0.91 sec
208/214 Test #212: writePLY: bunny.ply .....................................   Passed    2.85 sec
209/214 Test #213: writePLY: bunny.ply float ...............................   Passed    2.53 sec
210/214 Test #196: triangle_triangle_adjacency: dot ........................   Passed    6.56 sec
211/214 Test #205: upsample: V_comes_first_F_ordering ......................   Passed    6.29 sec
212/214 Test  #80: fast_winding_number: meshes .............................   Passed   63.46 sec
213/214 Test #209: winding_number: bunny ...................................   Passed   31.18 sec
214/214 Test  #31: cotmatrix: poly .........................................   Passed   72.03 sec

100% tests passed, 0 tests failed out of 214

Total Test time (real) =  73.01 sec
```
AdamKorcz pushed a commit that referenced this pull request Jul 28, 2025
run_tests.sh is used as part of Chronos with cached builds:
https://github.com/google/oss-fuzz/tree/master/infra/experimental/chronos#check-tests

```sh
$ infra/experimental/chronos/check_tests.sh arrow c++
...
...

33/46 Test #36: arrow-json-test ....................   Passed    1.56 sec
34/46 Test #32: arrow-feather-test .................   Passed    3.06 sec
35/46 Test #26: arrow-utility-test .................   Passed    3.49 sec
36/46 Test #39: parquet-reader-test ................   Passed    3.57 sec
37/46 Test #23: arrow-io-compressed-test ...........   Passed    5.50 sec
38/46 Test #38: parquet-encoding-test ..............   Passed    5.30 sec
39/46 Test #20: arrow-compute-scalar-cast-test .....   Passed    7.04 sec
40/46 Test #27: arrow-async-utility-test ...........   Passed    8.69 sec
41/46 Test #42: parquet-arrow-reader-writer-test ...   Passed    8.41 sec
42/46 Test #29: arrow-threading-utility-test .......   Passed    8.76 sec
43/46 Test #41: parquet-chunker-test ...............   Passed    8.71 sec
44/46 Test  #1: arrow-array-test ...................   Passed    9.60 sec
45/46 Test #34: arrow-ipc-read-write-test ..........   Passed    9.52 sec
46/46 Test #40: parquet-writer-test ................   Passed   18.53 sec

100% tests passed, 0 tests failed out of 46

Label Time Summary:
arrow-compute-tests    =   7.36 sec*proc (2 tests)
arrow-tests            =  63.05 sec*proc (34 tests)
parquet-tests          =  48.01 sec*proc (10 tests)
unittest               = 118.42 sec*proc (46 tests)

Total Test time (real) =  18.97 sec
--------------------------------------------------------
Total time taken to replay tests: 19
```

---------

Signed-off-by: David Korczynski <david@adalogics.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants