pxmlw6n2f/Gazebo_Distributed_TCP/gazebo/gui/model/CollisionConfig_TEST.cc

234 lines
6.0 KiB
C++

/*
* Copyright (C) 2015 Open Source Robotics Foundation
*
* 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.
*
*/
#include "gazebo/gui/ConfigWidget.hh"
#include "gazebo/gui/model/CollisionConfig.hh"
#include "gazebo/gui/model/CollisionConfig_TEST.hh"
#include "test_config.h"
/// \brief variable for testing closing modal dialogs
bool g_confirmed = false;
using namespace gazebo;
using namespace gui;
/////////////////////////////////////////////////
void CollisionConfig_TEST::Initialization()
{
gazebo::gui::CollisionConfig cc;
QCOMPARE(cc.GetCollisionCount(), 0u);
QVERIFY(cc.GetData("NotFound") == NULL);
}
/////////////////////////////////////////////////
void CollisionConfig_TEST::CollisionUpdates()
{
gazebo::gui::CollisionConfig cc;
msgs::Collision c1, c2, c3;
cc.AddCollision("c1", &c1);
cc.AddCollision("c2", &c2);
cc.AddCollision("c3", &c3);
QCOMPARE(cc.GetCollisionCount(), 3u);
QVERIFY(cc.GetData("c1") != NULL);
QVERIFY(cc.GetData("c2") != NULL);
QVERIFY(cc.GetData("c3") != NULL);
QVERIFY(cc.GetData("NotFound") == NULL);
msgs::CollisionPtr collisionMsgPtr(new msgs::Collision);
collisionMsgPtr->set_laser_retro(0.0000789);
cc.UpdateCollision("c1", collisionMsgPtr);
bool foundConfig = false;
for (const auto &it : cc.ConfigData())
{
if (it.second->name == "c1")
{
const CollisionConfigData *configData = it.second;
QCOMPARE(configData->configWidget->DoubleWidgetValue("laser_retro"),
0.0000789);
foundConfig = true;
break;
}
}
QVERIFY(foundConfig);
cc.Reset();
QCOMPARE(cc.GetCollisionCount(), 0u);
QVERIFY(cc.GetData("c1") == NULL);
QVERIFY(cc.GetData("c2") == NULL);
QVERIFY(cc.GetData("c3") == NULL);
}
/////////////////////////////////////////////////
void CollisionConfig_TEST::GeometryUpdates()
{
gazebo::gui::CollisionConfig cc;
msgs::Collision c1;
cc.AddCollision("c1", &c1);
const ignition::math::Vector3d size1(5, 10, 15);
cc.SetGeometry("c1", size1, "unit_box");
ignition::math::Vector3d size2;
std::string uri;
cc.Geometry("c1", size2, uri);
QCOMPARE(5.0, size2.X());
QCOMPARE(10.0, size2.Y());
QCOMPARE(15.0, size2.Z());
QCOMPARE(uri, std::string(""));
ignition::math::Vector3d size3(0, 0, 0);
cc.Geometry("NotFound", size3, uri);
QCOMPARE(0.0, size3.X());
QCOMPARE(0.0, size3.Y());
QCOMPARE(0.0, size3.Z());
QCOMPARE(uri, std::string(""));
}
/////////////////////////////////////////////////
void CollisionConfig_TEST::AppliedSignal()
{
// Create a link inspector
gazebo::gui::CollisionConfig *collisionConfig =
new gazebo::gui::CollisionConfig();
QVERIFY(collisionConfig != NULL);
// Connect signals
connect(collisionConfig, SIGNAL(Applied()), this, SLOT(OnApply()));
// Init it
collisionConfig->Init();
QCOMPARE(g_appliedSignalCount, 0u);
QCOMPARE(collisionConfig->GetCollisionCount(), 0u);
// Get push buttons
QList<QPushButton *> pushButtons =
collisionConfig->findChildren<QPushButton *>();
QVERIFY(pushButtons.size() == 1);
// Add a collision
pushButtons[0]->click();
QCOMPARE(collisionConfig->GetCollisionCount(), 1u);
// Get spins
QList<QDoubleSpinBox *> spins =
collisionConfig->findChildren<QDoubleSpinBox *>();
QVERIFY(spins.size() == 33);
// Get combo boxes
QList<QComboBox *> combos =
collisionConfig->findChildren<QComboBox *>();
QVERIFY(combos.size() == 2);
// Edit collision pose (2~7)
spins[2]->setValue(2.0);
QTest::keyClick(spins[2], Qt::Key_Enter);
QCOMPARE(g_appliedSignalCount, 1u);
// Edit geometry (0)
combos[0]->setCurrentIndex(2);
QTest::keyClick(combos[0], Qt::Key_Enter);
QCOMPARE(g_appliedSignalCount, 2u);
delete collisionConfig;
}
/////////////////////////////////////////////////
void CollisionConfig_TEST::OnApply()
{
g_appliedSignalCount++;
}
/////////////////////////////////////////////////
void CollisionConfig_TEST::Restore()
{
CollisionConfig cc;
msgs::Collision c1, c2, c3;
cc.AddCollision("c1", &c1);
cc.AddCollision("c2", &c2);
QCOMPARE(cc.GetCollisionCount(), 2u);
QVERIFY(cc.GetData("c1") != NULL);
QVERIFY(cc.GetData("c2") != NULL);
QVERIFY(cc.GetData("c3") == NULL);
// Set this as the original data
cc.Init();
// Add a collision and restore
cc.AddCollision("c3", &c3);
QCOMPARE(cc.GetCollisionCount(), 3u);
QVERIFY(cc.GetData("c1") != NULL);
QVERIFY(cc.GetData("c2") != NULL);
QVERIFY(cc.GetData("c3") != NULL);
cc.RestoreOriginalData();
QCOMPARE(cc.GetCollisionCount(), 2u);
QVERIFY(cc.GetData("c1") != NULL);
QVERIFY(cc.GetData("c2") != NULL);
QVERIFY(cc.GetData("c3") == NULL);
// Remove a collision and restore
QVERIFY(!g_confirmed);
auto button = cc.findChild<QToolButton *>("removeCollisionButton_0");
QVERIFY(button);
CollisionConfigTestHelper helper;
QTimer::singleShot(3000, &helper, SLOT(Confirm()));
button->click();
QVERIFY(g_confirmed);
QCOMPARE(cc.GetCollisionCount(), 1u);
QVERIFY(cc.GetData("c1") == NULL);
QVERIFY(cc.GetData("c2") != NULL);
QVERIFY(cc.GetData("c3") == NULL);
cc.RestoreOriginalData();
QCOMPARE(cc.GetCollisionCount(), 2u);
QVERIFY(cc.GetData("c1") != NULL);
QVERIFY(cc.GetData("c2") != NULL);
QVERIFY(cc.GetData("c3") == NULL);
}
/////////////////////////////////////////////////
void CollisionConfigTestHelper::Confirm()
{
auto w = QApplication::activeModalWidget();
QVERIFY(w != nullptr);
w->setFocus();
QTest::keyClick(w, Qt::Key_Enter);
g_confirmed = true;
}
// Generate a main function for the test
QTEST_MAIN(CollisionConfig_TEST)