亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? clienttest.h

?? funambol windows mobile plugin source code, the source code is taken from the funambol site
?? H
?? 第 1 頁 / 共 2 頁
字號:
/*
 * Copyright (C) 2005-2007 Funambol, Inc
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY, TITLE, NONINFRINGEMENT 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., 59 Temple Place, Suite 330, Boston, MA
 * 02111-1307  USA
 */

#ifndef INCL_TESTSYNCCLIENT
#define INCL_TESTSYNCCLIENT
/** @cond API */
/** @addtogroup Client */
/** @{ */

#include <string>
#include <vector>
#include "spds/SyncSource.h"
#include "spds/SyncReport.h"

#ifdef ENABLE_INTEGRATION_TESTS

#include <cppunit/TestSuite.h>
#include <cppunit/TestAssert.h>
#include <cppunit/TestFixture.h>

/**
 * This class encapsulates logging and checking of a SyncReport.
 * When constructed with default parameters, no checking will be done.
 * Otherwise the sync report has to contain exactly the expected result.
 * When multiple sync sources are active, @b all of them have to behave
 * alike (which is how the tests are constructed).
 *
 * No item is ever supposed to fail.
 */
class CheckSyncReport {
  public:
    CheckSyncReport(int clAdded = -1, int clUpdated = -1, int clDeleted = -1,
                    int srAdded = -1, int srUpdated = -1, int srDeleted = -1) :
        clientAdded(clAdded),
        clientUpdated(clUpdated),
        clientDeleted(clDeleted),
        serverAdded(srAdded),
        serverUpdated(srUpdated),
        serverDeleted(srDeleted)
        {}

    const int clientAdded, clientUpdated, clientDeleted,
        serverAdded, serverUpdated, serverDeleted;

    /**
     * checks that the sync completed as expected and throws
     * CPPUnit exceptions if something is wrong
     *
     * @param res     return code from SyncClient::sync()
     * @param report  the sync report stored in the SyncClient
     */
    virtual void check(int res, SyncReport &report) const;
};

class LocalTests;
class SyncTests;

/**
 * This is the interface expected by the testing framework for sync
 * clients.  It defines several methods that a derived class must
 * implement if it wants to use that framework. Note that this class
 * itself is not derived from SyncClient. This gives a user of this
 * framework the freedom to implement it in two different ways:
 * - implement a class derived from both SyncClient and ClientTest
 * - add testing of an existing subclass of SyncClient by implementing
 *   a ClientTest which uses that subclass
 *
 * The client is expected to support change tracking for multiple
 * servers. Although the framework always always tests against the
 * same server, for most tests it is necessary to access the database
 * without affecting the next synchronization with the server. This is
 * done by asking the client for two different sync sources via
 * Config::createSourceA and Config::createSourceB which have to
 * create them in a suitable way - pretty much as if the client was
 * synchronized against different server. A third, different change
 * tracking is needed for real synchronizations of the data.
 *
 * Furthermore the client is expected to support multiple data sources
 * of the same kind, f.i. two different address books. This is used to
 * test full client A <-> server <-> client B synchronizations in some
 * tests or to check server modifications done by client A with a
 * synchronization against client B. In those tests client A is mapped
 * to the first data source and client B to the second one.
 *
 * Finally the SyncSource API is used in slightly different ways which
 * go beyond what is normally expected from a SyncSource implementation:
 * - beginSync() may be called without setting a sync mode:
 *   when SyncSource::getSyncMode() returns SYNC_NONE the source is
 *   expected to make itself ready to iterate over all, new, updated and
 *   deleted items
 * - items may be added via SyncSource::addItem() with a type of "raw":
 *   this implies that the type is the one used for items in the
 *   ClientTest::Config below
 *
 * Handling configuration and creating classes is entirely done by the
 * subclass of ClientTest, the frameworks makes no assumptions
 * about how this is done. Instead it queries the ClientTest for
 * properties (like available sync sources) and then creates several
 * tests.
 */
class ClientTest {
  public:
    ClientTest(int serverSleepSec = 0, const std::string &serverLog= "");
    virtual ~ClientTest();

    /**
     * This function registers tests using this instance of ClientTest for
     * later use during a test run.
     *
     * The instance must remain valid until after the tests were
     * run. To run them use a separate test runner, like the one from
     * client-test-main.cpp.
     */
    virtual void registerTests();

    class Config;

    /**
     * Creates an instance of LocalTests (default implementation) or a
     * class derived from it.  LocalTests provides tests which cover
     * the SyncSource interface and can be executed without a SyncML
     * server. It also contains utility functions for working with
     * SyncSources.
     *
     * A ClientTest implementation can, but doesn't have to extend
     * these tests by instantiating a derived class here.
     */
    virtual LocalTests *createLocalTests(const std::string &name, int sourceParam, ClientTest::Config &co);

    /**
     * Creates an instance of SyncTests (default) or a class derived
     * from it.  SyncTests provides tests which cover the actual
     * interaction with a SyncML server.
     *
     * A ClientTest implementation can, but doesn't have to extend
     * these tests by instantiating a derived class here.
     */
    virtual SyncTests *createSyncTests(const std::string &name, std::vector<int> sourceIndices, bool isClientA = true);

    /**
     * utility function for dumping items which are C strings with blank lines as separator
     */
    static int dump(ClientTest &client, SyncSource &source, const char *file);

    /**
     * utility function for importing items with blank lines as separator
     */
    static int import(ClientTest &client, SyncSource &source, const char *file);

    /**
     * utility function for comparing vCard and iCal files with the external
     * synccompare.pl Perl script
     */
    static bool compare(ClientTest &client, const char *fileA, const char *fileB);

    struct Config;

    /**
     * A derived class can use this call to get default test
     * cases, but still has to add callbacks which create sources
     * and execute a sync session.
     *
     * Some of the test cases are compiled into the library, other
     * depend on the auxiliary files from the "test" directory.
     * Currently supported types:
     * - vcard30 = vCard 3.0 contacts
     * - vcard21 = vCard 2.1 contacts
     * - ical20 = iCal 2.0 events
     * - vcal10 = vCal 1.0 events
     * - itodo20 = iCal 2.0 tasks
     */
    static void getTestData(const char *type, Config &config);

    /**
     * Information about a data source. For the sake of simplicity all
     * items pointed to are owned by the ClientTest and must
     * remain valid throughout a test session. Not setting a pointer
     * is okay, but it will disable all tests that need the
     * information.
     */
    struct Config {
        /**
         * The name is used in test names and has to be set.
         */
        const char *sourceName;

        /**
         * A default URI to be used when creating a client config.
         */
        const char *uri;

        /**
         * A member function of a subclass which is called to create a
         * sync source referencing the data. This is used in tests of
         * the SyncSource API itself as well as in tests which need to
         * modify or check the data sources used during synchronization.
         *
         * The test framework will call beginSync() and then some of
         * the functions it wants to test. After a successful test it
         * will call endSync() which is then expected to store all
         * changes persistently. Creating a sync source again
         * with the same call should not report any
         * new/updated/deleted items until such changes are made via
         * another sync source.
         *
         * The instance will be deleted by the caller. Because this
         * may be in the error case or in an exception handler,
         * the sync source's desctructor should not thow exceptions.
         *
         * @param client    the same instance to which this config belongs
         * @param source    index of the data source (from 0 to ClientTest::getNumSources() - 1)
         * @param isSourceA true if the requested SyncSource is the first one accessing that
         *                  data, otherwise the second
         */
        typedef SyncSource *(*createsource_t)(ClientTest &client, int source, bool isSourceA);

        /**
         * Creates a sync source which references the primary database;
         * it may report the same changes as the sync source used during
         * sync tests.
         */
        createsource_t createSourceA;

        /**
         * A second sync source also referencing the primary data
         * source, but configured so that it tracks changes
         * independently from the the primary sync source.
         *
         * In local tests the usage is like this:
         * - add item via first SyncSource
         * - iterate over new items in second SyncSource
         * - check that it lists the added item
         *
         * In tests with a server the usage is:
         * - do a synchronization with the server
         * - iterate over items in second SyncSource
         * - check that the total number and number of
         *   added/updated/deleted items is as expected
         */
        createsource_t createSourceB;

        /**
         * The framework can generate vCard and vCalendar/iCalendar items
         * automatically by copying a template item and modifying certain
         * properties.
         *
         * This is the template for these automatically generated items.
         */
        const char *templateItem;

         /**
         * This is a colon (:) separated list of properties which need
         * to be modified in templateItem.
         */
        const char *uniqueProperties;

        /**
         * the number of items to create during stress tests
         */
        int numItems;

        /**
         * This is a single property in templateItem which can be extended
         * to increase the size of generated items.
         */
        const char *sizeProperty;

        /**
         * A very simple item that is inserted during basic tests. Ideally
         * it only contains properties supported by all servers.
         */
        const char *insertItem;

        /**
         * A slightly modified version of insertItem. If the source has UIDs
         * embedded into the item data, then both must have the same UID.
         * Again all servers should better support these modified properties.
         */
        const char *updateItem;

        /**
         * A more heavily modified version of insertItem. Same UID if necessary,
         * but can test changes to items only supported by more advanced
         * servers.
         */
        const char *complexUpdateItem;

        /**
         * To test merge conflicts two different updates of insertItem are
         * needed. This is the first such update.
         */
        const char *mergeItem1;

        /**
         * The second merge update item. To avoid true conflicts it should
         * update different properties than mergeItem1, but even then servers
         * usually have problems perfectly merging items. Therefore the
         * test is run without expecting a certain merge result.
         */
        const char *mergeItem2;

        /**
         * called to dump all items into a file, required by tests which need
         * to compare items
         *
         * ClientTest::dump can be used: it will simply dump all items of the source
         * with a blank line as separator.
         *
         * @param source     sync source A already created and with beginSync() called
         * @param file       a file name
         * @return error code, 0 for success
         */
        int (*dump)(ClientTest &client, SyncSource &source, const char *file);

        /**
         * import test items: which these are is determined entirely by
         * the implementor, but tests work best if several complex items are
         * imported
         *
         * ClientTest::import can be used if the file contains items separated by
         * empty lines.
         *
         * @param source     sync source A already created and with beginSync() called
         * @param file       the name of the file to import
         * @return error code, 0 for success
         */
        int (*import)(ClientTest &client, SyncSource &source, const char *file);

        /**
         * a function which compares two files with items in the format used by "dump"
         *
         * @param fileA      first file name
         * @param fileB      second file name
         * @return true if the content of the files is considered equal
         */
        bool (*compare)(ClientTest &client, const char *fileA, const char *fileB);

        /**
         * a file with test cases in the format expected by import and compare
         */
        const char *testcases;

        /**
         * the item type normally used by the source (not used by the tests
         * themselves; client-test.cpp uses it to initialize source configs)
         */
        const char *type;
    };

    /**
     * Data sources are enumbered from 0 to n-1 for the purpose of
     * testing. This call returns n.
     */
    virtual int getNumSources() = 0;

    /**
     * Called to fill the given test source config with information
     * about a sync source identified by its index. It's okay to only
     * fill in the available pieces of information and set everything
     * else to zero.
     */
    virtual void getSourceConfig(int source, Config &config) = 0;

    /**
     * The instance to use as second client. Returning NULL disables
     * all checks which require a second client. The returned pointer
     * must remain valid throughout the life time of the tests.
     *
     * The second client must be configured to access the same server
     * and have data sources which match the ones from the primary
     * client.
     */
    virtual ClientTest *getClientB() = 0;

    /**

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区视频| 国产欧美一区二区三区在线看蜜臀 | 亚洲乱码国产乱码精品精的特点| 日韩国产在线观看一区| 国产成人精品一区二| 在线观看日韩电影| 一区二区三区鲁丝不卡| 成人天堂资源www在线| 精品奇米国产一区二区三区| 午夜伊人狠狠久久| 欧美午夜精品免费| 五月婷婷久久综合| 日韩一区二区精品在线观看| 午夜影院久久久| 日韩欧美成人一区二区| 精品一区二区在线观看| 欧美r级在线观看| 免费欧美日韩国产三级电影| 精品婷婷伊人一区三区三| 日韩激情一二三区| 2021国产精品久久精品| 国产99久久久国产精品潘金网站| 欧美电影精品一区二区| 韩国欧美国产一区| 国产精品国产自产拍在线| 色综合中文综合网| 日本91福利区| 久久久精品国产99久久精品芒果| 国产电影一区在线| 亚洲精品第一国产综合野| 欧美猛男超大videosgay| 石原莉奈一区二区三区在线观看| 欧美一区二区三区视频| 国产在线精品一区二区不卡了| 久久久久亚洲蜜桃| 欧美日韩国产天堂| 国产aⅴ精品一区二区三区色成熟| 亚洲欧美自拍偷拍| 3d动漫精品啪啪一区二区竹菊| 国精产品一区一区三区mba桃花| 日本一区二区三区电影| 欧美人妇做爰xxxⅹ性高电影| 精品一区二区日韩| 天堂成人国产精品一区| 欧美国产激情二区三区| 日韩亚洲欧美中文三级| 91一区二区三区在线播放| 日本特黄久久久高潮| 亚洲免费av高清| 久久久三级国产网站| 日韩精品一区二区在线观看| 国产成人av电影在线播放| 麻豆久久一区二区| 天天亚洲美女在线视频| 一区二区三区高清| 亚洲欧洲韩国日本视频| 久久午夜老司机| 日韩欧美美女一区二区三区| 在线免费观看日本一区| 国产美女主播视频一区| 亚洲精品大片www| 亚洲免费高清视频在线| 成人欧美一区二区三区小说| 久久久噜噜噜久噜久久综合| 91国产丝袜在线播放| 日本韩国视频一区二区| 欧美天堂一区二区三区| 欧美日韩大陆一区二区| 亚洲精品在线观看视频| 国产欧美中文在线| 亚洲精品免费看| 蜜桃在线一区二区三区| 国产九九视频一区二区三区| 不卡一二三区首页| 欧美三级韩国三级日本三斤| 国产欧美一区二区在线观看| 日韩精品中午字幕| 91麻豆视频网站| 成人性生交大片免费| 91福利视频在线| 欧美一卡二卡三卡| 国产精品天干天干在线综合| 国产精品国产三级国产普通话三级| 亚洲午夜精品网| 国产在线精品一区在线观看麻豆| 成人精品一区二区三区四区| 欧美午夜影院一区| 精品美女在线观看| 亚洲一区二区三区激情| 国产不卡在线一区| 制服丝袜国产精品| 综合网在线视频| 免费看日韩a级影片| 国产91精品精华液一区二区三区| 欧美在线free| 亚洲六月丁香色婷婷综合久久 | 久久亚洲捆绑美女| 亚洲一区二区av在线| 国产一区二区影院| 欧美一区二区三区视频免费播放| 亚洲精品一二三区| 91在线精品一区二区三区| 国产精品福利一区| www.性欧美| 一区二区三区在线观看国产| 成人激情图片网| 国产精品色在线观看| 精品一区二区三区免费播放| 欧美群妇大交群中文字幕| 视频一区视频二区中文字幕| 欧美日韩综合一区| 久久av资源网| 亚洲精品一区二区在线观看| 韩国精品主播一区二区在线观看| 精品国产亚洲在线| 成人高清视频免费观看| 亚洲人成人一区二区在线观看 | 亚洲成人tv网| 在线观看91精品国产麻豆| 日本在线不卡视频| 国产日韩欧美麻豆| 欧美性受xxxx| 国产在线观看一区二区| 亚洲精品视频一区| 日韩你懂的在线播放| 成人性生交大片免费看中文| 亚洲乱码日产精品bd| 欧美三级电影精品| 激情综合网av| 五月婷婷另类国产| 中文av字幕一区| 91精品国产手机| 成人黄色网址在线观看| 一区二区三区高清不卡| 久久精品一级爱片| 91精品一区二区三区在线观看| 成人动漫av在线| 久久狠狠亚洲综合| 亚洲免费av高清| 国产亚洲一区二区在线观看| 欧美日韩综合在线| 91老师片黄在线观看| 成人综合激情网| 久久精品噜噜噜成人av农村| 尤物在线观看一区| 国产精品久久久久aaaa樱花| 2021中文字幕一区亚洲| 精品国产免费人成在线观看| 欧美亚洲尤物久久| 欧美图片一区二区三区| 国产福利精品一区二区| 国产精品69久久久久水密桃| 久久不见久久见中文字幕免费| 久久99国产精品尤物| 日韩成人午夜精品| 蜜臀久久99精品久久久久久9| 亚洲 欧美综合在线网络| 亚洲综合视频在线| 日韩国产精品91| 激情综合一区二区三区| 亚洲不卡一区二区三区| 亚洲午夜视频在线| 日本特黄久久久高潮| 国产一区日韩二区欧美三区| 蜜桃视频一区二区| 国产一区二区不卡| 成人黄色国产精品网站大全在线免费观看| 激情综合色播五月| 国产黄色成人av| 欧美日韩国产在线播放网站| 欧美猛男超大videosgay| 日韩欧美成人一区| 国产精品家庭影院| 日韩成人av影视| 99精品久久久久久| 精品免费视频.| 亚洲国产精品久久久男人的天堂| 午夜视频久久久久久| 国产成人一级电影| 欧美偷拍一区二区| 国产精品成人免费| 日本不卡中文字幕| 成人毛片视频在线观看| 日韩视频免费观看高清完整版| 国产精品久久看| 久久国产精品一区二区| 欧美午夜精品久久久久久超碰| 久久综合九色欧美综合狠狠| 午夜电影一区二区三区| 日本黄色一区二区| 一区二区三区精品视频| 国产精品自拍网站| 日韩欧美一二三四区| 天天免费综合色| 欧美写真视频网站| 亚洲va国产va欧美va观看| 99久久精品免费精品国产| 久久免费偷拍视频| 国产成人啪午夜精品网站男同| 国产色91在线|