2012-10-26 20:42:41 +00:00
|
|
|
// Copyright (c) 2012 The Chromium Embedded Framework Authors. All rights
|
|
|
|
// reserved. Use of this source code is governed by a BSD-style license that
|
|
|
|
// can be found in the LICENSE file.
|
|
|
|
|
2015-01-31 00:55:56 +00:00
|
|
|
#ifndef CEF_TESTS_CEFCLIENT_RENDERER_PERFORMANCE_TEST_SETUP_H_
|
|
|
|
#define CEF_TESTS_CEFCLIENT_RENDERER_PERFORMANCE_TEST_SETUP_H_
|
2012-10-26 20:42:41 +00:00
|
|
|
#pragma once
|
|
|
|
|
2014-07-11 20:10:05 +00:00
|
|
|
#include "include/base/cef_macros.h"
|
|
|
|
#include "include/base/cef_logging.h"
|
2012-10-26 20:42:41 +00:00
|
|
|
|
2015-01-22 20:21:21 +00:00
|
|
|
namespace client {
|
2012-10-26 20:42:41 +00:00
|
|
|
namespace performance_test {
|
|
|
|
|
|
|
|
// Default number of iterations.
|
2013-08-14 21:45:22 +00:00
|
|
|
extern const int kDefaultIterations;
|
2012-10-26 20:42:41 +00:00
|
|
|
|
|
|
|
// Test name.
|
|
|
|
#define PERF_TEST_NAME(name) PerfTest##name
|
|
|
|
|
|
|
|
// Entry in test array.
|
|
|
|
#define PERF_TEST_ENTRY_EX(name, iterations) \
|
|
|
|
{ #name, PERF_TEST_NAME(name), iterations }
|
|
|
|
#define PERF_TEST_ENTRY(name) PERF_TEST_ENTRY_EX(name, kDefaultIterations)
|
|
|
|
|
|
|
|
// Test function declaration.
|
|
|
|
#define PERF_TEST_RESULT int64
|
|
|
|
#define PERF_TEST_PARAM_ITERATIONS iterations
|
2013-08-14 21:45:22 +00:00
|
|
|
#define PERF_TEST_PARAMS int PERF_TEST_PARAM_ITERATIONS
|
2012-10-26 20:42:41 +00:00
|
|
|
#define PERF_TEST_FUNC(name) \
|
|
|
|
PERF_TEST_RESULT PERF_TEST_NAME(name)(PERF_TEST_PARAMS)
|
|
|
|
|
|
|
|
// Typedef for test pointers.
|
|
|
|
typedef PERF_TEST_RESULT(PerfTest(PERF_TEST_PARAMS));
|
|
|
|
|
|
|
|
class CefTimer {
|
|
|
|
public:
|
|
|
|
CefTimer() : running_(false) {
|
|
|
|
}
|
|
|
|
|
|
|
|
bool IsRunning() { return running_; }
|
|
|
|
|
|
|
|
void Start() {
|
2014-07-11 20:10:05 +00:00
|
|
|
DCHECK(!running_);
|
2012-10-26 20:42:41 +00:00
|
|
|
running_ = true;
|
|
|
|
start_.Now();
|
|
|
|
}
|
|
|
|
|
|
|
|
void Stop() {
|
|
|
|
stop_.Now();
|
2014-07-11 20:10:05 +00:00
|
|
|
DCHECK(running_);
|
2012-10-26 20:42:41 +00:00
|
|
|
running_ = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
int64 Delta() {
|
2014-07-11 20:10:05 +00:00
|
|
|
DCHECK(!running_);
|
2012-10-26 20:42:41 +00:00
|
|
|
return start_.Delta(stop_);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
bool running_;
|
|
|
|
CefTime start_;
|
|
|
|
CefTime stop_;
|
2014-07-11 20:10:05 +00:00
|
|
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(CefTimer);
|
2012-10-26 20:42:41 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Peform test iterations using a user-provided timing result variable.
|
|
|
|
#define PERF_ITERATIONS_START_EX() \
|
|
|
|
{ \
|
|
|
|
CefTimer _timer; \
|
|
|
|
_timer.Start(); \
|
2013-08-14 21:45:22 +00:00
|
|
|
for (int _i = 0; _i < PERF_TEST_PARAM_ITERATIONS; ++_i) {
|
2012-10-26 20:42:41 +00:00
|
|
|
|
|
|
|
#define PERF_ITERATIONS_END_EX(result) \
|
|
|
|
} \
|
|
|
|
_timer.Stop(); \
|
|
|
|
result = _timer.Delta(); \
|
|
|
|
}
|
|
|
|
|
|
|
|
// Perform test iterations and return the timing result.
|
|
|
|
#define PERF_ITERATIONS_START() \
|
|
|
|
int64 _result = 0; \
|
|
|
|
PERF_ITERATIONS_START_EX()
|
|
|
|
|
|
|
|
#define PERF_ITERATIONS_END() \
|
|
|
|
PERF_ITERATIONS_END_EX(_result) \
|
|
|
|
return _result;
|
|
|
|
|
|
|
|
// Perf test entry structure.
|
|
|
|
struct PerfTestEntry {
|
|
|
|
const char* name;
|
|
|
|
PerfTest* test;
|
2013-08-14 21:45:22 +00:00
|
|
|
int iterations;
|
2012-10-26 20:42:41 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Array of perf tests.
|
|
|
|
extern const PerfTestEntry kPerfTests[];
|
2013-08-14 21:45:22 +00:00
|
|
|
extern const int kPerfTestsCount;
|
2012-10-26 20:42:41 +00:00
|
|
|
|
|
|
|
} // namespace performance_test
|
2015-01-22 20:21:21 +00:00
|
|
|
} // namespace client
|
2012-10-26 20:42:41 +00:00
|
|
|
|
2015-01-31 00:55:56 +00:00
|
|
|
#endif // CEF_TESTS_CEFCLIENT_RENDERER_PERFORMANCE_TEST_H_
|