Joe Onorato e547205eec Get incidentd cts working again.
- The buffer size increased, and the CTS test that checked that
  was triggering.
- Privacy filtering wasn't working for the stack trace sections
- The incident command was not handling the default arguments correctly
- The throttler was throttling streaming reports, which made the
  test flaky.

Bug: 126253679
Test: atest CtsIncidentHostTestCases
Change-Id: I342cd7d0421ea8c22b7796fc99e779f21855af73
2019-04-26 17:44:10 -07:00

61 lines
1.5 KiB
C++

/*
* Copyright (C) 2018 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#pragma once
#include "Reporter.h"
#include <utils/RefBase.h>
#include <vector>
#include <unistd.h>
namespace android {
namespace os {
namespace incidentd {
/**
* This is a size-based throttler which prevents incidentd to take more data.
*/
class Throttler : public virtual android::RefBase {
public:
Throttler(size_t limit, int64_t refractoryPeriodMs);
~Throttler();
/**
* Return a batch containing reports, if any that should be executed.
* Those will be removed from 'queued'.
*/
sp<ReportBatch> filterBatch(const sp<ReportBatch>& queued);
bool shouldThrottle();
void addReportSize(size_t reportByteSize);
void dump(FILE* out);
private:
const size_t mSizeLimit;
const int64_t mRefractoryPeriodMs;
size_t mAccumulatedSize;
int64_t mLastRefractoryMs;
};
} // namespace incidentd
} // namespace os
} // namespace android