256 lines
10 KiB
C
256 lines
10 KiB
C
#ifndef _QPTESTLOG_H
|
|
#define _QPTESTLOG_H
|
|
/*-------------------------------------------------------------------------
|
|
* drawElements Quality Program Helper Library
|
|
* -------------------------------------------
|
|
*
|
|
* Copyright 2014 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.
|
|
*
|
|
*//*!
|
|
* \defgroup TestLog
|
|
* \ingroup TestLog
|
|
* \{
|
|
* \file
|
|
* \brief Test log library
|
|
*
|
|
* qpTestLog Conventions:
|
|
*
|
|
* Each function takes qpTestLog pointer. Operations are done on that log
|
|
* instance.
|
|
*
|
|
* When function takes a 'name' parameter, that name is expected to
|
|
* be a unique identifier within the scope of one test case. Test case
|
|
* begins with a call to qpTestLog_startCase and ends with a call to
|
|
* qpTestLog_endCase or qpTestLog_terminateCase. The human readable
|
|
* "name" for a piece of information is given with the parameter
|
|
* called 'description'.
|
|
*
|
|
* All functions writing to the log return a boolean value. False
|
|
* means that the current write operation failed and the current log
|
|
* instance should be abandoned.
|
|
*
|
|
*//*--------------------------------------------------------------------*/
|
|
|
|
#include "deDefs.h"
|
|
|
|
typedef struct qpTestLog_s qpTestLog;
|
|
|
|
/* Test results supported by current report version */
|
|
/* \note Keep in sync with TestCaseStatus in Candy project. */
|
|
typedef enum qpTestResult_e
|
|
{
|
|
QP_TEST_RESULT_PASS = 0, /*!< Test case passed. */
|
|
QP_TEST_RESULT_FAIL, /*!< Implementation produced incorrect results */
|
|
QP_TEST_RESULT_QUALITY_WARNING, /*!< Result is within specification, but is not of high quality */
|
|
QP_TEST_RESULT_COMPATIBILITY_WARNING, /*!< Result is within specification, but likely to cause fragmentation in the market */
|
|
QP_TEST_RESULT_PENDING, /*!< The test is still running. Not a valid end result */
|
|
QP_TEST_RESULT_NOT_SUPPORTED, /*!< Implementation does not support functionality needed by this test case */
|
|
QP_TEST_RESULT_RESOURCE_ERROR, /*!< Implementation fails to pass the test due to lack of resources */
|
|
QP_TEST_RESULT_INTERNAL_ERROR, /*!< Error occurred within Tester Core */
|
|
QP_TEST_RESULT_CRASH, /*!< Crash occurred in test execution. */
|
|
QP_TEST_RESULT_TIMEOUT, /*!< Timeout occurred in test execution. */
|
|
QP_TEST_RESULT_WAIVER, /*!< Status code reported by waived test. */
|
|
|
|
QP_TEST_RESULT_LAST
|
|
} qpTestResult;
|
|
|
|
/* Test case types. */
|
|
typedef enum qpTestCaseType_e
|
|
{
|
|
QP_TEST_CASE_TYPE_SELF_VALIDATE = 0, /*!< Self-validating test case */
|
|
QP_TEST_CASE_TYPE_PERFORMANCE, /*!< Performace test case */
|
|
QP_TEST_CASE_TYPE_CAPABILITY, /*!< Capability score case */
|
|
QP_TEST_CASE_TYPE_ACCURACY, /*!< Accuracy test case */
|
|
|
|
QP_TEST_CASE_TYPE_LAST
|
|
} qpTestCaseType;
|
|
|
|
/*--------------------------------------------------------------------*//*!
|
|
* \brief Tag key-value pairs to give cues on proper visualization in GUI
|
|
*//*--------------------------------------------------------------------*/
|
|
typedef enum qpKeyValueTag_e
|
|
{
|
|
QP_KEY_TAG_NONE = 0,
|
|
QP_KEY_TAG_PERFORMANCE,
|
|
QP_KEY_TAG_QUALITY,
|
|
QP_KEY_TAG_PRECISION,
|
|
QP_KEY_TAG_TIME,
|
|
|
|
/* Add new values here if needed, remember to update relevant code in qpTestLog.c and change format revision */
|
|
|
|
QP_KEY_TAG_LAST /* Do not remove */
|
|
} qpKeyValueTag;
|
|
|
|
/*--------------------------------------------------------------------*//*!
|
|
* \brief Sample value tag for giving hints for analysis
|
|
*//*--------------------------------------------------------------------*/
|
|
typedef enum qpSampleValueTag_e
|
|
{
|
|
QP_SAMPLE_VALUE_TAG_PREDICTOR = 0, /*!< Predictor for sample, such as number of operations. */
|
|
QP_SAMPLE_VALUE_TAG_RESPONSE, /*!< Response, i.e. measured value, such as render time. */
|
|
|
|
/* Add new values here if needed, remember to update relevant code in qpTestLog.c and change format revision */
|
|
|
|
QP_SAMPLE_VALUE_TAG_LAST /* Do not remove */
|
|
} qpSampleValueTag;
|
|
|
|
/* Image compression type. */
|
|
typedef enum qpImageCompressionMode_e
|
|
{
|
|
QP_IMAGE_COMPRESSION_MODE_NONE = 0, /*!< Do not compress images. */
|
|
QP_IMAGE_COMPRESSION_MODE_PNG, /*!< Compress images using lossless libpng. */
|
|
QP_IMAGE_COMPRESSION_MODE_BEST, /*!< Choose the best image compression mode. */
|
|
|
|
QP_IMAGE_COMPRESSION_MODE_LAST
|
|
} qpImageCompressionMode;
|
|
|
|
/*--------------------------------------------------------------------*//*!
|
|
* \brief Image formats.
|
|
*
|
|
* Pixels are handled as a byte stream, i.e., endianess does not
|
|
* affect component ordering.
|
|
*//*--------------------------------------------------------------------*/
|
|
typedef enum qpImageFormat_e
|
|
{
|
|
QP_IMAGE_FORMAT_RGB888 = 0,
|
|
QP_IMAGE_FORMAT_RGBA8888,
|
|
|
|
QP_IMAGE_FORMAT_LAST
|
|
} qpImageFormat;
|
|
|
|
/* Test log flags. */
|
|
typedef enum qpTestLogFlag_e
|
|
{
|
|
QP_TEST_LOG_EXCLUDE_IMAGES = (1<<0), /*!< Do not log images. This reduces log size considerably. */
|
|
QP_TEST_LOG_EXCLUDE_SHADER_SOURCES = (1<<1), /*!< Do not log shader sources. Helps to reduce log size further. */
|
|
QP_TEST_LOG_NO_FLUSH = (1<<2), /*!< Do not do a fflush after writing the log. */
|
|
QP_TEST_LOG_EXCLUDE_EMPTY_LOGINFO = (1<<3), /*!< Do not log empty shader compile or link loginfo. */
|
|
} qpTestLogFlag;
|
|
|
|
/* Shader type. */
|
|
typedef enum qpShaderType_e
|
|
{
|
|
QP_SHADER_TYPE_VERTEX = 0,
|
|
QP_SHADER_TYPE_FRAGMENT,
|
|
QP_SHADER_TYPE_GEOMETRY,
|
|
QP_SHADER_TYPE_TESS_CONTROL,
|
|
QP_SHADER_TYPE_TESS_EVALUATION,
|
|
QP_SHADER_TYPE_COMPUTE,
|
|
QP_SHADER_TYPE_RAYGEN,
|
|
QP_SHADER_TYPE_ANY_HIT,
|
|
QP_SHADER_TYPE_CLOSEST_HIT,
|
|
QP_SHADER_TYPE_MISS,
|
|
QP_SHADER_TYPE_INTERSECTION,
|
|
QP_SHADER_TYPE_CALLABLE,
|
|
QP_SHADER_TYPE_TASK,
|
|
QP_SHADER_TYPE_MESH,
|
|
|
|
QP_SHADER_TYPE_LAST
|
|
} qpShaderType;
|
|
|
|
DE_BEGIN_EXTERN_C
|
|
|
|
/* \todo [2013-04-13 pyry] Clean up & document. Do we actually want this? */
|
|
typedef struct qpEglConfigInfo_s
|
|
{
|
|
int bufferSize;
|
|
int redSize;
|
|
int greenSize;
|
|
int blueSize;
|
|
int luminanceSize;
|
|
int alphaSize;
|
|
int alphaMaskSize;
|
|
deBool bindToTextureRGB;
|
|
deBool bindToTextureRGBA;
|
|
const char* colorBufferType;
|
|
const char* configCaveat;
|
|
int configID;
|
|
const char* conformant;
|
|
int depthSize;
|
|
int level;
|
|
int maxPBufferWidth;
|
|
int maxPBufferHeight;
|
|
int maxPBufferPixels;
|
|
int maxSwapInterval;
|
|
int minSwapInterval;
|
|
deBool nativeRenderable;
|
|
const char* renderableType;
|
|
int sampleBuffers;
|
|
int samples;
|
|
int stencilSize;
|
|
const char* surfaceTypes;
|
|
const char* transparentType;
|
|
int transparentRedValue;
|
|
int transparentGreenValue;
|
|
int transparentBlueValue;
|
|
} qpEglConfigInfo;
|
|
|
|
|
|
qpTestLog* qpTestLog_createFileLog (const char* fileName, deUint32 flags);
|
|
deBool qpTestLog_beginSession (qpTestLog* log, const char* additionalSessionInfo);
|
|
void qpTestLog_destroy (qpTestLog* log);
|
|
|
|
deBool qpTestLog_startCase (qpTestLog* log, const char* testCasePath, qpTestCaseType testCaseType);
|
|
deBool qpTestLog_endCase (qpTestLog* log, qpTestResult result, const char* description);
|
|
|
|
deBool qpTestLog_startTestsCasesTime (qpTestLog* log);
|
|
deBool qpTestLog_endTestsCasesTime (qpTestLog* log);
|
|
|
|
deBool qpTestLog_terminateCase (qpTestLog* log, qpTestResult result);
|
|
|
|
deBool qpTestLog_startSection (qpTestLog* log, const char* name, const char* description);
|
|
deBool qpTestLog_endSection (qpTestLog* log);
|
|
deBool qpTestLog_writeText (qpTestLog* log, const char* name, const char* description, qpKeyValueTag tag, const char* value);
|
|
deBool qpTestLog_writeInteger (qpTestLog* log, const char* name, const char* description, const char* unit, qpKeyValueTag tag, deInt64 value);
|
|
deBool qpTestLog_writeFloat (qpTestLog* log, const char* name, const char* description, const char* unit, qpKeyValueTag tag, float value);
|
|
|
|
deBool qpTestLog_startImageSet (qpTestLog* log, const char* name, const char* description);
|
|
deBool qpTestLog_endImageSet (qpTestLog* log);
|
|
deBool qpTestLog_writeImage (qpTestLog* log, const char* name, const char* description, qpImageCompressionMode compressionMode, qpImageFormat format, int width, int height, int stride, const void* data);
|
|
|
|
deBool qpTestLog_startEglConfigSet (qpTestLog* log, const char* key, const char* description);
|
|
deBool qpTestLog_writeEglConfig (qpTestLog* log, const qpEglConfigInfo* config);
|
|
deBool qpTestLog_endEglConfigSet (qpTestLog* log);
|
|
|
|
/* \todo [2013-08-26 pyry] Unify ShaderProgram & KernelSource & CompileInfo. */
|
|
|
|
deBool qpTestLog_startShaderProgram (qpTestLog* log, deBool linkOk, const char* linkInfoLog);
|
|
deBool qpTestLog_endShaderProgram (qpTestLog* log);
|
|
deBool qpTestLog_writeShader (qpTestLog* log, qpShaderType type, const char* source, deBool compileOk, const char* infoLog);
|
|
|
|
deBool qpTestLog_writeKernelSource (qpTestLog* log, const char* source);
|
|
deBool qpTestLog_writeSpirVAssemblySource (qpTestLog* log, const char* source);
|
|
deBool qpTestLog_writeCompileInfo (qpTestLog* log, const char* name, const char* description, deBool compileOk, const char* infoLog);
|
|
|
|
deBool qpTestLog_startSampleList (qpTestLog* log, const char* name, const char* description);
|
|
deBool qpTestLog_startSampleInfo (qpTestLog* log);
|
|
deBool qpTestLog_writeValueInfo (qpTestLog* log, const char* name, const char* description, const char* unit, qpSampleValueTag tag);
|
|
deBool qpTestLog_endSampleInfo (qpTestLog* log);
|
|
deBool qpTestLog_startSample (qpTestLog* log);
|
|
deBool qpTestLog_writeValueFloat (qpTestLog* log, double value);
|
|
deBool qpTestLog_writeValueInteger (qpTestLog* log, deInt64 value);
|
|
deBool qpTestLog_endSample (qpTestLog* log);
|
|
deBool qpTestLog_endSampleList (qpTestLog* log);
|
|
|
|
deUint32 qpTestLog_getLogFlags (const qpTestLog* log);
|
|
|
|
const char* qpGetTestResultName (qpTestResult result);
|
|
|
|
DE_END_EXTERN_C
|
|
|
|
/*! \} */
|
|
|
|
#endif /* _QPTESTLOG_H */
|