summaryrefslogtreecommitdiff
path: root/cpp/test/Ice/logger/Client1.cpp
blob: a60a31b836ddf28429fe8d3c843668c80e86c4b3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
// **********************************************************************
//
// Copyright (c) 2003-2016 ZeroC, Inc. All rights reserved.
//
// This copy of Ice is licensed to you under the terms described in the
// ICE_LICENSE file included in this distribution.
//
// **********************************************************************

#include <Ice/Ice.h>
#include <TestCommon.h>
#include <fstream>

using namespace std;

namespace
{

class Client : public Ice::Application
{
public:
    virtual int
    run(int, char*[])
    {
        communicator()->getLogger()->trace("info", "XXX");
        return EXIT_SUCCESS;
    };
};

}

int
main(int argc, char* argv[])
{
#ifdef ICE_STATIC_LIBS
    Ice::registerIceSSL();
#endif

    cout << "testing logger encoding with Ice.LogFile... " << flush;
    Ice::InitializationData id;
    id.properties = Ice::createProperties();
    id.properties->load("config.client");
    id.properties->setProperty("Ice.LogFile", "log.txt");
    const string programName = id.properties->getProperty("Ice.ProgramName");

    Client c;
    c.main(argc, argv, id);

    ifstream in("log.txt");
    if(!in)
    {
        test(false);
    }
    string s;
    if(!getline(in, s))
    {
        test(false);
    }
    test(s.find(programName) != string::npos);
    in.close();
    remove("log.txt");
    cout << "ok" << endl;
    return EXIT_SUCCESS;
}