Skip to content
Snippets Groups Projects
Select Git revision
  • 2.2.0
  • master default protected
  • release/202005
  • release/202001
  • release/201912
  • release/201911
  • release/releaseWindowsTestOne
  • release/windowsReleaseTest
  • release/releaseTest
  • release/releaseWindowsTest
  • release/201910
  • release/qt/201910
  • release/windows-test/201910
  • release/201908
  • release/201906
  • release/201905
  • release/201904
  • release/201903
  • release/201902
  • release/201901
  • release/201812
  • 4.0.0
  • 2.1.0
  • 2.0.1
  • 2.0.0
  • 1.4.1
  • 1.4.0
  • 1.3.0
  • 1.2.0
  • 1.1.0
30 results

astylerc

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    configurationtest.cpp 8.73 KiB
    /*
     *  Copyright (C) 2004, 2005, 2006, 2008, 2009, 2010 Savoir-Faire Linux Inc.
     *  Author: Emmanuel Milou <emmanuel.milou@savoirfairelinux.com>
     *
     *  This program 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.
     *
     *  This program 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.
     *
     *  You should have received a copy of the GNU General Public License
     *  along with this program; if not, write to the Free Software
     *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
     *
     *  Additional permission under GNU GPL version 3 section 7:
     *
     *  If you modify this program, or any covered work, by linking or
     *  combining it with the OpenSSL project's OpenSSL library (or a
     *  modified version of that library), containing parts covered by the
     *  terms of the OpenSSL or SSLeay licenses, Savoir-Faire Linux Inc.
     *  grants you additional permission to convey the resulting work.
     *  Corresponding Source for a non-source form of such a combination
     *  shall include the source code for the parts of OpenSSL used as well
     *  as that of the covered work.
     */
    
    #include <stdio.h>
    #include <sstream>
    
    #include "configurationtest.h"
    #include "constants.h"
    #include "audio/alsa/alsalayer.h"
    #include "audio/pulseaudio/pulselayer.h"
    
    using std::cout;
    using std::endl;
    
    void ConfigurationTest::testDefaultValueAudio()
    {
        DEBUG("-------------------- ConfigurationTest::testDefaultValueAudio() --------------------\n");
    
        CPPUNIT_ASSERT(Manager::instance().audioPreference.getCardin() == 0);  // ALSA_DFT_CARD);
        CPPUNIT_ASSERT(Manager::instance().audioPreference.getCardout() == 0);  // ALSA_DFT_CARD);
        CPPUNIT_ASSERT(Manager::instance().audioPreference.getSmplrate() == 44100);  // DFT_SAMPLE_RATE);
        CPPUNIT_ASSERT(Manager::instance().audioPreference.getPlugin() == PCM_DEFAULT);
        CPPUNIT_ASSERT(Manager::instance().audioPreference.getVolumespkr() == 100);
        CPPUNIT_ASSERT(Manager::instance().audioPreference.getVolumemic() == 100);
    }
    
    void ConfigurationTest::testDefaultValuePreferences()
    {
        DEBUG("-------------------- ConfigurationTest::testDefaultValuePreferences --------------------\n");
    
        CPPUNIT_ASSERT(Manager::instance().preferences.getZoneToneChoice() == Preferences::DFT_ZONE);
    }
    
    void ConfigurationTest::testDefaultValueSignalisation()
    {
        DEBUG("-------------------- ConfigurationTest::testDefaultValueSignalisation --------------------\n");
    
        CPPUNIT_ASSERT(Manager::instance().voipPreferences.getSymmetricRtp());
        CPPUNIT_ASSERT(Manager::instance().voipPreferences.getPlayDtmf());
        CPPUNIT_ASSERT(Manager::instance().voipPreferences.getPlayTones());
        CPPUNIT_ASSERT(Manager::instance().voipPreferences.getPulseLength() == 250);
    }
    
    void ConfigurationTest::testInitAudioDriver()
    {
        DEBUG("-------------------- ConfigurationTest::testInitAudioDriver --------------------\n");
    
        // Load the audio driver
        Manager::instance().initAudioDriver();
    
        // Check the creation
    
        if (Manager::instance().getAudioDriver() == NULL)
            CPPUNIT_FAIL("Error while loading audio layer");
    
        // Check if it has been created with the right type
        if (Manager::instance().audioPreference.getAudioApi() == "alsa")
            CPPUNIT_ASSERT(!dynamic_cast<PulseLayer*>(Manager::instance().getAudioDriver()));
        else if (Manager::instance().audioPreference.getAudioApi() == "pulseaudio")
            CPPUNIT_ASSERT(!dynamic_cast<AlsaLayer*>(Manager::instance().getAudioDriver()));
        else
            CPPUNIT_FAIL("Wrong audio layer type");
    }
    
    
    void ConfigurationTest::testYamlParser()
    {
        try {
            Conf::YamlParser parser("ymlParser.yml");
            parser.serializeEvents();
            parser.composeEvents();
            parser.constructNativeData();
        } catch (const Conf::YamlParserException &e) {
           ERROR("ConfigTree: %s", e.what());
        }
    }
    
    void ConfigurationTest::testYamlEmitter()
    {
        using namespace Conf;
        MappingNode accountmap(NULL);
        MappingNode credentialmap(NULL);
        MappingNode srtpmap(NULL);
        MappingNode zrtpmap(NULL);
        MappingNode tlsmap(NULL);
    
        ScalarNode id("Account:1278432417");
        ScalarNode username("181");
        ScalarNode password("pass181");
        ScalarNode alias("sfl-181");
        ScalarNode hostname("192.168.50.3");
        ScalarNode enable(true);
        ScalarNode type("SIP");
        ScalarNode expire("3600");
        ScalarNode interface("default");
        ScalarNode port("5060");
        ScalarNode mailbox("97");
        ScalarNode publishAddr("192.168.50.182");
        ScalarNode publishPort("5060");
        ScalarNode sameasLocal(true);
        ScalarNode codecs("0/9/110/111/112/");
        ScalarNode stunServer("stun.sflphone.org");
        ScalarNode stunEnabled(false);
        ScalarNode displayName("Alexandre Savard");
        ScalarNode dtmfType("sipinfo");
    
        ScalarNode count("0");
    
        ScalarNode srtpenabled(false);
        ScalarNode keyExchange("sdes");
        ScalarNode rtpFallback(false);
    
        ScalarNode displaySas(false);
        ScalarNode displaySasOnce(false);
        ScalarNode helloHashEnabled(false);
        ScalarNode notSuppWarning(false);
    
        ScalarNode tlsport("");
        ScalarNode certificate("");
        ScalarNode calist("");
        ScalarNode ciphers("");
        ScalarNode tlsenabled(false);
        ScalarNode tlsmethod("TLSV1");
        ScalarNode timeout("0");
        ScalarNode tlspassword("");
        ScalarNode privatekey("");
        ScalarNode requirecertif(true);
        ScalarNode server("");
        ScalarNode verifyclient(true);
        ScalarNode verifyserver(true);
    
        accountmap.setKeyValue(aliasKey, &alias);
        accountmap.setKeyValue(typeKey, &type);
        accountmap.setKeyValue(idKey, &id);
        accountmap.setKeyValue(usernameKey, &username);
        accountmap.setKeyValue(passwordKey, &password);
        accountmap.setKeyValue(hostnameKey, &hostname);
        accountmap.setKeyValue(accountEnableKey, &enable);
        accountmap.setKeyValue(mailboxKey, &mailbox);
        accountmap.setKeyValue(registrationExpireKey, &expire);
        accountmap.setKeyValue(interfaceKey, &interface);
        accountmap.setKeyValue(portKey, &port);
        accountmap.setKeyValue(publishAddrKey, &publishAddr);
        accountmap.setKeyValue(publishPortKey, &publishPort);
        accountmap.setKeyValue(sameasLocalKey, &sameasLocal);
        accountmap.setKeyValue(dtmfTypeKey, &dtmfType);
        accountmap.setKeyValue(displayNameKey, &displayName);
    
        accountmap.setKeyValue(srtpKey, &srtpmap);
        srtpmap.setKeyValue(srtpEnableKey, &srtpenabled);
        srtpmap.setKeyValue(keyExchangeKey, &keyExchange);
        srtpmap.setKeyValue(rtpFallbackKey, &rtpFallback);
    
        accountmap.setKeyValue(zrtpKey, &zrtpmap);
        zrtpmap.setKeyValue(displaySasKey, &displaySas);
        zrtpmap.setKeyValue(displaySasOnceKey, &displaySasOnce);
        zrtpmap.setKeyValue(helloHashEnabledKey, &helloHashEnabled);
        zrtpmap.setKeyValue(notSuppWarningKey, &notSuppWarning);
    
        accountmap.setKeyValue(credKey, &credentialmap);
        SequenceNode credentialseq(NULL);
        accountmap.setKeyValue(credKey, &credentialseq);
    
        MappingNode credmap1(NULL);
        MappingNode credmap2(NULL);
        ScalarNode user1("user");
        ScalarNode pass1("pass");
        ScalarNode realm1("*");
        ScalarNode user2("john");
        ScalarNode pass2("doe");
        ScalarNode realm2("fbi");
        credmap1.setKeyValue(CONFIG_ACCOUNT_USERNAME, &user1);
        credmap1.setKeyValue(CONFIG_ACCOUNT_PASSWORD, &pass1);
        credmap1.setKeyValue(CONFIG_ACCOUNT_REALM, &realm1);
        credmap2.setKeyValue(CONFIG_ACCOUNT_USERNAME, &user2);
        credmap2.setKeyValue(CONFIG_ACCOUNT_PASSWORD, &pass2);
        credmap2.setKeyValue(CONFIG_ACCOUNT_REALM, &realm2);
        credentialseq.addNode(&credmap1);
        credentialseq.addNode(&credmap2);
    
        accountmap.setKeyValue(tlsKey, &tlsmap);
        tlsmap.setKeyValue(tlsPortKey, &tlsport);
        tlsmap.setKeyValue(certificateKey, &certificate);
        tlsmap.setKeyValue(calistKey, &calist);
        tlsmap.setKeyValue(ciphersKey, &ciphers);
        tlsmap.setKeyValue(tlsEnableKey, &tlsenabled);
        tlsmap.setKeyValue(methodKey, &tlsmethod);
        tlsmap.setKeyValue(timeoutKey, &timeout);
        tlsmap.setKeyValue(tlsPasswordKey, &tlspassword);
        tlsmap.setKeyValue(privateKeyKey, &privatekey);
        tlsmap.setKeyValue(requireCertifKey, &requirecertif);
        tlsmap.setKeyValue(serverKey, &server);
        tlsmap.setKeyValue(verifyClientKey, &verifyclient);
        tlsmap.setKeyValue(verifyServerKey, &verifyserver);
    
        try {
            YamlEmitter emitter("/tmp/ymlEmiter.txt");
    
            emitter.serializeAccount(&accountmap);
            emitter.serializeAccount(&accountmap);
            emitter.serializeData();
    
        } catch (const YamlEmitterException &e) {
           ERROR("ConfigTree: %s", e.what());
        }
    }