From: Louis Dionne Date: Tue, 4 Jun 2019 16:47:18 +0000 (+0000) Subject: [libcxx] Add test to check min/max requirement to regular expression X-Git-Tag: llvmorg-10-init~3785 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=c3c23b27a4d1f6eed39d17b6b5ca709b7b405e8e;p=platform%2Fupstream%2Fllvm.git [libcxx] Add test to check min/max requirement to regular expression This commit adds tests that repeated characters in regular expressions are within numeric limits, and that a <= b in a regex like `x{a,b}`. Thanks to Andrey Maksimov for the patch. Differential Revision: https://reviews.llvm.org/D62816 llvm-svn: 362525 --- diff --git a/libcxx/test/std/re/re.grammar/excessive_brace_min_max.pass.cpp b/libcxx/test/std/re/re.grammar/excessive_brace_min_max.pass.cpp new file mode 100644 index 0000000..09bedc5 --- /dev/null +++ b/libcxx/test/std/re/re.grammar/excessive_brace_min_max.pass.cpp @@ -0,0 +1,67 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// +// UNSUPPORTED: libcpp-no-exceptions +// UNSUPPORTED: c++98, c++03 + +// the "n" and "m" in `a{n,m}` should be within the numeric limits. +// requirement "m >= n" should be checked. + +#include +#include +#include "test_macros.h" + +int main(int, char**) { + // test that `n <= m` + for (std::regex_constants::syntax_option_type op : + {std::regex::basic}) { + try { + TEST_IGNORE_NODISCARD std::regex("a\\{3,2\\}", op); + assert(false); + } catch (const std::regex_error &e) { + assert(e.code() == std::regex_constants::error_badbrace); + LIBCPP_ASSERT(e.code() == std::regex_constants::error_badbrace); + } + } + for (std::regex_constants::syntax_option_type op : + {std::regex::ECMAScript, std::regex::extended, std::regex::egrep, + std::regex::awk}) { + try { + TEST_IGNORE_NODISCARD std::regex("a{3,2}", op); + assert(false); + } catch (const std::regex_error &e) { + assert(e.code() == std::regex_constants::error_badbrace); + LIBCPP_ASSERT(e.code() == std::regex_constants::error_badbrace); + } + } + + // test that both bounds are within the limit + for (std::regex_constants::syntax_option_type op : + {std::regex::basic}) { + try { + TEST_IGNORE_NODISCARD std::regex("a\\{100000000000000000000,10000000000000000000\\}", op); + assert(false); + } catch (const std::regex_error &e) { + assert(e.code() == std::regex_constants::error_badbrace); + LIBCPP_ASSERT(e.code() == std::regex_constants::error_badbrace); + } + } + for (std::regex_constants::syntax_option_type op : + {std::regex::ECMAScript, std::regex::extended, std::regex::egrep, + std::regex::awk}) { + try { + TEST_IGNORE_NODISCARD std::regex("a{100000000000000000000,10000000000000000000}", op); + assert(false); + } catch (const std::regex_error &e) { + assert(e.code() == std::regex_constants::error_badbrace); + LIBCPP_ASSERT(e.code() == std::regex_constants::error_badbrace); + } + } + return 0; +}