Commit 98b31d788b827763f7ec97db5a9db4e4dd9f0deb
Committed by
Henry Schreiner
1 parent
b2e471ac
Adding tests and deprecation messages
Showing
7 changed files
with
77 additions
and
2 deletions
CMakeLists.txt
| ... | ... | @@ -31,7 +31,7 @@ if(CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME) |
| 31 | 31 | if(MSVC) |
| 32 | 32 | add_definitions("/W4") |
| 33 | 33 | else() |
| 34 | - add_definitions(-Wall -Wextra -pedantic -Wno-deprecated-declarations) | |
| 34 | + add_definitions(-Wall -Wextra -pedantic) | |
| 35 | 35 | endif() |
| 36 | 36 | |
| 37 | 37 | if(CMAKE_VERSION VERSION_GREATER 3.6) | ... | ... |
include/CLI/App.hpp
| ... | ... | @@ -1039,6 +1039,18 @@ class App { |
| 1039 | 1039 | return formatter_->make_help(this, prev, mode); |
| 1040 | 1040 | } |
| 1041 | 1041 | |
| 1042 | + /// Provided for backwards compatibility \deprecated | |
| 1043 | + CLI11_DEPRECATED("Please use footer instead") | |
| 1044 | + App *set_footer(std::string msg) { return footer(msg); } | |
| 1045 | + | |
| 1046 | + /// Provided for backwards compatibility \deprecated | |
| 1047 | + CLI11_DEPRECATED("Please use name instead") | |
| 1048 | + App *set_name(std::string msg) { return name(msg); } | |
| 1049 | + | |
| 1050 | + /// Provided for backwards compatibility \deprecated | |
| 1051 | + CLI11_DEPRECATED("Please use callback instead") | |
| 1052 | + App *set_callback(std::function<void()> fn) { return callback(fn); } | |
| 1053 | + | |
| 1042 | 1054 | ///@} |
| 1043 | 1055 | /// @name Getters |
| 1044 | 1056 | ///@{ | ... | ... |
include/CLI/Macros.hpp
include/CLI/Option.hpp
| ... | ... | @@ -665,6 +665,10 @@ class Option : public OptionBase<Option> { |
| 665 | 665 | return this; |
| 666 | 666 | } |
| 667 | 667 | |
| 668 | + /// Provided for backward compatibility \deprecated | |
| 669 | + CLI11_DEPRECATED("Please use type_name instead") | |
| 670 | + Option *set_type_name(std::string typeval) { return type_name(typeval); } | |
| 671 | + | |
| 668 | 672 | /// Set a custom option size |
| 669 | 673 | Option *type_size(int type_size) { |
| 670 | 674 | type_size_ = type_size; | ... | ... |
tests/CMakeLists.txt
| ... | ... | @@ -30,6 +30,7 @@ set(CLI11_TESTS |
| 30 | 30 | FormatterTest |
| 31 | 31 | NewParseTest |
| 32 | 32 | OptionalTest |
| 33 | + DeprecatedTest | |
| 33 | 34 | ) |
| 34 | 35 | |
| 35 | 36 | set(CLI11_MULTIONLY_TESTS |
| ... | ... | @@ -66,6 +67,13 @@ foreach(T ${CLI11_MULTIONLY_TESTS}) |
| 66 | 67 | |
| 67 | 68 | endforeach() |
| 68 | 69 | |
| 70 | +# Add -Wno-deprecated-declarations to DeprecatedTest | |
| 71 | +if(NOT MSVC) | |
| 72 | + target_compile_options(DeprecatedTest PRIVATE -Wno-deprecated-declarations) | |
| 73 | + if(TARGET DeprecatedTest_Single) | |
| 74 | + target_compile_options(DeprecatedTest_Single PRIVATE -Wno-deprecated-declarations) | |
| 75 | + endif() | |
| 76 | +endif() | |
| 69 | 77 | |
| 70 | 78 | # Link test (build error if inlines missing) |
| 71 | 79 | add_library(link_test_1 link_test_1.cpp) | ... | ... |
tests/DeprecatedTest.cpp
0 → 100644
| 1 | +#ifdef CLI11_SINGLE_FILE | |
| 2 | +#include "CLI11.hpp" | |
| 3 | +#else | |
| 4 | +#include "CLI/CLI.hpp" | |
| 5 | +#endif | |
| 6 | + | |
| 7 | +#include "gtest/gtest.h" | |
| 8 | + | |
| 9 | +TEST(Deprecated, SetFooter) { | |
| 10 | + CLI::App app{"My prog"}; | |
| 11 | + | |
| 12 | + app.set_footer("My Footer"); | |
| 13 | + EXPECT_EQ("My Footer", app.get_footer()); | |
| 14 | +} | |
| 15 | + | |
| 16 | +TEST(Deprecated, SetName) { | |
| 17 | + CLI::App app{"My prog"}; | |
| 18 | + | |
| 19 | + app.set_name("My Name"); | |
| 20 | + EXPECT_EQ("My Name", app.get_name()); | |
| 21 | +} | |
| 22 | + | |
| 23 | +TEST(Deprecated, SetCallback) { | |
| 24 | + CLI::App app{"My prog"}; | |
| 25 | + | |
| 26 | + bool val; | |
| 27 | + app.set_callback([&val]() { val = true; }); | |
| 28 | + | |
| 29 | + std::vector<std::string> something; | |
| 30 | + app.parse(something); | |
| 31 | + | |
| 32 | + EXPECT_TRUE(val); | |
| 33 | +} | |
| 34 | + | |
| 35 | +TEST(Deprecated, SetTypeName) { | |
| 36 | + CLI::App app{"My prog"}; | |
| 37 | + | |
| 38 | + std::string val; | |
| 39 | + auto opt = app.add_option("--val", val); | |
| 40 | + opt->set_type_name("THAT"); | |
| 41 | + | |
| 42 | + EXPECT_EQ(opt->get_type_name(), "THAT"); | |
| 43 | +} | ... | ... |
tests/HelpTest.cpp
| ... | ... | @@ -561,6 +561,14 @@ TEST(THelp, CustomDoubleOption) { |
| 561 | 561 | EXPECT_THAT(app.help(), Not(HasSubstr("x 2"))); |
| 562 | 562 | } |
| 563 | 563 | |
| 564 | +TEST(THelp, CheckEmptyTypeName) { | |
| 565 | + CLI::App app; | |
| 566 | + | |
| 567 | + auto opt = app.add_flag("-f,--flag"); | |
| 568 | + std::string name = opt->get_type_name(); | |
| 569 | + EXPECT_TRUE(name.empty()); | |
| 570 | +} | |
| 571 | + | |
| 564 | 572 | TEST(THelp, AccessDescription) { |
| 565 | 573 | CLI::App app{"My description goes here"}; |
| 566 | 574 | ... | ... |