summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJacob Keeler <jacob.keeler@livioradio.com>2019-09-13 14:54:58 -0400
committerGitHub <noreply@github.com>2019-09-13 14:54:58 -0400
commit10829fa42cf406d915ea26d7200045964674d12a (patch)
tree0c5bbffbd7716298c4ccf0851dd68d4691d4f12b
parent73b34832829650834ea69b3606ce8127a93ef973 (diff)
downloadsdl_core-revert-3015-fix/sdl_versioning_for_vehicle_data.tar.gz
Revert "Fix sdl versioning for vehicle data (#3015)"revert-3015-fix/sdl_versioning_for_vehicle_data
This reverts commit 73b34832829650834ea69b3606ce8127a93ef973.
-rw-r--r--src/components/application_manager/rpc_plugins/rc_rpc_plugin/test/commands/rc_get_interior_vehicle_data_consent_test.cc8
-rw-r--r--src/components/application_manager/rpc_plugins/sdl_rpc_plugin/src/commands/mobile/register_app_interface_request.cc6
-rw-r--r--src/components/application_manager/src/rpc_handler_impl.cc6
-rw-r--r--src/components/application_manager/src/rpc_service_impl.cc2
-rwxr-xr-xsrc/components/application_manager/test/CMakeLists.txt5
-rw-r--r--src/components/application_manager/test/rpc_handler_impl_test.cc117
-rw-r--r--src/components/smart_objects/include/smart_objects/object_schema_item.h2
-rw-r--r--src/components/smart_objects/src/object_schema_item.cc31
8 files changed, 28 insertions, 149 deletions
diff --git a/src/components/application_manager/rpc_plugins/rc_rpc_plugin/test/commands/rc_get_interior_vehicle_data_consent_test.cc b/src/components/application_manager/rpc_plugins/rc_rpc_plugin/test/commands/rc_get_interior_vehicle_data_consent_test.cc
index 55be43f37b..d44265a1d5 100644
--- a/src/components/application_manager/rpc_plugins/rc_rpc_plugin/test/commands/rc_get_interior_vehicle_data_consent_test.cc
+++ b/src/components/application_manager/rpc_plugins/rc_rpc_plugin/test/commands/rc_get_interior_vehicle_data_consent_test.cc
@@ -265,17 +265,15 @@ TEST_F(RCGetInteriorVehicleDataConsentTest,
TEST_F(RCGetInteriorVehicleDataConsentTest,
Run_MobileSendButtonPressMessage_HMISendINUSEModeToMobile) {
+ // Arrange
+ auto mobile_message = CreateBasicMessage();
+
// Expectations
EXPECT_CALL(mock_allocation_manager_, AcquireResource(_, _, _))
.WillOnce(Return(rc_rpc_plugin::AcquireResult::IN_USE));
- auto msg_ver = utils::SemanticVersion();
- ON_CALL(*mock_app_, msg_version()).WillByDefault(ReturnRef(msg_ver));
-
EXPECT_CALL(*optional_mock_rpc_plugin, GetCommandFactory())
.WillOnce(ReturnRef(mock_command_factory));
-
- auto mobile_message = CreateBasicMessage();
auto rc_consent_response =
CreateRCCommand<commands::RCGetInteriorVehicleDataConsentResponse>(
mobile_message);
diff --git a/src/components/application_manager/rpc_plugins/sdl_rpc_plugin/src/commands/mobile/register_app_interface_request.cc b/src/components/application_manager/rpc_plugins/sdl_rpc_plugin/src/commands/mobile/register_app_interface_request.cc
index 4d41f69b49..c4bc5cb486 100644
--- a/src/components/application_manager/rpc_plugins/sdl_rpc_plugin/src/commands/mobile/register_app_interface_request.cc
+++ b/src/components/application_manager/rpc_plugins/sdl_rpc_plugin/src/commands/mobile/register_app_interface_request.cc
@@ -383,7 +383,11 @@ void RegisterAppInterfaceRequest::Run() {
// Version negotiation
utils::SemanticVersion module_version(
major_version, minor_version, patch_version);
- if (mobile_version < module_version) {
+ if (mobile_version < utils::rpc_version_5) {
+ // Mobile versioning did not exist for
+ // versions before 5.0
+ application->set_msg_version(utils::base_rpc_version);
+ } else if (mobile_version < module_version) {
// Use mobile RPC version as negotiated version
application->set_msg_version(mobile_version);
} else {
diff --git a/src/components/application_manager/src/rpc_handler_impl.cc b/src/components/application_manager/src/rpc_handler_impl.cc
index 3fee1da9e4..d1ca05e9a1 100644
--- a/src/components/application_manager/src/rpc_handler_impl.cc
+++ b/src/components/application_manager/src/rpc_handler_impl.cc
@@ -294,11 +294,11 @@ void RPCHandlerImpl::GetMessageVersion(
if (sync_msg_version.keyExists(strings::patch_version)) {
patch = sync_msg_version[strings::patch_version].asUInt();
}
-
- message_version = utils::base_rpc_version;
utils::SemanticVersion temp_version(major, minor, patch);
if (temp_version.isValid()) {
- message_version = temp_version;
+ message_version = (temp_version >= utils::rpc_version_5)
+ ? temp_version
+ : utils::base_rpc_version;
}
}
}
diff --git a/src/components/application_manager/src/rpc_service_impl.cc b/src/components/application_manager/src/rpc_service_impl.cc
index 1bbc3256c7..e29edd8f59 100644
--- a/src/components/application_manager/src/rpc_service_impl.cc
+++ b/src/components/application_manager/src/rpc_service_impl.cc
@@ -181,7 +181,7 @@ bool RPCServiceImpl::ManageMobileCommand(
#endif // ENABLE_SECURITY
// Message for "CheckPermission" must be with attached schema
- mobile_so_factory().attachSchema(*message, true, app_ptr->msg_version());
+ mobile_so_factory().attachSchema(*message, false);
}
auto plugin =
diff --git a/src/components/application_manager/test/CMakeLists.txt b/src/components/application_manager/test/CMakeLists.txt
index 230be524c8..f6146f96f9 100755
--- a/src/components/application_manager/test/CMakeLists.txt
+++ b/src/components/application_manager/test/CMakeLists.txt
@@ -86,9 +86,6 @@ set (RequestController_SOURCES
${AM_TEST_DIR}/mock_message_helper.cc
)
-set (RPCHandlerImplTest_SOURCES ${AM_TEST_DIR}/rpc_handler_impl_test.cc
- ${AM_TEST_DIR}/mock_message_helper.cc)
-
set(LIBRARIES
Utils
ApplicationManager
@@ -147,8 +144,6 @@ create_test("help_prompt_manager_test" "${testSourcesHelpPromptManager}" "${LIBR
create_test("request_controller_test" "${RequestController_SOURCES}" "${LIBRARIES}")
-create_test("rpc_handler_impl_test" "${RPCHandlerImplTest_SOURCES}" "${LIBRARIES}")
-
set(ResumptionData_SOURCES
${AM_TEST_DIR}/resumption/resumption_data_test.cc
${AM_TEST_DIR}/resumption/resumption_data_db_test.cc
diff --git a/src/components/application_manager/test/rpc_handler_impl_test.cc b/src/components/application_manager/test/rpc_handler_impl_test.cc
deleted file mode 100644
index 9db8e7c0d8..0000000000
--- a/src/components/application_manager/test/rpc_handler_impl_test.cc
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * Copyright (c) 2019, Ford Motor Company
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- *
- * Redistributions of source code must retain the above copyright notice, this
- * list of conditions and the following disclaimer.
- *
- * Redistributions in binary form must reproduce the above copyright notice,
- * this list of conditions and the following
- * disclaimer in the documentation and/or other materials provided with the
- * distribution.
- *
- * Neither the name of the Ford Motor Company nor the names of its contributors
- * may be used to endorse or promote products derived from this software
- * without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
- * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- * POSSIBILITY OF SUCH DAMAGE.
- */
-
-#include "application_manager/rpc_handler_impl.h"
-#include <memory>
-#include "application_manager/mock_application_manager.h"
-#include "application_manager/smart_object_keys.h"
-#include "interfaces/HMI_API.h"
-#include "interfaces/MOBILE_API.h"
-
-namespace test {
-namespace components {
-namespace application_manager_test {
-
-using ::test::components::application_manager_test::MockApplicationManager;
-using ::testing::_;
-using ::testing::Mock;
-using ::testing::NiceMock;
-using namespace ::smart_objects;
-using namespace application_manager::rpc_handler;
-
-class RPCHandlerImplTest : public ::testing::Test {
- public:
- RPCHandlerImplTest()
- : rpc_handler_(new RPCHandlerImpl(
- mock_app_mngr_, hmi_so_factory_, mobile_so_factory_)) {}
-
- protected:
- std::unique_ptr<RPCHandlerImpl> rpc_handler_;
- hmi_apis::HMI_API hmi_so_factory_;
- mobile_apis::MOBILE_API mobile_so_factory_;
- NiceMock<MockApplicationManager> mock_app_mngr_;
-};
-
-TEST_F(RPCHandlerImplTest, GetMessageVersion_SUCCESS) {
- namespace json_str = ns_smart_device_link::ns_json_handler::strings;
- namespace app_str = application_manager::strings;
-
- std::vector<utils::SemanticVersion> test_versions = {
- utils::SemanticVersion("2.5.0"),
- utils::SemanticVersion("3.0.0"),
- utils::SemanticVersion("5.0.0"),
- utils::SemanticVersion("6.1.0")};
-
- SmartObject message;
- message[json_str::S_MSG_PARAMS] = SmartObject(SmartType_Map);
- message[json_str::S_MSG_PARAMS][app_str::sync_msg_version] =
- SmartObject(SmartType_Map);
-
- for (const auto& expected_version : test_versions) {
- message[json_str::S_MSG_PARAMS][app_str::sync_msg_version]
- [app_str::major_version] = expected_version.major_version_;
- message[json_str::S_MSG_PARAMS][app_str::sync_msg_version]
- [app_str::minor_version] = expected_version.minor_version_;
- message[json_str::S_MSG_PARAMS][app_str::sync_msg_version]
- [app_str::patch_version] = expected_version.patch_version_;
-
- utils::SemanticVersion result_message_version;
- rpc_handler_->GetMessageVersion(message, result_message_version);
- EXPECT_EQ(expected_version, result_message_version);
- }
-}
-
-TEST_F(RPCHandlerImplTest, GetMessageVersion_InvalidVersion) {
- namespace json_str = ns_smart_device_link::ns_json_handler::strings;
- namespace app_str = application_manager::strings;
-
- SmartObject message;
- message[json_str::S_MSG_PARAMS] = SmartObject(SmartType_Map);
- message[json_str::S_MSG_PARAMS][app_str::sync_msg_version] =
- SmartObject(SmartType_Map);
- message[json_str::S_MSG_PARAMS][app_str::sync_msg_version]
- [app_str::major_version] = 0;
- message[json_str::S_MSG_PARAMS][app_str::sync_msg_version]
- [app_str::minor_version] = 0;
- message[json_str::S_MSG_PARAMS][app_str::sync_msg_version]
- [app_str::patch_version] = 0;
-
- utils::SemanticVersion expected_version(utils::base_rpc_version);
-
- utils::SemanticVersion result_message_version;
- rpc_handler_->GetMessageVersion(message, result_message_version);
- EXPECT_EQ(expected_version, result_message_version);
-}
-
-} // namespace application_manager_test
-} // namespace components
-} // namespace test
diff --git a/src/components/smart_objects/include/smart_objects/object_schema_item.h b/src/components/smart_objects/include/smart_objects/object_schema_item.h
index 5b1eb15078..ee42b36620 100644
--- a/src/components/smart_objects/include/smart_objects/object_schema_item.h
+++ b/src/components/smart_objects/include/smart_objects/object_schema_item.h
@@ -86,7 +86,7 @@ struct SMember {
boost::optional<utils::SemanticVersion> mSince;
boost::optional<utils::SemanticVersion> mUntil;
bool mIsDeprecated;
- mutable bool mIsRemoved;
+ bool mIsRemoved;
std::vector<SMember> mHistoryVector;
};
typedef std::map<std::string, SMember> Members;
diff --git a/src/components/smart_objects/src/object_schema_item.cc b/src/components/smart_objects/src/object_schema_item.cc
index dee1a7c9c7..01e4ec46e0 100644
--- a/src/components/smart_objects/src/object_schema_item.cc
+++ b/src/components/smart_objects/src/object_schema_item.cc
@@ -57,8 +57,7 @@ SMember::SMember(const ISchemaItemPtr SchemaItem,
const bool IsDeprecated,
const bool IsRemoved,
const std::vector<SMember>& history_vector)
- : mSchemaItem(SchemaItem)
- , mIsMandatory(IsMandatory) {
+ : mSchemaItem(SchemaItem), mIsMandatory(IsMandatory) {
if (Since.size() > 0) {
utils::SemanticVersion since_struct(Since);
if (since_struct.isValid()) {
@@ -252,21 +251,25 @@ CObjectSchemaItem::CObjectSchemaItem(const Members& members)
void CObjectSchemaItem::RemoveFakeParams(
SmartObject& Object, const utils::SemanticVersion& MessageVersion) {
- for (SmartMap::const_iterator it = Object.map_begin(); it != Object.map_end();
- ++it) {
+ for (SmartMap::const_iterator it = Object.map_begin();
+ it != Object.map_end();) {
const std::string& key = it->first;
std::map<std::string, SMember>::const_iterator members_it =
mMembers.find(key);
-
- if (mMembers.end() == members_it && key.compare(connection_key) != 0 &&
- key.compare(binary_data) != 0 && key.compare(app_id) != 0) {
+ if (mMembers.end() == members_it
+ // FIXME(EZamakhov): Remove illegal usage of filed in AM
+ && key.compare(connection_key) != 0 && key.compare(binary_data) != 0 &&
+ key.compare(app_id) != 0) {
+ ++it;
Object.erase(key);
- }
- if (mMembers.end() != members_it) {
- if (GetCorrectMember(members_it->second, MessageVersion).mIsRemoved) {
- Object.erase(key);
- }
+ } else if (mMembers.end() != members_it &&
+ GetCorrectMember(members_it->second, MessageVersion)
+ .mIsRemoved) {
+ ++it;
+ Object.erase(key);
+ } else {
+ ++it;
}
}
}
@@ -285,10 +288,6 @@ const SMember& CObjectSchemaItem::GetCorrectMember(
}
}
}
-
- // If member didn't pass checks above then
- // it becomes not valid and must be removed.
- member.mIsRemoved = true;
// Return member as default
return member;
}