Browse Source
			
			
			QA: Add WX_FILENAME split tests
			
				
		QA: Add WX_FILENAME split tests
	
		
	
			
				Add some tests of the filename splitting of WX_FILENAME objects. Interestingly, the result of GetFuillPath on an empty path is likely wrong as it will imply an absolute path from /. But this is probably not a used code path. Document the current behaviour as passing the test. This unit tests covers the code reported by Coverity 183884 and 183894 (improper use of negative). The find_last_of can return "npos" (-1), but it's stored as a size_t. This is correct according the WX docs, and the substr() method it is passed to can handle npos too.pull/13/head
				 2 changed files with 130 additions and 0 deletions
			
			
		| @ -0,0 +1,129 @@ | |||
| /*
 | |||
|  * This program source code file is part of KiCad, a free EDA CAD application. | |||
|  * | |||
|  * Copyright (C) 2019 KiCad Developers, see CHANGELOG.TXT for contributors. | |||
|  * | |||
|  * This program is free software; you can redistribute it and/or | |||
|  * modify it under the terms of the GNU General Public License | |||
|  * as published by the Free Software Foundation; either version 2 | |||
|  * of the License, or (at your option) any later version. | |||
|  * | |||
|  * This program is distributed in the hope that it will be useful, | |||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | |||
|  * GNU General Public License for more details. | |||
|  * | |||
|  * You should have received a copy of the GNU General Public License | |||
|  * along with this program; if not, you may find one here: | |||
|  * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
 | |||
|  * or you may search the http://www.gnu.org website for the version 2 license,
 | |||
|  * or you may write to the Free Software Foundation, Inc., | |||
|  * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA | |||
|  */ | |||
| 
 | |||
| /**
 | |||
|  * @file | |||
|  * Test suite for WX_FILNAME | |||
|  */ | |||
| 
 | |||
| #include <unit_test_utils/unit_test_utils.h>
 | |||
| 
 | |||
| // Code under test
 | |||
| #include <common.h>
 | |||
| 
 | |||
| /**
 | |||
|  * Declare the test suite | |||
|  */ | |||
| BOOST_AUTO_TEST_SUITE( WxFilename ) | |||
| 
 | |||
| 
 | |||
| struct WX_FILENAME_SPLIT_CASE | |||
| { | |||
|     // Ctor params
 | |||
|     std::string m_path; | |||
|     std::string m_name; | |||
| 
 | |||
|     // Split results
 | |||
|     std::string m_exp_name; | |||
|     std::string m_exp_full_name; | |||
|     std::string m_exp_path; | |||
|     std::string m_exp_full_path; | |||
| }; | |||
| 
 | |||
| 
 | |||
| // clang-format off
 | |||
| static const std::vector<WX_FILENAME_SPLIT_CASE> split_cases = { | |||
|     { | |||
|         "", | |||
|         "", | |||
|         "", | |||
|         "", | |||
|         "", | |||
|         "/", // This doesn't look right...
 | |||
|     }, | |||
|     { | |||
|         "", | |||
|         "name.ext", | |||
|         "name", | |||
|         "name.ext", | |||
|         "", | |||
|         "/name.ext", // This doesn't look right...
 | |||
|     }, | |||
|     { | |||
|         "/tmp/example", | |||
|         "", | |||
|         "", | |||
|         "", | |||
|         "/tmp/example", | |||
|         "/tmp/example/", | |||
|     }, | |||
|     { | |||
|         "/tmp/example", | |||
|         "name.ext", | |||
|         "name", | |||
|         "name.ext", | |||
|         "/tmp/example", | |||
|         "/tmp/example/name.ext", | |||
|     }, | |||
|     { | |||
|         "/tmp/example", | |||
|         "name", // no extension
 | |||
|         "name", | |||
|         "name", | |||
|         "/tmp/example", | |||
|         "/tmp/example/name", | |||
|     }, | |||
|     { | |||
|         "/tmp/example", | |||
|         "name.ext1.ext2", // two extensions
 | |||
|         "name.ext1", // remove the first one
 | |||
|         "name.ext1.ext2", | |||
|         "/tmp/example", | |||
|         "/tmp/example/name.ext1.ext2", | |||
|     }, | |||
| }; | |||
| // clang-format on
 | |||
| 
 | |||
| /**
 | |||
|  * Check the various split cases work correctly | |||
|  */ | |||
| BOOST_AUTO_TEST_CASE( Split ) | |||
| { | |||
|     for( const auto& c : split_cases ) | |||
|     { | |||
|         std::stringstream ss; | |||
|         ss << c.m_path << ", " << c.m_name; | |||
|         BOOST_TEST_CONTEXT( ss.str() ) | |||
|         { | |||
|             // Const: all methods called must be const
 | |||
|             const WX_FILENAME wx_fn( c.m_path, c.m_name ); | |||
| 
 | |||
|             BOOST_CHECK_EQUAL( c.m_exp_name, wx_fn.GetName() ); | |||
|             BOOST_CHECK_EQUAL( c.m_exp_full_name, wx_fn.GetFullName() ); | |||
|             BOOST_CHECK_EQUAL( c.m_exp_path, wx_fn.GetPath() ); | |||
|             BOOST_CHECK_EQUAL( c.m_exp_full_path, wx_fn.GetFullPath() ); | |||
|         } | |||
|     } | |||
| } | |||
| 
 | |||
| BOOST_AUTO_TEST_SUITE_END() | |||
						Write
						Preview
					
					
					Loading…
					
					Cancel
						Save
					
		Reference in new issue