-
Notifications
You must be signed in to change notification settings - Fork 2.5k
Update new_library.md #17
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
$ cd /path/to/oss-fuzz | ||
$ python scripts/helper.py build_image $LIB_NAME | ||
$ python scripts/helper.py build_fuzzers $LIB_NAME | ||
$ sudo python scripts/helper.py build_image $LIB_NAME |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sudo? Why did you need it?
Does docker run without sudo for you? (docker ps)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have the same problem, and that's because I'm not in the "docker" group.
Must be a docker setup issue.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
you need to reboot computer or run newgrp
in your session. @eugenis can you verify?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes
don;t know about newgrp but reboot helps
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I did not read/follow past "Optional configurations". Mailed #28 to clarify instructions.
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)
cc @oliverchang @alan32liu after #9100 and #8448 After compiling locally, I can see that `./SystemSan ./target_dns -dict=vuln.dict` crashes in a few seconds with ``` ===BUG DETECTED: Arbitrary domain name resolution=== ===Domain resolved: .f.z=== ===DNS request type: 0, class: 256=== ==315== ERROR: libFuzzer: deadly signal #0 0x539131 in __sanitizer_print_stack_trace /src/llvm-project/compiler-rt/lib/asan/asan_stack.cpp:87:3 #1 0x457c48 in fuzzer::PrintStackTrace() /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerUtil.cpp:210:5 #2 0x43c923 in fuzzer::Fuzzer::CrashCallback() /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:233:3 #3 0x7fa57940041f (/lib/x86_64-linux-gnu/libpthread.so.0+0x1441f) (BuildId: 7b4536f41cdaa5888408e82d0836e33dcf436466) #4 0x7fa5793ff7db in send (/lib/x86_64-linux-gnu/libpthread.so.0+0x137db) (BuildId: 7b4536f41cdaa5888408e82d0836e33dcf436466) #5 0x503ba4 in __interceptor_send /src/llvm-project/compiler-rt/lib/asan/../sanitizer_common/sanitizer_common_interceptors.inc:6802:17 #6 0x7fa578abf462 (/lib/x86_64-linux-gnu/libresolv.so.2+0xb462) (BuildId: 4519041bde5b859c55798ac0745b0b6199cb7d94) #7 0x7fa578abbc43 in __res_context_query (/lib/x86_64-linux-gnu/libresolv.so.2+0x7c43) (BuildId: 4519041bde5b859c55798ac0745b0b6199cb7d94) #8 0x7fa578abc8ed in __res_context_search (/lib/x86_64-linux-gnu/libresolv.so.2+0x88ed) (BuildId: 4519041bde5b859c55798ac0745b0b6199cb7d94) #9 0x7fa578ad2cc1 (/lib/x86_64-linux-gnu/libnss_dns.so.2+0x2cc1) (BuildId: 3fac4ec397ba8e8938fe298f103113f315465130) #10 0x7fa578ad2e8b in _nss_dns_gethostbyname3_r (/lib/x86_64-linux-gnu/libnss_dns.so.2+0x2e8b) (BuildId: 3fac4ec397ba8e8938fe298f103113f315465130) #11 0x7fa578ad2f41 in _nss_dns_gethostbyname2_r (/lib/x86_64-linux-gnu/libnss_dns.so.2+0x2f41) (BuildId: 3fac4ec397ba8e8938fe298f103113f315465130) #12 0x7fa5792fdc9d in gethostbyname2_r (/lib/x86_64-linux-gnu/libc.so.6+0x130c9d) (BuildId: 1878e6b475720c7c51969e69ab2d276fae6d1dee) #13 0x7fa5792d179e (/lib/x86_64-linux-gnu/libc.so.6+0x10479e) (BuildId: 1878e6b475720c7c51969e69ab2d276fae6d1dee) #14 0x7fa5792d2f58 in getaddrinfo (/lib/x86_64-linux-gnu/libc.so.6+0x105f58) (BuildId: 1878e6b475720c7c51969e69ab2d276fae6d1dee) #15 0x4d93ac in getaddrinfo /src/llvm-project/compiler-rt/lib/asan/../sanitizer_common/sanitizer_common_interceptors.inc:2667:13 #16 0x56c8d9 in LLVMFuzzerTestOneInput /out/SystemSan/target_dns.cpp:35:11 #17 0x43dec3 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:611:15 #18 0x43d6aa in fuzzer::Fuzzer::RunOne(unsigned char const*, unsigned long, bool, fuzzer::InputInfo*, bool, bool*) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:514:3 #19 0x43ed79 in fuzzer::Fuzzer::MutateAndTestOne() /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:757:19 #20 0x43fa45 in fuzzer::Fuzzer::Loop(std::__Fuzzer::vector<fuzzer::SizedFile, std::__Fuzzer::allocator<fuzzer::SizedFile> >&) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:895:5 #21 0x42edaf in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:912:6 #22 0x458402 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10 #23 0x7fa5791f1082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 1878e6b475720c7c51969e69ab2d276fae6d1dee) #24 0x41f7ed in _start (/out/SystemSan/target_dns+0x41f7ed) NOTE: libFuzzer has rudimentary signal handlers. Combine libFuzzer with AddressSanitizer or similar for better crash reports. SUMMARY: libFuzzer: deadly signal MS: 2 CrossOver-ManualDict- DE: "f.z"-; base unit: ac3478d69a3c81fa62e60f5c3696165a4e5e6ac4 0x66,0x2e,0x7a, f.z artifact_prefix='./'; Test unit written to ./crash-926813b2d6adde373f96a10594a5314951588384 Base64: Zi56 ``` You can also try ``` echo -n f.z > toto ./SystemSan ./target_dns toto ``` Co-authored-by: Oliver Chang <oliverchang@users.noreply.github.com> Co-authored-by: jonathanmetzman <31354670+jonathanmetzman@users.noreply.github.com>
cc @oliverchang @alan32liu after google#9100 and google#8448 After compiling locally, I can see that `./SystemSan ./target_dns -dict=vuln.dict` crashes in a few seconds with ``` ===BUG DETECTED: Arbitrary domain name resolution=== ===Domain resolved: .f.z=== ===DNS request type: 0, class: 256=== ==315== ERROR: libFuzzer: deadly signal #0 0x539131 in __sanitizer_print_stack_trace /src/llvm-project/compiler-rt/lib/asan/asan_stack.cpp:87:3 google#1 0x457c48 in fuzzer::PrintStackTrace() /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerUtil.cpp:210:5 google#2 0x43c923 in fuzzer::Fuzzer::CrashCallback() /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:233:3 google#3 0x7fa57940041f (/lib/x86_64-linux-gnu/libpthread.so.0+0x1441f) (BuildId: 7b4536f41cdaa5888408e82d0836e33dcf436466) google#4 0x7fa5793ff7db in send (/lib/x86_64-linux-gnu/libpthread.so.0+0x137db) (BuildId: 7b4536f41cdaa5888408e82d0836e33dcf436466) google#5 0x503ba4 in __interceptor_send /src/llvm-project/compiler-rt/lib/asan/../sanitizer_common/sanitizer_common_interceptors.inc:6802:17 google#6 0x7fa578abf462 (/lib/x86_64-linux-gnu/libresolv.so.2+0xb462) (BuildId: 4519041bde5b859c55798ac0745b0b6199cb7d94) google#7 0x7fa578abbc43 in __res_context_query (/lib/x86_64-linux-gnu/libresolv.so.2+0x7c43) (BuildId: 4519041bde5b859c55798ac0745b0b6199cb7d94) google#8 0x7fa578abc8ed in __res_context_search (/lib/x86_64-linux-gnu/libresolv.so.2+0x88ed) (BuildId: 4519041bde5b859c55798ac0745b0b6199cb7d94) google#9 0x7fa578ad2cc1 (/lib/x86_64-linux-gnu/libnss_dns.so.2+0x2cc1) (BuildId: 3fac4ec397ba8e8938fe298f103113f315465130) google#10 0x7fa578ad2e8b in _nss_dns_gethostbyname3_r (/lib/x86_64-linux-gnu/libnss_dns.so.2+0x2e8b) (BuildId: 3fac4ec397ba8e8938fe298f103113f315465130) google#11 0x7fa578ad2f41 in _nss_dns_gethostbyname2_r (/lib/x86_64-linux-gnu/libnss_dns.so.2+0x2f41) (BuildId: 3fac4ec397ba8e8938fe298f103113f315465130) google#12 0x7fa5792fdc9d in gethostbyname2_r (/lib/x86_64-linux-gnu/libc.so.6+0x130c9d) (BuildId: 1878e6b475720c7c51969e69ab2d276fae6d1dee) google#13 0x7fa5792d179e (/lib/x86_64-linux-gnu/libc.so.6+0x10479e) (BuildId: 1878e6b475720c7c51969e69ab2d276fae6d1dee) google#14 0x7fa5792d2f58 in getaddrinfo (/lib/x86_64-linux-gnu/libc.so.6+0x105f58) (BuildId: 1878e6b475720c7c51969e69ab2d276fae6d1dee) google#15 0x4d93ac in getaddrinfo /src/llvm-project/compiler-rt/lib/asan/../sanitizer_common/sanitizer_common_interceptors.inc:2667:13 google#16 0x56c8d9 in LLVMFuzzerTestOneInput /out/SystemSan/target_dns.cpp:35:11 google#17 0x43dec3 in fuzzer::Fuzzer::ExecuteCallback(unsigned char const*, unsigned long) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:611:15 google#18 0x43d6aa in fuzzer::Fuzzer::RunOne(unsigned char const*, unsigned long, bool, fuzzer::InputInfo*, bool, bool*) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:514:3 google#19 0x43ed79 in fuzzer::Fuzzer::MutateAndTestOne() /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:757:19 google#20 0x43fa45 in fuzzer::Fuzzer::Loop(std::__Fuzzer::vector<fuzzer::SizedFile, std::__Fuzzer::allocator<fuzzer::SizedFile> >&) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerLoop.cpp:895:5 google#21 0x42edaf in fuzzer::FuzzerDriver(int*, char***, int (*)(unsigned char const*, unsigned long)) /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerDriver.cpp:912:6 google#22 0x458402 in main /src/llvm-project/compiler-rt/lib/fuzzer/FuzzerMain.cpp:20:10 google#23 0x7fa5791f1082 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24082) (BuildId: 1878e6b475720c7c51969e69ab2d276fae6d1dee) google#24 0x41f7ed in _start (/out/SystemSan/target_dns+0x41f7ed) NOTE: libFuzzer has rudimentary signal handlers. Combine libFuzzer with AddressSanitizer or similar for better crash reports. SUMMARY: libFuzzer: deadly signal MS: 2 CrossOver-ManualDict- DE: "f.z"-; base unit: ac3478d69a3c81fa62e60f5c3696165a4e5e6ac4 0x66,0x2e,0x7a, f.z artifact_prefix='./'; Test unit written to ./crash-926813b2d6adde373f96a10594a5314951588384 Base64: Zi56 ``` You can also try ``` echo -n f.z > toto ./SystemSan ./target_dns toto ``` Co-authored-by: Oliver Chang <oliverchang@users.noreply.github.com> Co-authored-by: jonathanmetzman <31354670+jonathanmetzman@users.noreply.github.com>
Using `apt upgrade` without `-y` is problematic, because it may fail: ``` Step #17: Step 3/4 : RUN apt-get upgrade && apt-get install --yes --no-install-recommends libclang-dev pkg-config libcap-dev Step #17: ---> Running in 4fd961f9329f Step #17: Reading package lists... Step #17: Building dependency tree... Step #17: Reading state information... Step #17: Calculating upgrade... Step #17: The following packages will be upgraded: Step #17: bsdutils fdisk libblkid1 libfdisk1 libmount1 libsmartcols1 libuuid1 mount Step #17: util-linux Step #17: 9 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. Step #17: Need to get 1901 kB of archives. Step #17: After this operation, 4096 B of additional disk space will be used. Step #17: Do you want to continue? [Y/n] Abort. Step #17: The command '/bin/sh -c apt-get upgrade && apt-get install --yes --no-install-recommends libclang-dev pkg-config libcap-dev' returned a non-zero code: 1 Finished Step #17 ERROR ``` Also, an `apt-get update` is needed, anyway. Fix both issues by replacing `upgrade` with `update`.
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>
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>
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>
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 shaderc c++ ... ... [13/26 Test #13: shaderc_shaderc_cpp ...................... Passed 14.67 sec Start 14: shaderc_shaderc_private 14/26 Test #14: shaderc_shaderc_private .................. Passed 0.01 sec Start 15: shaderc_shared_shaderc 15/26 Test #15: shaderc_shared_shaderc ................... Passed 40.47 sec Start 16: shaderc_shared_shaderc_cpp 16/26 Test #16: shaderc_shared_shaderc_cpp ............... Passed 30.58 sec Start 17: shaderc_shared_shaderc_private 17/26 Test #17: shaderc_shared_shaderc_private ........... Passed 0.02 sec Start 18: shaderc_combined_shaderc 18/26 Test #18: shaderc_combined_shaderc ................. Passed 19.36 sec Start 19: shaderc_combined_shaderc_cpp 19/26 Test #19: shaderc_combined_shaderc_cpp ............. Passed 14.83 sec Start 20: shaderc_c_smoke_test 20/26 Test #20: shaderc_c_smoke_test ..................... Passed 0.20 sec Start 21: glslc_file 21/26 Test #21: glslc_file ............................... Passed 0.02 sec Start 22: glslc_resource_parse 22/26 Test #22: glslc_resource_parse ..................... Passed 0.01 sec Start 23: glslc_stage 23/26 Test #23: glslc_stage .............................. Passed 0.01 sec Start 24: shaderc_expect_unittests 24/26 Test #24: shaderc_expect_unittests ................. Passed 0.08 sec Start 25: shaderc_glslc_test_framework_unittests 25/26 Test #25: shaderc_glslc_test_framework_unittests ... Passed 0.06 sec Start 26: glslc_tests 26/26 Test #26: glslc_tests .............................. Passed 66.44 sec 100% tests passed, 0 tests failed out of 26 Total Test time (real) = 262.85 sec ``` Signed-off-by: David Korczynski <david@adalogics.com>
Adds `run_tests.sh` to the jsonc 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 jsoncpp c++`: ``` Running tests... Test project /src/json-c/json-c-build Start 1: test1 1/25 Test #1: test1 ............................ Passed 0.22 sec Start 2: test2 2/25 Test #2: test2 ............................ Passed 0.15 sec Start 3: test4 3/25 Test #3: test4 ............................ Passed 0.05 sec Start 4: testReplaceExisting 4/25 Test #4: testReplaceExisting .............. Passed 0.04 sec Start 5: test_cast 5/25 Test #5: test_cast ........................ Passed 0.05 sec Start 6: test_charcase 6/25 Test #6: test_charcase .................... Passed 0.06 sec Start 7: test_compare 7/25 Test #7: test_compare ..................... Passed 0.05 sec Start 8: test_deep_copy 8/25 Test #8: test_deep_copy ................... Passed 0.05 sec Start 9: test_double_serializer 9/25 Test #9: test_double_serializer ........... Passed 0.04 sec Start 10: test_float 10/25 Test #10: test_float ....................... Passed 0.04 sec Start 11: test_int_add 11/25 Test #11: test_int_add ..................... Passed 0.04 sec Start 12: test_int_get 12/25 Test #12: test_int_get ..................... Passed 0.04 sec Start 13: test_locale 13/25 Test #13: test_locale ...................... Passed 0.05 sec Start 14: test_null 14/25 Test #14: test_null ........................ Passed 0.04 sec Start 15: test_parse 15/25 Test #15: test_parse ....................... Passed 0.05 sec Start 16: test_parse_int64 16/25 Test #16: test_parse_int64 ................. Passed 0.05 sec Start 17: test_printbuf 17/25 Test #17: test_printbuf .................... Passed 0.05 sec Start 18: test_set_serializer 18/25 Test #18: test_set_serializer .............. Passed 0.04 sec Start 19: test_set_value 19/25 Test #19: test_set_value ................... Passed 0.05 sec Start 20: test_strerror 20/25 Test #20: test_strerror .................... Passed 0.04 sec Start 21: test_util_file 21/25 Test #21: test_util_file ................... Passed 0.05 sec Start 22: test_visit 22/25 Test #22: test_visit ....................... Passed 0.05 sec Start 23: test_object_iterator 23/25 Test #23: test_object_iterator ............. Passed 0.05 sec Start 24: test_json_pointer 24/25 Test #24: test_json_pointer ................ Passed 0.05 sec Start 25: test_json_patch 25/25 Test #25: test_json_patch .................. Passed 0.07 sec 100% tests passed, 0 tests failed out of 25 Total Test time (real) = 1.48 sec ```
Adds `run_tests.sh` to the fmt 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 fmt c++: ``` [0/1] Running tests... Test project /src/fmt/build Start 1: args-test 1/21 Test #1: args-test ........................ Passed 0.07 sec Start 2: base-test 2/21 Test #2: base-test ........................ Passed 0.11 sec Start 3: assert-test 3/21 Test #3: assert-test ...................... Passed 0.40 sec Start 4: chrono-test 4/21 Test #4: chrono-test ...................... Passed 0.45 sec Start 5: color-test 5/21 Test #5: color-test ....................... Passed 0.07 sec Start 6: gtest-extra-test 6/21 Test #6: gtest-extra-test ................. Passed 0.13 sec Start 7: format-test 7/21 Test #7: format-test ...................... Passed 0.15 sec Start 8: format-impl-test 8/21 Test #8: format-impl-test ................. Passed 0.16 sec Start 9: ostream-test 9/21 Test #9: ostream-test ..................... Passed 0.04 sec Start 10: compile-test 10/21 Test #10: compile-test ..................... Passed 0.04 sec Start 11: compile-fp-test 11/21 Test #11: compile-fp-test .................. Passed 0.04 sec Start 12: printf-test 12/21 Test #12: printf-test ...................... Passed 0.09 sec Start 13: ranges-test 13/21 Test #13: ranges-test ...................... Passed 0.06 sec Start 14: no-builtin-types-test 14/21 Test #14: no-builtin-types-test ............ Passed 0.05 sec Start 15: scan-test 15/21 Test #15: scan-test ........................ Passed 0.08 sec Start 16: std-test 16/21 Test #16: std-test ......................... Passed 0.05 sec Start 17: unicode-test 17/21 Test #17: unicode-test ..................... Passed 0.05 sec Start 18: xchar-test 18/21 Test #18: xchar-test ....................... Passed 0.06 sec Start 19: enforce-checks-test 19/21 Test #19: enforce-checks-test .............. Passed 0.03 sec Start 20: posix-mock-test 20/21 Test #20: posix-mock-test .................. Passed 0.06 sec Start 21: os-test 21/21 Test #21: os-test .......................... Passed 0.07 sec 100% tests passed, 0 tests failed out of 21 Total Test time (real) = 2.32 sec ```
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 ```
`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 phmap c` ``` Test project /src/parallel-hashmap/build Start 1: test_container_memory 1/17 Test #1: test_container_memory ............... Passed 0.01 sec Start 2: test_hash_policy_testing 2/17 Test #2: test_hash_policy_testing ............ Passed 0.01 sec Start 3: test_node_hash_policy 3/17 Test #3: test_node_hash_policy ............... Passed 0.01 sec Start 4: test_raw_hash_set 4/17 Test #4: test_raw_hash_set ................... Passed 0.74 sec Start 5: test_raw_hash_set_allocator 5/17 Test #5: test_raw_hash_set_allocator ......... Passed 0.02 sec Start 6: test_flat_hash_set 6/17 Test #6: test_flat_hash_set .................. Passed 0.04 sec Start 7: test_flat_hash_map 7/17 Test #7: test_flat_hash_map .................. Passed 0.46 sec Start 8: test_node_hash_map 8/17 Test #8: test_node_hash_map .................. Passed 0.05 sec Start 9: test_node_hash_set 9/17 Test #9: test_node_hash_set .................. Passed 0.04 sec Start 10: test_parallel_flat_hash_map 10/17 Test #10: test_parallel_flat_hash_map ......... Passed 0.47 sec Start 11: test_parallel_flat_hash_set 11/17 Test #11: test_parallel_flat_hash_set ......... Passed 0.04 sec Start 12: test_parallel_node_hash_map 12/17 Test #12: test_parallel_node_hash_map ......... Passed 0.46 sec Start 13: test_parallel_node_hash_set 13/17 Test #13: test_parallel_node_hash_set ......... Passed 0.04 sec Start 14: test_parallel_flat_hash_map_mutex 14/17 Test #14: test_parallel_flat_hash_map_mutex ... Passed 0.49 sec Start 15: test_dump_load 15/17 Test #15: test_dump_load ...................... Passed 0.01 sec Start 16: test_erase_if 16/17 Test #16: test_erase_if ....................... Passed 0.01 sec Start 17: test_btree 17/17 Test #17: test_btree .......................... Passed 18.09 sec 100% tests passed, 0 tests failed out of 17 Total Test time (real) = 21.00 sec ``` Signed-off-by: Adam Korczynski <adam@adalogics.com>
`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 glaze c` ``` Test project /src/glaze/build Start 1: api_test Start 2: beve_test Start 3: compare_test Start 4: csv_test Start 5: eigen_test Start 6: example_json Start 7: exceptions_test Start 8: inplace_vector_test 1/28 Test #1: api_test ........................... Passed 0.01 sec Start 9: inplace_vector_test_noexceptions 2/28 Test #3: compare_test ....................... Passed 0.01 sec Start 10: int_parsing 3/28 Test #8: inplace_vector_test ................ Passed 0.01 sec Start 11: jmespath 4/28 Test #6: example_json ....................... Passed 0.02 sec Start 12: jsonrpc_test 5/28 Test #5: eigen_test ......................... Passed 0.02 sec Start 13: lib_test 6/28 Test #9: inplace_vector_test_noexceptions ... Passed 0.02 sec Start 14: mock_json_test 7/28 Test #4: csv_test ........................... Passed 0.04 sec Start 15: reflection 8/28 Test #11: jmespath ........................... Passed 0.03 sec Start 16: roundtrip_JSON 9/28 Test #12: jsonrpc_test ....................... Passed 0.03 sec Start 17: roundtrip_BEVE 10/28 Test #13: lib_test ........................... Passed 0.03 sec Start 18: stencil_test 11/28 Test #15: reflection ......................... Passed 0.02 sec Start 19: threading_test 12/28 Test #14: mock_json_test ..................... Passed 0.04 sec 13/28 Test #16: roundtrip_JSON ..................... Passed 0.02 sec 14/28 Test #17: roundtrip_BEVE ..................... Passed 0.01 sec Start 20: toml_test Start 21: utility_formats Start 22: json_conformance 15/28 Test #7: exceptions_test .................... Passed 0.07 sec 16/28 Test #18: stencil_test ....................... Passed 0.02 sec Start 23: json_performance Start 24: json_reflection_test 17/28 Test #21: utility_formats .................... Passed 0.01 sec Start 25: json_test 18/28 Test #20: toml_test .......................... Passed 0.02 sec Start 26: json_test_non_null 19/28 Test #22: json_conformance ................... Passed 0.02 sec Start 27: json_t_test 20/28 Test #24: json_reflection_test ............... Passed 0.02 sec Start 28: jsonschema_test 21/28 Test #27: json_t_test ........................ Passed 0.02 sec 22/28 Test #28: jsonschema_test .................... Passed 0.05 sec 23/28 Test #2: beve_test .......................... Passed 1.17 sec 24/28 Test #19: threading_test ..................... Passed 1.30 sec 25/28 Test #25: json_test .......................... Passed 2.24 sec 26/28 Test #26: json_test_non_null ................. Passed 2.30 sec 27/28 Test #10: int_parsing ........................ Passed 12.10 sec 28/28 Test #23: json_performance ................... Passed 87.87 sec 100% tests passed, 0 tests failed out of 28 Label Time Summary: format_BEVE = 0.01 sec*proc (1 test) format_JSON = 0.02 sec*proc (1 test) Total Test time (real) = 87.95 sec -------------------------------------------------------- Total time taken to replay tests: 8 ``` Signed-off-by: Adam Korczynski <adam@adalogics.com>
scripts/helper.py should be run with sudo, otherwise it fails with: