Line data Source code
1 : /****************************************************************************** 2 : * $Id$ 3 : * 4 : * Project: GDAL 5 : * Purpose: Test CPL_LOG 6 : * Author: Even Rouault, even.rouault at spatialys.com 7 : * 8 : ****************************************************************************** 9 : * Copyright (c) 2021, Even Rouault <even.rouault at spatialys.com> 10 : * 11 : * Permission is hereby granted, free of charge, to any person obtaining a 12 : * copy of this software and associated documentation files (the "Software"), 13 : * to deal in the Software without restriction, including without limitation 14 : * the rights to use, copy, modify, merge, publish, distribute, sublicense, 15 : * and/or sell copies of the Software, and to permit persons to whom the 16 : * Software is furnished to do so, subject to the following conditions: 17 : * 18 : * The above copyright notice and this permission notice shall be included 19 : * in all copies or substantial portions of the Software. 20 : * 21 : * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 22 : * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 23 : * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 24 : * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 25 : * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 26 : * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 27 : * DEALINGS IN THE SOFTWARE. 28 : ****************************************************************************/ 29 : 30 : #include "cpl_conv.h" 31 : #include "cpl_error.h" 32 : #include "cpl_vsi.h" 33 : 34 : #include "gtest_include.h" 35 : 36 : namespace 37 : { 38 : 39 : // --------------------------------------------------------------------------- 40 : 41 4 : TEST(testlog, test) 42 : { 43 1 : const char *logname = "log_with_âccent.txt"; 44 1 : CPLSetConfigOption("CPL_LOG", logname); 45 1 : CPLError(CE_Failure, CPLE_AppDefined, "test"); 46 1 : VSILFILE *fp = VSIFOpenL(logname, "rb"); 47 : char szGot[20 + 1]; 48 1 : size_t nRead = VSIFReadL(szGot, 1, 20, fp); 49 1 : szGot[nRead] = 0; 50 1 : VSIFCloseL(fp); 51 1 : CPLCleanupErrorMutex(); 52 1 : VSIUnlink(logname); 53 : 54 1 : EXPECT_TRUE(strstr(szGot, "ERROR 1") != nullptr) << szGot; 55 1 : EXPECT_TRUE(strstr(szGot, "test") != nullptr) << szGot; 56 1 : } 57 : 58 : } // namespace