Skip to content
Snippets Groups Projects
MockLink.h 7.4 KiB
Newer Older
  • Learn to ignore specific revisions
  • Don Gagne's avatar
    Don Gagne committed
    /*=====================================================================
    
    Don Gagne's avatar
    Don Gagne committed
     QGroundControl Open Source Ground Control Station
    
    Don Gagne's avatar
    Don Gagne committed
     (c) 2009 - 2014 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
    
    Don Gagne's avatar
    Don Gagne committed
     This file is part of the QGROUNDCONTROL project
    
    Don Gagne's avatar
    Don Gagne committed
     QGROUNDCONTROL is free software: you can redistribute it and/or modify
     it under the terms of the GNU General Public License as published by
     the Free Software Foundation, either version 3 of the License, or
     (at your option) any later version.
    
    Don Gagne's avatar
    Don Gagne committed
     QGROUNDCONTROL is distributed in the hope that it will be useful,
     but WITHOUT ANY WARRANTY; without even the implied warranty of
     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     GNU General Public License for more details.
    
    Don Gagne's avatar
    Don Gagne committed
     You should have received a copy of the GNU General Public License
     along with QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.
    
    Don Gagne's avatar
    Don Gagne committed
     ======================================================================*/
    
    #ifndef MOCKLINK_H
    #define MOCKLINK_H
    
    #include <QMap>
    
    #include <QLoggingCategory>
    
    Don Gagne's avatar
    Don Gagne committed
    
    #include "MockLinkMissionItemHandler.h"
    
    #include "MockLinkFileServer.h"
    
    #include "QGCMAVLink.h"
    
    Q_DECLARE_LOGGING_CATEGORY(MockLinkLog)
    
    Don Gagne's avatar
    Don Gagne committed
    Q_DECLARE_LOGGING_CATEGORY(MockLinkVerboseLog)
    
    class MockConfiguration : public LinkConfiguration
    {
    public:
    
        MockConfiguration(const QString& name);
        MockConfiguration(MockConfiguration* source);
    
        MAV_AUTOPILOT firmwareType(void) { return _firmwareType; }
        void setFirmwareType(MAV_AUTOPILOT firmwareType) { _firmwareType = firmwareType; }
    
    
        /// @param sendStatusText true: mavlink status text messages will be sent for each severity, as well as voice output info message
        void setSendStatusText(bool sendStatusText) { _sendStatusText = sendStatusText; }
        bool sendStatusText(void) { return _sendStatusText; }
    
    
        // Overrides from LinkConfiguration
        int  type(void) { return LinkConfiguration::TypeMock; }
        void copyFrom(LinkConfiguration* source);
        void loadSettings(QSettings& settings, const QString& root);
        void saveSettings(QSettings& settings, const QString& root);
        void updateSettings(void);
    
    private:
    
        MAV_AUTOPILOT   _firmwareType;
        bool            _sendStatusText;
    
        static const char* _firmwareTypeKey;
    
        static const char* _sendStatusTextKey;
    
    Don Gagne's avatar
    Don Gagne committed
    class MockLink : public LinkInterface
    {
        Q_OBJECT
    
    Don Gagne's avatar
    Don Gagne committed
    public:
    
        // LinkConfiguration is optional for MockLink
        MockLink(MockConfiguration* config = NULL);
    
    Don Gagne's avatar
    Don Gagne committed
        ~MockLink(void);
    
        // MockLink methods
    
    Don Gagne's avatar
    Don Gagne committed
        int vehicleId(void) { return _vehicleSystemId; }
    
    Don Gagne's avatar
    Don Gagne committed
        MAV_AUTOPILOT getFirmwareType(void) { return _firmwareType; }
        void setFirmwareType(MAV_AUTOPILOT autopilot) { _firmwareType = autopilot; }
    
        void setSendStatusText(bool sendStatusText) { _sendStatusText = sendStatusText; }
    
    Don Gagne's avatar
    Don Gagne committed
    
        /// APM stack has strange handling of the first item of the mission list. If it has no
        /// onboard mission items, sometimes it sends back a home position in position 0 and
        /// sometimes it doesn't. Don't ask. This option allows you to configure that behavior
        /// for unit testing.
        void setAPMMissionResponseMode(bool sendHomePositionOnEmptyList) { _apmSendHomePositionOnEmptyList = sendHomePositionOnEmptyList; }
    
    
        void emitRemoteControlChannelRawChanged(int channel, uint16_t raw);
    
        
        /// Sends the specified mavlink message to QGC
        void respondWithMavlinkMessage(const mavlink_message_t& msg);
        
        MockLinkFileServer* getFileServer(void) { return _fileServer; }
    
    Don Gagne's avatar
    Don Gagne committed
        // Virtuals from LinkInterface
        virtual QString getName(void) const { return _name; }
        virtual void requestReset(void){ }
        virtual bool isConnected(void) const { return _connected; }
        virtual qint64 getConnectionSpeed(void) const { return 100000000; }
        virtual qint64 bytesAvailable(void) { return 0; }
    
    
        // These are left unimplemented in order to cause linker errors which indicate incorrect usage of
        // connect/disconnect on link directly. All connect/disconnect calls should be made through LinkManager.
        bool connect(void);
        bool disconnect(void);
    
    
        LinkConfiguration* getLinkConfiguration() { return _config; }
    
        
        /// Sets a failure mode for unit testing
        ///     @param failureMode Type of failure to simulate
        ///     @param firstTimeOnly true: fail first call, success subsequent calls, false: fail all calls
        void setMissionItemFailureMode(MockLinkMissionItemHandler::FailureMode_t failureMode, bool firstTimeOnly);
        
        /// Called to send a MISSION_ACK message while the MissionManager is in idle state
        void sendUnexpectedMissionAck(MAV_MISSION_RESULT ackType) { _missionItemHandler.sendUnexpectedMissionAck(ackType); }
        
        /// Called to send a MISSION_ITEM message while the MissionManager is in idle state
        void sendUnexpectedMissionItem(void) { _missionItemHandler.sendUnexpectedMissionItem(); }
        
        /// Called to send a MISSION_REQUEST message while the MissionManager is in idle state
        void sendUnexpectedMissionRequest(void) { _missionItemHandler.sendUnexpectedMissionRequest(); }
        
        /// Reset the state of the MissionItemHandler to no items, no transactions in progress.
        void resetMissionItemHandler(void) { _missionItemHandler.reset(); }
    
    Don Gagne's avatar
    Don Gagne committed
    signals:
        /// @brief Used internally to move data to the thread.
        void _incomingBytes(const QByteArray bytes);
    
    Don Gagne's avatar
    Don Gagne committed
    public slots:
        virtual void writeBytes(const char *bytes, qint64 cBytes);
    
    Don Gagne's avatar
    Don Gagne committed
    protected slots:
        // FIXME: This should not be part of LinkInterface. It is an internal link implementation detail.
        virtual void readBytes(void);
    
    Don Gagne's avatar
    Don Gagne committed
    private slots:
        void _run1HzTasks(void);
        void _run10HzTasks(void);
        void _run50HzTasks(void);
    
    Don Gagne's avatar
    Don Gagne committed
    private:
    
        // From LinkInterface
        virtual bool _connect(void);
        virtual bool _disconnect(void);
    
    Don Gagne's avatar
    Don Gagne committed
        // QThread override
        virtual void run(void);
    
    Don Gagne's avatar
    Don Gagne committed
        // MockLink methods
        void _sendHeartBeat(void);
        void _handleIncomingBytes(const QByteArray bytes);
        void _handleIncomingNSHBytes(const char* bytes, int cBytes);
        void _handleIncomingMavlinkBytes(const uint8_t* bytes, int cBytes);
        void _loadParams(void);
        void _handleHeartBeat(const mavlink_message_t& msg);
        void _handleSetMode(const mavlink_message_t& msg);
        void _handleParamRequestList(const mavlink_message_t& msg);
        void _handleParamSet(const mavlink_message_t& msg);
        void _handleParamRequestRead(const mavlink_message_t& msg);
    
        void _handleFTP(const mavlink_message_t& msg);
    
        void _handleCommandLong(const mavlink_message_t& msg);
    
        float _floatUnionForParam(int componentId, const QString& paramName);
        void _setParamFloatUnionIntoMap(int componentId, const QString& paramName, float paramFloat);
    
        void _sendHomePosition(void);
    
    Don Gagne's avatar
    Don Gagne committed
        void _sendGpsRawInt(void);
    
        void _sendStatusTextMessages(void);
    
        MockLinkMissionItemHandler  _missionItemHandler;
    
    Don Gagne's avatar
    Don Gagne committed
        QString _name;
        bool    _connected;
    
    Don Gagne's avatar
    Don Gagne committed
        uint8_t _vehicleSystemId;
        uint8_t _vehicleComponentId;
    
    Don Gagne's avatar
    Don Gagne committed
        bool    _inNSH;
        bool    _mavlinkStarted;
    
        QMap<int, QMap<QString, QVariant> > _mapParamName2Value;
        QMap<QString, MAV_PARAM_TYPE>       _mapParamName2MavParamType;
    
        uint8_t     _mavBaseMode;
        uint32_t    _mavCustomMode;
        uint8_t     _mavState;
    
    Don Gagne's avatar
    Don Gagne committed
        MAV_AUTOPILOT _firmwareType;
    
        
        MockLinkFileServer* _fileServer;
    
        bool _sendStatusText;
    
    Don Gagne's avatar
    Don Gagne committed
        bool _apmSendHomePositionOnEmptyList;
    
        int _sendHomePositionDelayCount;
    
    
    Don Gagne's avatar
    Don Gagne committed
        static float _vehicleLatitude;
        static float _vehicleLongitude;
        static float _vehicleAltitude;