X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=automated-tests%2Fsrc%2Fdali-toolkit%2Fdali-toolkit-test-utils%2Ftest-trace-call-stack.h;h=76316309f4087cad7daee83ef9aa90f4884b9680;hb=d6e2f99851ab626fdb78e426498ff9ada6d298b8;hp=8cb592286daf04b2b02c7f67d44d8aa182475755;hpb=893ec494389e7fe476a64e220ae97eedb73e74d7;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/automated-tests/src/dali-toolkit/dali-toolkit-test-utils/test-trace-call-stack.h b/automated-tests/src/dali-toolkit/dali-toolkit-test-utils/test-trace-call-stack.h index 8cb5922..7631630 100644 --- a/automated-tests/src/dali-toolkit/dali-toolkit-test-utils/test-trace-call-stack.h +++ b/automated-tests/src/dali-toolkit/dali-toolkit-test-utils/test-trace-call-stack.h @@ -2,7 +2,7 @@ #define TEST_TRACE_CALL_STACK_H /* - * Copyright (c) 2020 Samsung Electronics Co., Ltd. + * Copyright (c) 2021 Samsung Electronics Co., Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -42,12 +42,106 @@ class TraceCallStack { public: /// Typedef for passing and storing named parameters - typedef std::map NamedParams; + class NamedParams + { + public: + struct NameValue + { + std::string parameterName; + std::ostringstream value; + NameValue(std::string pname, std::string aValue) + : parameterName(pname), + value(aValue) + { + } + NameValue(const NameValue& rhs) + : parameterName(rhs.parameterName), + value(rhs.value.str()) + { + } + NameValue& operator=(const NameValue& rhs) + { + if(this != &rhs) + { + this->parameterName = rhs.parameterName; + this->value.str(rhs.value.str()); + } + return *this; + } + + bool operator==(const NameValue& rhs) + { + return !parameterName.compare(rhs.parameterName) && !value.str().compare(rhs.value.str()); + } + + bool operator==(int match) const; + }; + + auto find(const std::string& param) const + { + auto iter = mParams.begin(); + for(; iter != mParams.end(); ++iter) + { + if(!iter->parameterName.compare(param)) + { + break; + } + } + return iter; + } + + auto begin() const + { + return mParams.begin(); + } + auto end() const + { + return mParams.end(); + } + + std::ostringstream& operator[](std::string name) + { + auto iter = mParams.begin(); + for(; iter != mParams.end(); ++iter) + { + if(!iter->parameterName.compare(name)) + { + break; + } + } + + if(iter != mParams.end()) + { + return iter->value; + } + else + { + mParams.push_back(NameValue(name, "")); + return mParams.back().value; + } + } + + std::string str() const + { + std::ostringstream out; + bool first = true; + for(auto& elem : mParams) + { + out << (first ? "" : " ") << elem.parameterName << ": " << elem.value.str(); + first = false; + } + return out.str(); + } + std::vector mParams{}; + }; /** * Constructor */ - TraceCallStack(); + TraceCallStack(bool logging, std::string prefix); + + TraceCallStack(const TraceCallStack&) = delete; + TraceCallStack(TraceCallStack&&) = delete; /** * Destructor @@ -61,6 +155,8 @@ public: bool IsEnabled(); + void EnableLogging(bool enable); + /** * Push a call onto the stack if the trace is active * @param[in] method The name of the method @@ -144,6 +240,14 @@ public: int FindIndexFromMethodAndParams(std::string method, const NamedParams& params) const; /** + * Search for the most recent occurrence of the method with the given (partial) parameters. + * @param[in] method The name of the method + * @param[in] params A map of named parameter values to match + * @return The full named parameters of the matching call. + */ + const NamedParams* FindLastMatch(std::string method, const TraceCallStack::NamedParams& params) const; + + /** * Test if the given method and parameters are at a given index in the stack * @param[in] index Index in the call stack * @param[in] method Name of method to test @@ -173,8 +277,10 @@ public: return traceStream.str(); } -private: - bool mTraceActive; ///< True if the trace is active +public: + bool mTraceActive{false}; ///< True if the trace is active + bool mLogging{false}; ///< True if the trace is logged to stdout + std::string mPrefix; struct FunctionCall {