Meeting #331
Updated by André Neto almost 8 years ago
With respect to v0.13 this version contains minor bug fixes and the addition of the CircularStaticList class.
h1. Requirements review
*Date of the review:* 13/06/2017
*Person who did the review:* André Neto
*Version of requirements:* 0.14
*Result of review:* N/A
*List of non-conformities:* N/A
*Comments*: This version only provides minor updates w.r.t. to v0.12.
h1. Architecture & design review
*Date of the review:* 13/06/2017
*Person who did the review:* André Neto
*Version of architecture & design document:* 0.14
*Result of review:* N/A
*List of non-conformities:* N/A
*Comments*: This version only provides minor updates w.r.t. to v0.12.
h1. Code and documentation review
*Date of the review:* 13/06/2017
*Person who did the review:* André Neto
*Version of source code:* 0.14
*Result of review:* PASS
*List of non-conformities:*
<pre>
Note 974: Worst case function for stack usage: 'MARTe::ConfigurationDatabase::Copy' is recursive, loop contains call to 'MARTe::ConfigurationDatabase::Copy'. See +stack for a full report. [MISRA C++ Rule 7-5-4]
</pre>
*List of warnings reported by Doxygen:*
<pre>
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Windows/BasicFileProperties.h:44: Warning: Compound MARTe::BasicFileProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Linux/BasicFileProperties.h:42: Warning: Compound MARTe::BasicFileProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L4LoggerService/LoggerConsumerI.h:113: Warning: Compound MARTe::LoggerConsumerI::FormatPreferences is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Windows/InternetHost.cpp:50: Warning: Compound MARTe::LocalHostInfo is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Linux/InternetHost.cpp:53: Warning: Compound MARTe::LocalHostInfo is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L1Portability/Environment/Windows/MutexSem.cpp:42: Warning: Compound MARTe::MutexSemProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L1Portability/Environment/Linux/MutexSem.cpp:45: Warning: Compound MARTe::MutexSemProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Windows/SelectProperties.h:42: Warning: Compound MARTe::SetIdentifier is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L1Portability/Environment/Windows/EventSem.cpp:45: Warning: Compound MARTe::EventSemProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L1Portability/Environment/Linux/EventSem.cpp:46: Warning: Compound MARTe::EventSemProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/BareMetal/L0Types/TemplateParametersVerificator.h:47: Warning: Compound TemplateParametersVerificator< true > is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/BareMetal/L1Portability/Environment/Windows/BasicConsole.cpp:43: Warning: Compound MARTe::BasicConsoleProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/BareMetal/L1Portability/Environment/Linux/BasicConsole.cpp:49: Warning: Compound MARTe::BasicConsoleProperties is not documented.
</pre>
_Disclaimer: These warnings are due a bug of Doxygen (https://bugzilla.gnome.org/show_bug.cgi?id=406027), fixed on version 1.8.10 (we use 1.6.1 on vcis-jenkins.f4e.europa.eu)._
*Remark*
The documentation of DataSourceI has to be revisited.
*Remark*
The following classes have non-virtual destructors. As long they are not base classes of any derived class, it is safe, but they need to be monitored (flexlint will check and signal this as error code 1509).
<pre>
Matrix, Vector, GlobalObjectsDatabase, LoadableLibrary, MemoryArea, StaticListHolder, CharBuffer, AnyTypeCreator, LexicalAnalyzer, Token, TokenInfo, Directory, MutexSem, ThreadInformation.
</pre>
h1. Unit test review
*Date of the review:* 13/06/2017
*Person who did the review:* André Neto
*Version of unit tests:* 0.14
*Result of coverage tests review:* PASS
*Result of functional tests review:* PASS
*Result of review:* PASS
*List of non-conformities:*
_LCOV report (methods not executed at all):_
<pre>
TimeoutType EmbeddedThreadI::GetTimeout() const
inline ExceptionHandler::~ExceptionHandler()
bool GAMDataSource::Synchronise()
bool GAM::SetContext(ConstReference context)
ReferenceT<T>* ReferenceT<T>::operator&() (*)
Object *Object::Clone() const
IntrospectionEntry::IntrospectionEntry()
Introspection::Introspection()
uint32 ClassProperties::GetSize() const
void MemoryArea::SetHeapName(const char8 * const name)
</pre>
(*) The ReferenceT<T>::operator& is private. See solution applied in Reference::operator&.
_LCOV report (fragments of code not executed):_
<pre>
case if (timeout.IsFinite()) @ bool BasicUDPSocket::Write(const char8 * const input, uint32 & size, const TimeoutType &timeout)
loop for (uint32 i = 0u; i < numberOfChildren; i++) @ bool RealTimeThread::ToStructuredData(StructuredDataI& data)
call with recursive==true @ Reference ReferenceContainer::Find(const char8 * const path, const bool recursive)
case if (dllOpened) @ ClassRegistryItem *ClassRegistryDatabase::Find(const char8 *className)
case if (ok) @ bool BasicConsole::Open(const FlagsType &mode)
case else if (shift < bitSize) @ DoubleInteger<T2> Shift::LogicalRightShift(DoubleInteger<T2> number, uint8 shift)
error reporting and set variables to default values on error checking @ all classes
</pre>
_GTest report_
<pre>
[----------] Global test environment tear-down
[==========] 3865 3674 tests from 143 133 test cases ran. (211109 (225205 ms total)
[ PASSED ] 3864 3664 tests.
[ FAILED ] 1 10 tests, listed below:
[ FAILED ] DirectoryGTest.TestGetSize_FileIncorrect
[ FAILED ] DirectoryGTest.TestGetSize_FileIncorrect2
[ FAILED ] DirectoryGTest.TestGetLastAccessTime_ReRead
[ FAILED ] DirectoryGTest.TestGetLastAccessTime_ReRead2
[ FAILED ] DirectoryGTest.TestGetLastWriteTime_ReWrite
[ FAILED ] DirectoryGTest.TestGetLastWriteTime_ReWrite2
[ FAILED ] ThreadsGTest.TestGetThreadInfoCopy
[ FAILED ] ThreadsGTest.TestPriority
[ FAILED ] IOBufferGTest.TestPrintStructuredDataInterface
[ FAILED ] BasicConsoleGTest.TestOpenModePerformCharacterInput
</pre>
h1. Integration test review
*Date of the review:* 13/06/2017 20/12/2016
*Person who did the review:* André Neto Ivan Herrero
*Version of integration tests:* 0.14 0.12
*Result of review:* N/A
*List of non-conformities:* N/A
*Comments*: Not performed. As per the original MARTe implementation, the user stories of this sprint are support functions and do not require formal integration tests.
h1. Acceptance test review
*Date of the review:* 13/06/2017 20/12/2016
*Person who did the review:* André Neto Ivan Herrero
*Version of acceptance tests:* 0.14 0.12
*Result of review:* N/A
*List of non-conformities:* N/A
*Comments*: Not performed. As per the original MARTe implementation, the user stories of this sprint are support functions and do not require formal acceptance tests.
h1. Requirements review
*Date of the review:* 13/06/2017
*Person who did the review:* André Neto
*Version of requirements:* 0.14
*Result of review:* N/A
*List of non-conformities:* N/A
*Comments*: This version only provides minor updates w.r.t. to v0.12.
h1. Architecture & design review
*Date of the review:* 13/06/2017
*Person who did the review:* André Neto
*Version of architecture & design document:* 0.14
*Result of review:* N/A
*List of non-conformities:* N/A
*Comments*: This version only provides minor updates w.r.t. to v0.12.
h1. Code and documentation review
*Date of the review:* 13/06/2017
*Person who did the review:* André Neto
*Version of source code:* 0.14
*Result of review:* PASS
*List of non-conformities:*
<pre>
Note 974: Worst case function for stack usage: 'MARTe::ConfigurationDatabase::Copy' is recursive, loop contains call to 'MARTe::ConfigurationDatabase::Copy'. See +stack for a full report. [MISRA C++ Rule 7-5-4]
</pre>
*List of warnings reported by Doxygen:*
<pre>
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Windows/BasicFileProperties.h:44: Warning: Compound MARTe::BasicFileProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Linux/BasicFileProperties.h:42: Warning: Compound MARTe::BasicFileProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L4LoggerService/LoggerConsumerI.h:113: Warning: Compound MARTe::LoggerConsumerI::FormatPreferences is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Windows/InternetHost.cpp:50: Warning: Compound MARTe::LocalHostInfo is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Linux/InternetHost.cpp:53: Warning: Compound MARTe::LocalHostInfo is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L1Portability/Environment/Windows/MutexSem.cpp:42: Warning: Compound MARTe::MutexSemProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L1Portability/Environment/Linux/MutexSem.cpp:45: Warning: Compound MARTe::MutexSemProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/FileSystem/L1Portability/Environment/Windows/SelectProperties.h:42: Warning: Compound MARTe::SetIdentifier is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L1Portability/Environment/Windows/EventSem.cpp:45: Warning: Compound MARTe::EventSemProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/Scheduler/L1Portability/Environment/Linux/EventSem.cpp:46: Warning: Compound MARTe::EventSemProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/BareMetal/L0Types/TemplateParametersVerificator.h:47: Warning: Compound TemplateParametersVerificator< true > is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/BareMetal/L1Portability/Environment/Windows/BasicConsole.cpp:43: Warning: Compound MARTe::BasicConsoleProperties is not documented.
/home/aneto/Projects/MARTe2-dev/Source/Core/BareMetal/L1Portability/Environment/Linux/BasicConsole.cpp:49: Warning: Compound MARTe::BasicConsoleProperties is not documented.
</pre>
_Disclaimer: These warnings are due a bug of Doxygen (https://bugzilla.gnome.org/show_bug.cgi?id=406027), fixed on version 1.8.10 (we use 1.6.1 on vcis-jenkins.f4e.europa.eu)._
*Remark*
The documentation of DataSourceI has to be revisited.
*Remark*
The following classes have non-virtual destructors. As long they are not base classes of any derived class, it is safe, but they need to be monitored (flexlint will check and signal this as error code 1509).
<pre>
Matrix, Vector, GlobalObjectsDatabase, LoadableLibrary, MemoryArea, StaticListHolder, CharBuffer, AnyTypeCreator, LexicalAnalyzer, Token, TokenInfo, Directory, MutexSem, ThreadInformation.
</pre>
h1. Unit test review
*Date of the review:* 13/06/2017
*Person who did the review:* André Neto
*Version of unit tests:* 0.14
*Result of coverage tests review:* PASS
*Result of functional tests review:* PASS
*Result of review:* PASS
*List of non-conformities:*
_LCOV report (methods not executed at all):_
<pre>
TimeoutType EmbeddedThreadI::GetTimeout() const
inline ExceptionHandler::~ExceptionHandler()
bool GAMDataSource::Synchronise()
bool GAM::SetContext(ConstReference context)
ReferenceT<T>* ReferenceT<T>::operator&() (*)
Object *Object::Clone() const
IntrospectionEntry::IntrospectionEntry()
Introspection::Introspection()
uint32 ClassProperties::GetSize() const
void MemoryArea::SetHeapName(const char8 * const name)
</pre>
(*) The ReferenceT<T>::operator& is private. See solution applied in Reference::operator&.
_LCOV report (fragments of code not executed):_
<pre>
case if (timeout.IsFinite()) @ bool BasicUDPSocket::Write(const char8 * const input, uint32 & size, const TimeoutType &timeout)
loop for (uint32 i = 0u; i < numberOfChildren; i++) @ bool RealTimeThread::ToStructuredData(StructuredDataI& data)
call with recursive==true @ Reference ReferenceContainer::Find(const char8 * const path, const bool recursive)
case if (dllOpened) @ ClassRegistryItem *ClassRegistryDatabase::Find(const char8 *className)
case if (ok) @ bool BasicConsole::Open(const FlagsType &mode)
case else if (shift < bitSize) @ DoubleInteger<T2> Shift::LogicalRightShift(DoubleInteger<T2> number, uint8 shift)
error reporting and set variables to default values on error checking @ all classes
</pre>
_GTest report_
<pre>
[----------] Global test environment tear-down
[==========] 3865 3674 tests from 143 133 test cases ran. (211109 (225205 ms total)
[ PASSED ] 3864 3664 tests.
[ FAILED ] 1 10 tests, listed below:
[ FAILED ] DirectoryGTest.TestGetSize_FileIncorrect
[ FAILED ] DirectoryGTest.TestGetSize_FileIncorrect2
[ FAILED ] DirectoryGTest.TestGetLastAccessTime_ReRead
[ FAILED ] DirectoryGTest.TestGetLastAccessTime_ReRead2
[ FAILED ] DirectoryGTest.TestGetLastWriteTime_ReWrite
[ FAILED ] DirectoryGTest.TestGetLastWriteTime_ReWrite2
[ FAILED ] ThreadsGTest.TestGetThreadInfoCopy
[ FAILED ] ThreadsGTest.TestPriority
[ FAILED ] IOBufferGTest.TestPrintStructuredDataInterface
[ FAILED ] BasicConsoleGTest.TestOpenModePerformCharacterInput
</pre>
h1. Integration test review
*Date of the review:* 13/06/2017 20/12/2016
*Person who did the review:* André Neto Ivan Herrero
*Version of integration tests:* 0.14 0.12
*Result of review:* N/A
*List of non-conformities:* N/A
*Comments*: Not performed. As per the original MARTe implementation, the user stories of this sprint are support functions and do not require formal integration tests.
h1. Acceptance test review
*Date of the review:* 13/06/2017 20/12/2016
*Person who did the review:* André Neto Ivan Herrero
*Version of acceptance tests:* 0.14 0.12
*Result of review:* N/A
*List of non-conformities:* N/A
*Comments*: Not performed. As per the original MARTe implementation, the user stories of this sprint are support functions and do not require formal acceptance tests.