forked from catchorg/Catch2
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
v3.7.1 === Improvements === * Applied the JUnit reporter's optimization from last release to the SonarQube reporter * Suppressed `-Wuseless-cast` in `CHECK_THROWS_MATCHES` (catchorg#2904) * Standardize exit codes for various failures * Running no tests is now guaranteed to exit with 2 (without the `--allow-running-no-tests` flag) * All tests skipped is now always 4 (...) * Assertion failures are now always 42 * and so on === Fixes === * Fixed out-of-bounds access when the arg parser encounters single `-` as an argument (catchorg#2905) === Miscellaneous === * Added `catch_config_prefix_messages.hpp` to meson build (catchorg#2903) * `catch_discover_tests` now supports skipped tests (catchorg#2873) * You can get the old behaviour by calling `catch_discover_tests` with `SKIP_IS_FAILURE` option. # -----BEGIN PGP SIGNATURE----- # # iQIzBAABCgAdFiEE8QyLZSqAHw/oZQgX3kgwe4sNOBoFAmbpQnMACgkQ3kgwe4sN # OBpa1Q//UbNsxKpLU7cKzCr3kEOOc2RsryS5foHYRs+mhUzOFYf4y1HkSdvzc3TV # ZUI8sA5FA1OVO7JtCSpgzizF5vGiOunDFGgroSw9kIxsX0KtHugksNgQcU7QeFEf # 6KqtKb4/tmRryuyoHZTdWMxBGpB4dtc3zy1Yq+ebe8k52neBmilb80Mz9KbuQ4vT # QAXz7xWiZukHyxosmKZe5kxDLF3Ck5iVCvvUJu9iwiE6Ua8TIJgs+sOFApsQztmu # 5hwrmajqZGLB65RQe4G6AXScNLGnzRTJwByR5fg+YFZQmUdjSE0oQ6rd2Ni9qk5c # QUOPBAVA2A3rahnV3k9bY6SapFjeTZlO4/go9eSzswc2CU7LCX0jRME5d+oW6YJ4 # H0XgacVYM362Exd4hKsSplfuvwkRi1irlnGxHpTvBLBp1czJgUnQV1lwsncaiQFx # IZfxiqot+V0fPEweVkgHOwf175o9SLLZka6546MFgSvWY8yEEMnl3nLrmeHhCFPq # 70MdKcj/Qbzkzd5PTSuUoUhxIFZJMzsszj9b0pdGlCb5ObRMcN0UHKG9nVNXWTmn # tWnukCdzGHsZzaHjH/J0IY8P9ANNjAb5xtROzuF5TmE6h+D5J6kwxGTqZoCyqmC/ # FyPPf1WYkrU2qj+ms7SbdyGlE7s1w8VF/7p3/EKwoE2fpZk/9WM= # =lDEO # -----END PGP SIGNATURE----- # gpg: Signature made Tue Sep 17 10:48:51 2024 WEDT # gpg: using RSA key F10C8B652A801F0FE8650817DE48307B8B0D381A # gpg: Can't check signature: No public key # Conflicts: # README.md # conanfile.py # docs/release-notes.md # docs/tutorial.md # include/internal/catch_compiler_capabilities.h # include/internal/catch_debugger.h # include/internal/catch_evaluate.hpp # include/internal/catch_expression_lhs.hpp # include/internal/catch_fatal_condition.hpp # include/internal/catch_message.hpp # include/internal/catch_result_builder.hpp # include/internal/catch_run_context.hpp # include/internal/catch_test_case_registry_impl.hpp # include/reporters/catch_reporter_console.hpp # include/reporters/catch_reporter_teamcity.hpp # include/reporters/catch_reporter_xml.hpp # scripts/updateVcpkgPackage.py # single_include/catch.hpp # src/catch2/catch_version.cpp # test_package/conanfile.py
- Loading branch information
Showing
734 changed files
with
199,428 additions
and
53,061 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
build --enable_platform_specific_config | ||
|
||
build:gcc9 --cxxopt=-std=c++2a | ||
build:gcc11 --cxxopt=-std=c++2a | ||
build:clang13 --cxxopt=-std=c++17 | ||
build:vs2019 --cxxopt=/std:c++17 | ||
build:vs2022 --cxxopt=/std:c++17 | ||
|
||
build:windows --config=vs2022 | ||
build:linux --config=gcc11 | ||
build:macos --cxxopt=-std=c++2b |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
--- | ||
Language: Cpp | ||
Standard: c++14 | ||
|
||
# Note that we cannot use IncludeIsMainRegex functionality, because it | ||
# does not support includes in angle brackets (<>) | ||
SortIncludes: true | ||
IncludeBlocks: Regroup | ||
IncludeCategories: | ||
- Regex: <catch2/.*\.hpp> | ||
Priority: 1 | ||
- Regex: <.*/.*\.hpp> | ||
Priority: 2 | ||
- Regex: <.*> | ||
Priority: 3 | ||
|
||
AllowShortBlocksOnASingleLine: Always | ||
AllowShortEnumsOnASingleLine: false | ||
AllowShortFunctionsOnASingleLine: All | ||
AllowShortIfStatementsOnASingleLine: WithoutElse | ||
AllowShortLambdasOnASingleLine: Inline | ||
|
||
AccessModifierOffset: "-4" | ||
AlignEscapedNewlines: Left | ||
AllowAllConstructorInitializersOnNextLine: "true" | ||
BinPackArguments: "false" | ||
BinPackParameters: "false" | ||
BreakConstructorInitializers: AfterColon | ||
ConstructorInitializerAllOnOneLineOrOnePerLine: "true" | ||
DerivePointerAlignment: "false" | ||
FixNamespaceComments: "true" | ||
IndentCaseLabels: "false" | ||
IndentPPDirectives: AfterHash | ||
IndentWidth: "4" | ||
NamespaceIndentation: All | ||
PointerAlignment: Left | ||
SpaceBeforeCtorInitializerColon: "false" | ||
SpaceInEmptyParentheses: "false" | ||
SpacesInParentheses: "true" | ||
TabWidth: "4" | ||
UseTab: Never | ||
AlwaysBreakTemplateDeclarations: Yes | ||
SpaceAfterTemplateKeyword: true | ||
SortUsingDeclarations: true | ||
ReflowComments: true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,81 @@ | ||
--- | ||
# Note: Alas, `Checks` is a string, not an array. | ||
# Comments in the block string are not parsed and are passed in the value. | ||
# They must thus be delimited by ',' from either side - then they are | ||
# harmless. It's terrible, but it works. | ||
Checks: >- | ||
clang-diagnostic-*, | ||
clang-analyzer-*, | ||
-clang-analyzer-optin.core.EnumCastOutOfRange, | ||
bugprone-*, | ||
-bugprone-unchecked-optional-access, | ||
,# This is ridiculous, as it triggers on constants, | ||
-bugprone-implicit-widening-of-multiplication-result, | ||
-bugprone-easily-swappable-parameters, | ||
,# Is not really useful, has false positives, triggers for no-noexcept move constructors ..., | ||
-bugprone-exception-escape, | ||
-bugprone-narrowing-conversions, | ||
-bugprone-chained-comparison,# RIP decomposers, | ||
modernize-*, | ||
-modernize-avoid-c-arrays, | ||
-modernize-use-auto, | ||
-modernize-use-emplace, | ||
-modernize-use-nullptr,# it went crazy with three-way comparison operators, | ||
-modernize-use-trailing-return-type, | ||
-modernize-return-braced-init-list, | ||
-modernize-concat-nested-namespaces, | ||
-modernize-use-nodiscard, | ||
-modernize-use-default-member-init, | ||
-modernize-type-traits,# we need to support C++14, | ||
-modernize-deprecated-headers, | ||
,# There's a lot of these and most of them are probably not useful, | ||
-modernize-pass-by-value, | ||
performance-*, | ||
-performance-enum-size, | ||
portability-*, | ||
readability-*, | ||
-readability-braces-around-statements, | ||
-readability-container-size-empty, | ||
-readability-convert-member-functions-to-static, | ||
-readability-else-after-return, | ||
-readability-function-cognitive-complexity, | ||
-readability-function-size, | ||
-readability-identifier-length, | ||
-readability-implicit-bool-conversion, | ||
-readability-isolate-declaration, | ||
-readability-magic-numbers, | ||
-readability-named-parameter, | ||
-readability-qualified-auto, | ||
-readability-redundant-access-specifiers, | ||
-readability-simplify-boolean-expr, | ||
-readability-static-definition-in-anonymous-namespace, | ||
-readability-uppercase-literal-suffix, | ||
-readability-use-anyofallof, | ||
-readability-avoid-return-with-void-value, | ||
,# time hogs, | ||
-bugprone-throw-keyword-missing, | ||
-modernize-replace-auto-ptr, | ||
-readability-identifier-naming, | ||
,# We cannot use this until clang-tidy supports custom unique_ptr, | ||
-bugprone-use-after-move, | ||
,# Doesn't recognize unevaluated context in CATCH_MOVE and CATCH_FORWARD, | ||
-bugprone-macro-repeated-side-effects, | ||
WarningsAsErrors: >- | ||
clang-analyzer-core.*, | ||
clang-analyzer-cplusplus.*, | ||
clang-analyzer-security.*, | ||
clang-analyzer-unix.*, | ||
performance-move-const-arg, | ||
performance-unnecessary-value-param, | ||
readability-duplicate-include, | ||
HeaderFilterRegex: '.*\.(c|cxx|cpp)$' | ||
FormatStyle: none | ||
CheckOptions: {} | ||
... |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
#!/usr/bin/env python | ||
# -*- coding: utf-8 -*- | ||
|
||
import os | ||
import re | ||
from cpt.packager import ConanMultiPackager | ||
from cpt.ci_manager import CIManager | ||
from cpt.printer import Printer | ||
|
||
|
||
class BuilderSettings(object): | ||
@property | ||
def username(self): | ||
""" Set catchorg as package's owner | ||
""" | ||
return os.getenv("CONAN_USERNAME", "catchorg") | ||
|
||
@property | ||
def login_username(self): | ||
""" Set Bintray login username | ||
""" | ||
return os.getenv("CONAN_LOGIN_USERNAME", "horenmar") | ||
|
||
@property | ||
def upload(self): | ||
""" Set Catch2 repository to be used on upload. | ||
The upload server address could be customized by env var | ||
CONAN_UPLOAD. If not defined, the method will check the branch name. | ||
Only devel or CONAN_STABLE_BRANCH_PATTERN will be accepted. | ||
The devel branch will be pushed to testing channel, because it does | ||
not match the stable pattern. Otherwise it will upload to stable | ||
channel. | ||
""" | ||
return os.getenv("CONAN_UPLOAD", "https://api.bintray.com/conan/catchorg/catch2") | ||
|
||
@property | ||
def upload_only_when_stable(self): | ||
""" Force to upload when running over tag branch | ||
""" | ||
return os.getenv("CONAN_UPLOAD_ONLY_WHEN_STABLE", "True").lower() in ["true", "1", "yes"] | ||
|
||
@property | ||
def stable_branch_pattern(self): | ||
""" Only upload the package the branch name is like a tag | ||
""" | ||
return os.getenv("CONAN_STABLE_BRANCH_PATTERN", r"v\d+\.\d+\.\d+") | ||
|
||
@property | ||
def reference(self): | ||
""" Read project version from branch create Conan reference | ||
""" | ||
return os.getenv("CONAN_REFERENCE", "catch2/{}".format(self._version)) | ||
|
||
@property | ||
def channel(self): | ||
""" Default Conan package channel when not stable | ||
""" | ||
return os.getenv("CONAN_CHANNEL", "testing") | ||
|
||
@property | ||
def _version(self): | ||
""" Get version name from cmake file | ||
""" | ||
pattern = re.compile(r"project\(Catch2 LANGUAGES CXX VERSION (\d+\.\d+\.\d+)\)") | ||
version = "latest" | ||
with open("CMakeLists.txt") as file: | ||
for line in file: | ||
result = pattern.search(line) | ||
if result: | ||
version = result.group(1) | ||
return version | ||
|
||
@property | ||
def _branch(self): | ||
""" Get branch name from CI manager | ||
""" | ||
printer = Printer(None) | ||
ci_manager = CIManager(printer) | ||
return ci_manager.get_branch() | ||
|
||
|
||
if __name__ == "__main__": | ||
settings = BuilderSettings() | ||
builder = ConanMultiPackager( | ||
reference=settings.reference, | ||
channel=settings.channel, | ||
upload=settings.upload, | ||
upload_only_when_stable=False, | ||
stable_branch_pattern=settings.stable_branch_pattern, | ||
login_username=settings.login_username, | ||
username=settings.username, | ||
test_folder=os.path.join(".conan", "test_package")) | ||
builder.add() | ||
builder.run() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
cmake_minimum_required(VERSION 3.15) | ||
project(PackageTest CXX) | ||
|
||
find_package(Catch2 CONFIG REQUIRED) | ||
|
||
add_executable(test_package test_package.cpp) | ||
target_link_libraries(test_package Catch2::Catch2WithMain) | ||
target_compile_features(test_package PRIVATE cxx_std_14) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
#!/usr/bin/env python | ||
# -*- coding: utf-8 -*- | ||
from conan import ConanFile | ||
from conan.tools.cmake import CMake, cmake_layout | ||
from conan.tools.build import can_run | ||
from conan.tools.files import save, load | ||
import os | ||
|
||
|
||
class TestPackageConan(ConanFile): | ||
settings = "os", "compiler", "build_type", "arch" | ||
generators = "CMakeToolchain", "CMakeDeps", "VirtualRunEnv" | ||
test_type = "explicit" | ||
|
||
def requirements(self): | ||
self.requires(self.tested_reference_str) | ||
|
||
def layout(self): | ||
cmake_layout(self) | ||
|
||
def generate(self): | ||
save(self, os.path.join(self.build_folder, "package_folder"), | ||
self.dependencies[self.tested_reference_str].package_folder) | ||
save(self, os.path.join(self.build_folder, "license"), | ||
self.dependencies[self.tested_reference_str].license) | ||
|
||
def build(self): | ||
cmake = CMake(self) | ||
cmake.configure() | ||
cmake.build() | ||
|
||
def test(self): | ||
if can_run(self): | ||
cmd = os.path.join(self.cpp.build.bindir, "test_package") | ||
self.run(cmd, env="conanrun") | ||
|
||
package_folder = load(self, os.path.join(self.build_folder, "package_folder")) | ||
license = load(self, os.path.join(self.build_folder, "license")) | ||
assert os.path.isfile(os.path.join(package_folder, "licenses", "LICENSE.txt")) | ||
assert license == 'BSL-1.0' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
#include <catch2/catch_test_macros.hpp> | ||
|
||
int Factorial( int number ) { | ||
return number <= 1 ? 1 : Factorial( number - 1 ) * number; | ||
} | ||
|
||
TEST_CASE( "Factorial Tests", "[single-file]" ) { | ||
REQUIRE( Factorial(0) == 1 ); | ||
REQUIRE( Factorial(1) == 1 ); | ||
REQUIRE( Factorial(2) == 2 ); | ||
REQUIRE( Factorial(3) == 6 ); | ||
REQUIRE( Factorial(10) == 3628800 ); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
github: "horenmar" | ||
custom: "https://www.paypal.me/horenmar" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
--- | ||
name: Bug report | ||
about: Create an issue that documents a bug | ||
title: '' | ||
labels: '' | ||
assignees: '' | ||
|
||
--- | ||
|
||
**Describe the bug** | ||
A clear and concise description of what the bug is. | ||
|
||
**Expected behavior** | ||
A clear and concise description of what you expected to happen. | ||
|
||
**Reproduction steps** | ||
Steps to reproduce the bug. | ||
<!-- Usually this means a small and self-contained piece of code that uses Catch and specifying compiler flags if relevant. --> | ||
|
||
|
||
**Platform information:** | ||
<!-- Fill in any extra information that might be important for your issue. --> | ||
- OS: **Windows NT** | ||
- Compiler+version: **GCC v2.9.5** | ||
- Catch version: **v1.2.3** | ||
|
||
|
||
**Additional context** | ||
Add any other context about the problem here. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
--- | ||
name: Feature request | ||
about: Create an issue that requests a feature or other improvement | ||
title: '' | ||
labels: '' | ||
assignees: '' | ||
|
||
--- | ||
|
||
**Description** | ||
Describe the feature/change you request and why do you want it. | ||
|
||
**Additional context** | ||
Add any other context or screenshots about the feature request here. |
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.