Coverage Report

Created: 2026-03-19 06:57

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/logging-log4cxx/src/fuzzers/cpp/TimeBasedRollingPolicyFuzzer.cpp
Line
Count
Source
1
/*
2
 * Licensed to the Apache Software Foundation (ASF) under one or more
3
 * contributor license agreements.  See the NOTICE file distributed with
4
 * this work for additional information regarding copyright ownership.
5
 * The ASF licenses this file to You under the Apache License, Version 2.0
6
 * (the "License"); you may not use this file except in compliance with
7
 * the License.  You may obtain a copy of the License at
8
 *
9
 *      http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 */
17
18
#include "stdint.h"
19
#include <fuzzer/FuzzedDataProvider.h>
20
#include <log4cxx/patternlayout.h>
21
#include <log4cxx/rolling/rollingfileappender.h>
22
#include <log4cxx/rolling/timebasedrollingpolicy.h>
23
#include <log4cxx/logmanager.h>
24
25
#define DATE_PATTERN            "yyyy-MM-dd_HH_mm_ss"
26
418
#define PATTERN_LAYOUT          LOG4CXX_STR("%c{1} - %m%n")
27
28
using namespace log4cxx;
29
using namespace log4cxx::helpers;
30
using namespace log4cxx::rolling;
31
32
// A fuzzer for TimeBasedRollingPolicy
33
418
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
34
418
    FuzzedDataProvider fdp(data, size);
35
36
    // Set up logger
37
418
    Pool            pool;
38
418
    PatternLayoutPtr         layout( new PatternLayout(PATTERN_LAYOUT));
39
418
    RollingFileAppenderPtr  rfa(    new RollingFileAppender());
40
418
    rfa->setAppend(fdp.ConsumeBool());
41
418
    rfa->setLayout(layout);
42
43
418
    TimeBasedRollingPolicyPtr tbrp = TimeBasedRollingPolicyPtr(new TimeBasedRollingPolicy());
44
418
    bool usegz = fdp.ConsumeBool();
45
418
    if(usegz) {
46
175
           tbrp->setFileNamePattern(LogString(LOG4CXX_STR("fuzz-%d{" DATE_PATTERN "}.gz")));
47
243
    } else {
48
243
           tbrp->setFileNamePattern(LogString(LOG4CXX_STR("fuzz-%d{" DATE_PATTERN "}.zip")));
49
243
    }
50
418
    rfa->setFile(LOG4CXX_STR("test.log"));
51
    
52
418
    tbrp->activateOptions(pool);
53
418
    rfa->setRollingPolicy(tbrp);
54
418
    rfa->activateOptions(pool);
55
418
    rfa->setBufferedSeconds(fdp.ConsumeIntegral<int>());
56
418
    rfa->activateOptions(pool);
57
418
    LoggerPtr logger = LogManager::getLogger("org.apache.log4j.TimeBasedRollingTest");
58
418
    logger->addAppender(rfa);
59
    
60
    // Log and rollover
61
4.59k
    for (int i = 0; i < 10; i++)
62
4.18k
    {
63
4.18k
            if (i == 4 || i == 9)
64
836
            {
65
836
                rfa->rollover(pool);
66
836
            }
67
68
4.18k
            LOG4CXX_DEBUG(logger, fdp.ConsumeRandomLengthString());
69
4.18k
    }
70
71
    // Cleanup
72
418
    logger->removeAppender(rfa);
73
418
    rfa->close();
74
418
    LogManager::shutdown();
75
418
    std::remove("test.log");
76
77
418
    return 0;
78
418
}